IOS移动端 -webkit-overflow-scrollin属性造成的问题
-webkit-overflow-scrolling带来的相关问题。
-webkit-overflow-scrolling 属性控制元素在移动设备上是否使用滚动回弹效果.
其具有两个属性:
auto: 使用普通滚动, 当手指从触摸屏上移开,滚动会立即停止。
touch: 使用具有回弹效果的滚动, 当手指从触摸屏上移开,内容会继续保持一段时间的滚动效果。继续滚动的速度和持续的时间和滚动手势的强烈程度成正比。同时也会创建一个新的堆栈上下文。
在查找相关资料时,有看见这样一个问题,虽然在开发过程中并没有遇见,但防患未然还是做一个记录。
如果在-webkit-overflow-scrolling:touch属性的元素上,想通过动态添加内容来撑开容器,触发滚动,页面会卡住不动。(测试中未复现此bug)。
给出的解决方案:给内容最小高度101%;主动触发scrollbar。
你也可以直接加伪元素上
滚动的盒子:after { min-height: calc(100% + 1px)}
OS回弹现象产生的问题
滚动元素的滚动条在顶部时做下拉操作,或滚动条在底部时做上滑操作时,引发窗口反弹。此时滚动元素的滚动事件暂时失效。
解决方案可引用inobounce.js,其原理为:
判断当前浏览器是否支持-webkit-overflow-scrolling:touch属性。
若存在,监听touchstart和touchmove事件
window.addEventListener('touchstart ',handleTouchstart, { passive : false });
window.addEventListener('touchmove',handleTouchmove,{ passive : false });
在touchstart中获取触摸点的y(startY)坐标
在touchmove中通过循环查找,如果当前事件源的祖先元素具有-webkit-overflow-scrolling:touch属性,且完全计算属性overflow-yauto或者overflow-yscroll 则进一步做判断,否则阻止默认事件。
var handleTouchmove = function(evt)
var el = evt.target; //获取当前事件源
var zoom = window.innerWidth / window.document.documentElement.clientWidth;
if (evt.touches.length > 1 || zoom !== 1) {
return;
}
//检查是否存在可滚动的祖先元素
while (el !== document.body && el !== document) {
//获取样式属性
var style = window.getComputedStyle(el);
if (!style) { // 如果遇到无法计算样式的元素,请退出
break;
}
//忽略input元素
if (el.nodeName === 'INPUT' && el.getAttribute('type') === 'range') {
return;
}
var scrolling = style.getPropertyValue('-webkit-overflow-scrolling');
var overflowY = style.getPropertyValue('overflow-y');
var height = parseInt(style.getPropertyValue('height'), 10);
var isScrollable = scrolling === 'touch' && (overflowY === 'auto' || overflowY === 'scroll');
var canScroll = el.scrollHeight > el.offsetHeight;
// 如果检查的元素具有回弹属性,且可滚动。
if (isScrollable && canScroll) {
//获取当前触摸点的y( curY )坐标
var curY = evt.touches ? evt.touches[0].screenY : evt.screenY;
//滚动条位于顶部,且用户进行下拉操作
var isAtTop = (startY <= curY && el.scrollTop === 0);
//滚动条位于底部,且用户进行上滑操作,此时窗口也会反弹
var isAtBottom = (startY >= curY && el.scrollHeight - el.scrollTop === height);
// 这两种情况下窗口会都会反弹,为避免这种现象,此时阻止默认事件
if (isAtTop || isAtBottom) {
evt.preventDefault();
}
return;
}
// 测试元素不具有回弹属性,且不可滚动,继续测试其父元素
el = el.parentNode;
}
// 祖先元素都不具有回弹属性,且不可滚动,则阻止默认事件
evt.preventDefault();
};
Element.scrollHeight 这个只读属性是一个元素内容高度的度量,包括由于溢出导致的视图中不可见内容。
以上方式虽然可解决当滚动条到达底部或顶部时,窗口整体下移或上移,导致内部滚动事件暂时性失效问题
不过也使得滚动容器自身回弹效果的部分丢失。
可改进的一个想法的记录:
在touchstart事件中判断祖先元素是否具有回弹属性。且当滚动条在顶部或底部时对应的将滚动条的位置置为1或底部滚动最大距离-1。
阻止其他自身或祖先元素不具有滚动条的元素的默认事件。
在做测试时发现在非轻触时是可以实现的,但是触摸事件急促短暂时,窗口依旧整体下移。
移动端唤起软键盘引起的问题
当input框聚焦时,移动端唤起软键盘,页面整体太高,当软键盘消失后,如果input框的祖先元素是固定定位,则元素视觉上回到之前的位置,但实际上窗口的滚动条为负,页面出现错位现象,如果祖先元素是绝对定位,元素会停留在软键盘存在时的位置,需手动滑动页面恢复原状。
解决方法:中心思想是在失焦事件时设置window.scroll(0,0)。
但是,当页面内存在两个以上的输入框时,在输入框切换之间,会存在聚焦失焦聚焦事件,如果未做判断,此时会出现输入框切换间页面上下抖动。
解决方式:在失焦事件中设置定时器,定时器内部设置window.scroll(0,0)在聚焦事件中清除定时器。即保证了在软键盘存在时不触发window.scroll(0,0)。
IOS移动端 -webkit-overflow-scrollin属性造成的问题的更多相关文章
- iOS 移动端生成工具开发
代码地址如下:http://www.demodashi.com/demo/11284.html 一.准备工作 编译环境 xcode 用于生成冗余架构代码, 实现生成零耦合架构 二.程序实现 上个月的一 ...
- IOS开发UI篇—导航控制器属性和基本使用
IOS开发UI篇—导航控制器属性和基本使用 一.导航控制器的一些属性和基本使用 1.把子控制器添加到导航控制器中的四种方法 (1) 1.创建一个导航控制器 UINavigationController ...
- IOS 杂笔-19(属性与变量的优缺点)
IOS 杂笔-19(属性与变量的优缺点) 在前面的文章中我介绍了属性与变量的区别.这篇博客我将会简单介绍一下属性与变量的优缺点. 变量 优点: 访问速度快 缺点: 使用不灵活 属性 缺点: 耗时 优点 ...
- ele.me在IOS浏览器端启动APP的技巧分析
ele.me在IOS浏览器端启动APP的技巧分析 巧妙利用后台重定向,在schemes启动时提示用户打开,启动不了APP时能够及时跳转至下载页面. 避免报错页面的出现以及用户还没来的及选择就跳转到下载 ...
- iOS对UIViewController生命周期和属性方法的解析
目录[-] iOS对UIViewController生命周期和属性方法的解析 一.引言 二.UIViewController的生命周期 三.从storyBoard加载UIViewController实 ...
- {前端CSS} 语法 Css的几种引入方式 css选择器 选择器的优先级 CSS属性相关 背景属性 边框 CSS盒子模型 清除浮动 overflow溢出属性 定位(position)z-index
前端CSS CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素,给HTML设置样式,让它更加美观. 当浏览器读到一个样式表,它就会按照这个样式表来对文 ...
- [Web 前端] inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移
cp from : https://blog.csdn.net/iefreer/article/details/50421025 在表单修改界面中常会使用一个标签.一个内容加一个修改按钮来组成单行界面 ...
- 【iOS开发】iOS对UIViewController生命周期和属性方法的解析
iOS对UIViewController生命周期和属性方法的解析 一.引言 作为MVC设计模式中的C,Controller一直扮演着项目开发中最重要的角色,它是视图和数据的桥梁,通过它的管理,将数据有 ...
- html5音频audio对象处理以及ios微信端自动播放和息屏后唤醒的判断---可供参考(功能都完整实现了,只是细节还没处理的很好)
// html模版中的 此处结合了weui样式整合的微信手机端片段代码(不可直接粘贴复制进行使用)里面含有一些php的写法,可直接略过..###重点参考js代码### <div> < ...
- ios移动端浏览器点击事件失效的解决方案
点击事件失效的原因可能是因为,你用了事件代理了, 比如这样 $(document).on("click",".fd",function(){ }) 这段代码在安 ...
随机推荐
- 通过Metricbeat实现外部对Elastic Stack的监控
对于Elastic Stack监视的所有用户,建议使用外部数据收集. 概括一下: 关闭Elastic Stack自带的监控功能,然后使用metricbeat收集Elastic Stack数据传输到另外 ...
- 使用logstash读取MySQL数据传输到es,并且@timestamp字段采用MySQL中的字段时间--建议采用这个
MySQL中数据样式 ES中数据样式 input { jdbc { jdbc_connection_string => "jdbc:mysql://192.168.0.145:3306 ...
- 驱动开发:内核中实现Dump进程转储
多数ARK反内核工具中都存在驱动级别的内存转存功能,该功能可以将应用层中运行进程的内存镜像转存到特定目录下,内存转存功能在应对加壳程序的分析尤为重要,当进程在内存中解码后,我们可以很容易的将内存镜像导 ...
- TF-GNN踩坑记录(三)
引言 Batch size问题 在Tensorflow-GNN中使用batch size除了需要注意上面的链接问题之外,最近我在调试的发现,使用了merge_batch_to_components() ...
- mysql安装教程-window操作系统
1.下载安装包(官网下载) 直达链接:https://dev.mysql.com/downloads/mysql/ 下载后放到指定目录下解压即可(给电脑新手忠告:注意不要放在C盘,养成好习惯,放C盘多 ...
- 【Chrome浏览器】关闭触摸板双指滑动进行前进后退的功能
痛点 Chrome浏览器使用过程中,当前页面经常会莫名其妙地退回到上一个浏览的页面. 当时真是一脸懵B(心里一万头草泥马呼啸而过~)!以为活见鬼了! 后来才发现浏览器左边,有一个幽灵般的淡蓝色箭头的出 ...
- jenkins集成基于maven的javaweb项目,部署到docker容器中
使用开源工具:Jenkins,码云gitee,docker,docker页面管理工具PortainerUI,github 各种工具的安装就不必介绍了,首先打开Jenkins,刚安装完Jenkins,可 ...
- python爬虫下载小说
1. from urllib.request import urlopen from urllib import request from bs4 import BeautifulSoup from ...
- 6.pygame-搭建主程序
职责明确 新建plane_main.py 封装主游戏类 创建游戏对象 启动游戏 新建plane_sprites.py 封装游戏中所有需要使用的精灵子类 提供游戏的相关工具 #plane_sprit ...
- CSP2022游记
第一次几乎完全没有准备的比赛 也是倒数第二场比赛 Day -1 上了一天文化课,晚上还有强基班. 强基班上完之后来机房写了几个板子就开始颓废了 基本上就抱着摆烂的心态 不过是第一次在学校拿到手机 还在 ...