温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

CSS3中webkit-overflow-scolling怎么使用

发布时间:2022-03-09 15:20:48 来源:亿速云 阅读:416 作者:iii 栏目:web开发

这篇文章主要介绍“CSS3中webkit-overflow-scolling怎么使用”,在日常操作中,相信很多人在CSS3中webkit-overflow-scolling怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS3中webkit-overflow-scolling怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    我们都知道在ios的safari浏览器和app内核浏览器中,当一个h6页面内容超出屏幕高度,我们手指去滑动屏幕的时候,只要手势一离开屏幕,滚动立刻结束。这时候我们可以通过设置-webkit-overflow-scrolling=touch来使页面可以顺畅滚动,但是设置这个也会引出许多问题。

    1、单独对body设置-webkit-overflow-scrollingtouch是无效的,需要针对html和body同时设置才有效果,代码如下:

    html,body{

    height:100%;

    overflow:auto;

    -webkit-overflow-scrolling:touch;

    }

    2、父容器设置-webkit-overflow-scrolling=touch后,子容器不允许出现fixed固定的子元素,为什么这么说呢。因为当你设定-webkit-overflow-scrolling=touch后,你滑动屏幕的时候会发现fixed属性失效了,他也跟着屏幕滚动了,只有当滚动停止的时候这个元素才会在固定到页面上。显然这不是我们要的结果。

    这里我的解决方法是不把-webkit-overflow-scrolling设置在body元素上,在需要滚动的地方另外增加div容器去设定,然后把需要fixed的容器都直接放在body元素内。

    3、单独对div设定-webkit-overflow-scrolling属性无效,经测试后发现,我需要先对父容器div1设定为有高度的容器,然后在对超出的子容器设定-webkit-overflow-scrolling属性具体代码如下:

    <style>.div-p{width:100%;height:500px;/*这是测试值,具体针对项目需求设置,不要超出子容器内容高度*/overflow:hidden;/*设不设定这个值对-webkit-overflow-scrolling没有影响*/}

    .div-c{width:100%;height:2000px;overflow:auto;/*测试发现一定要设定这个值才起作用*/-webkit-overflow-scrolling:touch;}</style>

    <divclass="div-p">

    <divclass="div-c">我要滚动啊,,在ios要顺畅啊</div>

    </div>

    经过反复测试发现如下设置也是能有效触发-webkit-overflow-scrolling属性的,具体代码如下:

    <style>

    .content-box{

    height:500px;/*经过测试后发现只要设定的这个高度小于屏幕高度,-webkit-overflow-scrolling属性也能有效触发*/

    border:solid1pxgreen;

    overflow:auto;

    -webkit-overflow-scrolling:touch;}

    </style>

    <body>

    <divclass="content-box">哎呀我是要滚动的啊<br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    <br>

    有效果的哦。。。

    </div>

    </body>

    当然,以上的版本就得在html渲染结束的时候去改变他的高度,以达到和屏幕高度一致,但是这种方式的维护性太差,后来又找到一种解决方案,具体代码如下:

    <style>

    .ios-scroll-father{

    position:absolute;

    top:0;

    bottom:0;

    left:0;

    width:10rem;

    height:100%;}

    .ios-scroll-child{

    position:absolute;

    top:0;

    bottom:0;

    left:0;

    width:10rem;

    overflow:auto;}

    -webkit-overflow-scrollingtouch

    </style>

    <divclass="ios-scroll-father">

    <divclass="ios-scroll-child">

    我要完美解决ios的顺畅滑动问题啊,,,来试试咯。演示,请自己添加代码到超出屏幕内容哦~

    </div>

    </div>

    这里,要提个醒,设置-webkit-overflow-scrolling属性的同时要么不要设定height,要么height+padding的高度不要超出屏幕的高度,不然你会发现等你滚动到顶部或者底部的时候会被截取掉一部分,需要你在滑动才能出现。。。这是个坑啊,本人一不小心设定高度百分百和padding后发现了这种现象,然后找来找去都找不到问题,只能删减代码慢慢排查。

    4、当然,如果只是这些问题,那还真是好解决,可是,可是,某天写了个列表,需要做滚动分页特效,这时候我去兼听滚动条的滚动事件,发现scrollTop不会时时更新,要等到页面停止滚动后才能获取到scrollTop值。

到此,关于“CSS3中webkit-overflow-scolling怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI