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(){ }) 这段代码在安 ...
随机推荐
- P7113 [NOIP2020] 排水系统 (拓扑排序)
(不想打高精,也不想学习其他大佬的神仙写法,打了90分的错解). 本题容易想到用拓扑排序处理,涉及分数的加法,用long long会超时,不过通分时先除后乘卡一下也可以拿90分. 结构体真是个复杂的东 ...
- 代码随想录第十三天 | 150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素
第一题150. 逆波兰表达式求值 根据 逆波兰表示法,求表达式的值. 有效的算符包括 +.-.*./ .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 注意 两个整数之间的除法只保留整数部分. ...
- Docker容器虚拟化
Docker容器虚拟化 目录 Docker容器虚拟化 虚拟化网络 单节点容器间通信 不同节点容器间通信 虚拟化网络 Network Namespace 是 Linux 内核提供的功能,是实现网络虚拟化 ...
- 程序员便于开发的一些工具、网站、App。
http://www.kancloud.cn 关于文档,各种技术,框架的学习指南,API文档搜索方便. https://leetcode.com/ 程序员刷题面试网站,无聊的时候可以做一做.
- 作用域通信对象:session用户在登录时通过`void setAttribute(String name,Object value)`方法设置用户名和密码。点击登录按钮后,跳转到另外一个页面显示用户
作用域通信对象:session session对象基于会话,不同用户拥有不同的会话.同一个用户共享session对象的所有属性.作用域开始客户连接到应用程序的某个页面,结束与服务器断开连接.sessi ...
- 去除router-link中的下划线
文章目录 1.设置router-link的样式 2.效果展示 1.设置router-link的样式 text-decoration: none; 2.效果展示
- Vue3 SFC 和 TSX 方式自定义组件实现 v-model
1 v-model 1.1 理解 v-model v-model 是 vue3 中的一个内置指令,很多表单元素都可以使用这个属性,如 input.checkbox 等,咱可以在自定义组件中实现 v-m ...
- 学习ASP.NET Core Blazor编程系列八——数据校验
学习ASP.NET Core Blazor编程系列一--综述 学习ASP.NET Core Blazor编程系列二--第一个Blazor应用程序(上) 学习ASP.NET Core Blazor编程系 ...
- python视频与帧图片的相互转化,以及查看视频分辨率
1.拆分视频为帧图片 import cv2 def video2frame(videos_path,frames_save_path,time_interval): vidcap = cv2.Vide ...
- python查找相似图片或重复图片
1.查找重复图片 利用文件的MD5值可查找完全一样的重复图片 import os,time,hashlib def getmd5(file): if not os.path.isfile(file): ...