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(){ }) 这段代码在安 ...
随机推荐
- 普通用户使用CI/CD权限使用
根据文章:授权用户访问名称空间 (https://www.cnblogs.com/sanduzxcvbnm/p/15015576.html) 进行有关操作后,普通用户点击 会报错如下信息: 解决办法: ...
- centos离线安装nvm
PS:因为项目需,客户现场不能联网需要不同的node版本来切换,里面已经内置好了node 8.11.2和12.1.0 两个版本,使用nvm可以切换 链接:https://pan.baidu.com/s ...
- Wine 安装迅雷5.8.14.176
测试过的系统版本:Kubuntu 22.04 测试过的Wine版本 Wine7.8 程序下载地址: https://pan.baidu.com/s/1pSgunVH3WtACssX5we3DdQ 提取 ...
- Allure的简单使用
Allure的简单使用 1.Allure简介 简单的理解下,可以把Allure当成一个用于生成美观测试报告的开源工具,配合Pytest测试框架使用更佳. 也就是说,Allure是在Pytest执行测试 ...
- 浅谈MySQL、Hadoop、BigTable、Clickhouse数据读写机制
个人理解,欢迎指正 数据库 引擎 写数据 读数据 补充 MySql InnoDB:支持事务,高速读写性能一般 Myisam:不支持事务,高速读写性能好 以InnoDB更新一条记录为例 1.B+Tree ...
- Vue学习之--------el与data的两种写法、MVVM模型、数据代理(2022/7/5)
文章目录 1.el与data的两种写法 1.1.基础知识 1.2.代码实例 1.3.页面效果 2.MVVM模型 2.1. 基础知识 2.2 .代码实例 2.3.页面效果 3.数据代理 3.1. 基础知 ...
- golang中的errgroup
0.1.索引 https://waterflow.link/articles/1665239900004 1.串行执行 假如我们需要查询一个课件列表,其中有课件的信息,还有课件创建者的信息,和课件的缩 ...
- python查找相似图片或重复图片
1.查找重复图片 利用文件的MD5值可查找完全一样的重复图片 import os,time,hashlib def getmd5(file): if not os.path.isfile(file): ...
- 43.Permission源码解析和自定义权限类
drf的权限类位于permission模块 如何确定权限 认证.限流,权限决定是否应该接收请求或拒绝访问 权限检查在视图的最开始处执行,在继续执行其他代码前 权限检查通常会使用request.us ...
- 狂神说mysql笔记
1.mysql 基本操作 Windows-->Mysql5.7打开 输入用户名和密码 查看数据库 :show databases:查询所有数据库,记住一定要加分号结尾 这里必须全部为 英文空格 ...