整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

css设置高度height: 100%滚动条无法显示的解决办法

是在写样式的时候,会碰到给div无论怎么加样式 overflow-y: auto 的时候,都不会出现垂直的滚动条,经过不断折腾终于知道是啥原因导致了。

<style>

body{

height: 100%; //若是所有的div的高度都不固定,需要body高度也是100%,才可以出现滚动条

}

.parent{

//你自己样式

height: 100%; //父元素的高度也需要是100%才可以出现滚动条

}

.children{

overflow-y: auto;

overflow-x: hidden;

height: 100%;

}

</style>


<div class="parent">

<div class="children">

xx-blog主题

xxzhuti主题网

</div>

辑导语:产品中我们经常会遇到上下滑动的页面,比如我们在进行预览页面时,需要上下滑动进行查看;本文作者分享了关于实现移动端页面上下滑动效果的Axure教程,我们一起来了解一下。

案例展示:https://ctm29p.axshare.com/#id=1btojr

工具:Axure RP9

本文章会介绍2种实现页面上下滑动效果的方法(学会这两种方法就够用了)。

01 方法一:(超级便捷)

这个方法重点是利用了“动态面板”的“滚动条”垂直滚动的功能是实现内容上下滑动的效果。

设计思路如下:

1. 先画出页面基本结构

如下图:基于(375*667)iPhone8的宽高,顶部和底部2个矩形(375*50),中间1个动态面板(375*567)。

2. 对动态面板进行设置(重点来了)

1)填充滚动预览的内容:双击【动态面板】,进入state1,然后再里面那个框框里填东西,使劲填,至少要填超过动态面板的高度。

2)实现内容滚动:关闭state1,然后选中【动态面板】右击选中【滚动条】选择【垂直滚动】。

或者如下图操作:

点击“预览”,上下滑动的效果就实现了,so easy!但是你会发现中有一条滚动条在右边好抓狂,影响美观。

3)隐藏滚动条:我们可以用一个矩形这个滚动条给遮挡起来(魔高一尺道高一丈,( ̄▽ ̄)/嘚瑟)如下图:

点击预览,完美。

02 方法二:(没有滚动条的烦恼)

这个方法比方法一稍微难理解一丢丢,可以跟着下面的操作步骤一边操作一边理解额。

这个方法是在于对动态面板2的内容会跟随操作动态面板1的滚动而移动,并对滑动界限设置。

设计思路如下:

gif动态来源于:http://www.woshipm.com/rp/420885.html

1. 先画出页面基本结构

一如既往先画个模型,如下图:基于(375*667)iPhone8的宽高,顶部和底部2个矩形(375*50),中间1个动态面板1(375*567),再在动态面板1的state1中添加一个动态面板2(375*567)。

2. 渐进明细

1)在动态面板2的state1中填充内容;使劲填充内容,至少要填超过动态面板1的高度,完成后才能看到滑动效果。

2)拖动 动态面板1 时,动态面板2跟随垂直拖动而移动;选中【动态面板1】点击【新建交互】选中【拖动时】-【移动】目标选择“动态面板2”,移动选择“跟随垂直拖动”点击“完成”,如图下设置:

3)拖动结束 动态面板1时,如果动态面板2未接触到顶部矩形时,移动动态面板2开头回到顶部。

  • 选中【动态面板1】点击【新建交互】选择【拖动结束时】点击【启用情形】;
  • 添加情形1:如果范围于 动态面板2 未接触 范围于 顶部矩形;
  • 在情形1下添加动作:【添加动作】-【移动】动态面板2 到达 (0,0) 点击“完成”;如下图设置:

4)拖动结束 动态面板1时,如果动态面板2未接触到底部矩形时,移动动态面板2结尾回到底部;操作步骤和(3)基本一致。

  • 在【拖动结束时】添加情形2:如果范围于 动态面板2 未接触 范围于 底部矩形;
  • 在情形2下添加动作:【添加动作】-【移动】动态面板2 到达 (0,-222) 点击“完成”;如下图设置:(tip:动态面板1的高 – 动态面板2的高 = -222)。

点击预览,完美。

终于写完了o(╥﹏╥)o,希望也能帮到有缘的你们额。

本文由 @人事匆匆 原创发布于人人都是产品经理,未经作者许可,禁止转载。

题图来自Unsplash,基于CC0协议。

看个锚点定位的例子

发现页面唰的一些就到顶部了,快到我们懵逼了。。。

开始解决

scroll-behavior

CSS属性 scroll-behavior 为一个滚动框指定滚动行为,其他任何的滚动,例如那些由于用户行为而产生的滚动,不受这个属性的影响。在根元素中指定这个属性时,它反而适用于视窗。

scroll-behavior:smooth 写在滚动容器元素上,可以让容器的滚动变得平滑。

在网页默认滚动是在<html>标签上,移动端大多数在<body>标签上。

我们可以这样加:

html, 
body { scroll-behavior:smooth; }

加了以后的效果如下:

这是录制的GIF图,效果没那么好。 大家可以动手试一下,滑动体验非常不错。

缺点

兼容性不够好

当然我们可以通过js来做个类似

Element.scrollIntoView() 方法

DOM元素的scrollIntoView() 方法让当前的元素滚动到浏览器窗口的可视区域内,通过触发滚动容器的定位实现。

DOM元素的scrollIntoView()方法 是原生JS 兼容到IE6,兼容性非常好。

参数如下

{
 behavior: "auto" | "instant" | "smooth", // 默认 auto
 block: "start" | "center" | "end" | "nearest", // 默认 center
 inline: "start" | "center" | "end" | "nearest", // 默认 nearest
}

解释一下这三个参数:

  1. behavior 表示滚动方式。auto 表示使用当前元素的 scroll-behavior 样式。instant 和 smooth 表示 直接滚到底 和 使用平滑滚动。
  2. block 表示块级元素排列方向要滚动到的位置。对于默认的 writing-mode: horizontal-tb 来说,就是竖直方向。start 表示将视口的顶部和元素顶部对齐;center 表示将视口的中间和元素的中间对齐;end 表示将视口的底部和元素底部对齐;nearest 表示就近对齐。
  3. inline 表示行内元素排列方向要滚动到的位置。对于默认的 writing-mode: horizontal-tb 来说,就是水平方向。其值与 block 类似。

用法:

html:

<div class="wrap">
 <div onClick="onScrollIntoView()">点击让黑色块到顶部</div>
 <ul class="body">
 <li>1</li>
 <li>2</li>
 <li id="box">我是黑色</li>
 <li>3</li>
 <li>4</li>
 </ul>
</div>

js:

function onScrollIntoView () {
 var element = document.getElementById("box");
 element.scrollIntoView({behavior: "smooth"});
}

效果:

这回大家再也不用害怕做锚点定位啦。

最后我们在说一个关于页面滚动问题吧,那就是 返回顶部 功能实现

返回顶部 功能实现

我们常用定时器 setInterval 来不断减去高度。

如:当前距离顶部 1000, 我们每10毫秒减50,

var timer = setInterval(function() { // 定时器 每10毫秒执行一次
 // 顶部距离 document.body.scrollTop = 1000 
 var speed = 50 // 返回顶部速度 
 document.body.scrollTop = document.body.scrollTop - speed
 if (document.body.scrollTop === 0) { // 返回到达顶部后, 销毁定时器
 clearInterval(timer)
 }
}, 10)

效果:

大家会发现,页面返回是滚动起来很干。 没10毫秒减50. 很平均,在交互上效果并不好。

借鉴上面 scroll-behavior:smooth 的交互效果。 缓动的返回顶部。

改一下计算方式:1000/2 = 500, 500/2 =250, 250/2 = ...... 这样滑动起来是不是就平滑了呢?

换算成公式:开始位置 = 开始位置 + (结束位置 - 开始位置) / 速度

document.body.scrollTop = 1000 + (0 - 1000) / 2

公式太烦了还是上代码吧:

var onTop = function (a, b, c, d) {
 if (a == b || typeof a != 'number') {
 return
 }
 b = b || 0
 c = c || 2
 
 var speed = function () {
 a = a + (b - b) / c
 
 if (a < 1) {
 d(b, true)
 return
 }
 d(a, false)
 requestAnimationFrame(speed)
 }
 speed()
}
  • a 开始位置
  • b 结束位置
  • c 速度
  • d 位置回调,d(当前的位置值, 否动画结束)


调用:

var target = document.body.scrollTop ? document.body : document.documentElement
onTop(target.scrollTop, 0, 4, function (value) {
 target.scrollTop = value
})

效果:

Ps: gif录制效果不好,大家可以动手写一下DEMO