iScroll 4,把禁掉的:active样式还给我~
iScroll这个移动端的滚动神器大家都非常熟悉了,直到现在仍是实现移动端Web滚动的首选方案之一。。。
当我接触移动端Web时iScroll已经有两个版本了,iScroll 4和iScroll 5,当时看到很多文章都是关于iScroll 4的,看来这个版本已经得到的非常广泛的应用,而iScroll 5的文章相对非常之少,好吧,项目进度耽误不起,我们就选当前最流行的这个版本吧(iScroll 4.2.5),想必也是最成熟稳定的。。。
iScroll 4的官网地址:
这个插件的功能全面,使用也简单,应对表面统一的移动浏览器平台(我们只关注webkit核心~~ ^_^)感觉游刃有余,对于性能问题,使用初期也察觉到有什么异样(看来常年停留在安卓2.3系统的我根本不知道顺滑与卡顿的区别~~),心里还在莫莫崇拜国外牛人多啊~~
直到项目进入后期完善阶段了,就会到处点一点,按一按,检查下前端工作是否有重大Bug,突然间意识到有些页面表现怪怪的,一些Button点击时少了一点什么效果,原来是在点击按钮时没有表现出交互效果!
查看下CSS代码,明明我在.btn类上加了:active效果了的,而且在应用iScroll滚动的区域外的button是有效果的(我是用桌面Chrome模拟器的),那问题一定是出在iScroll身上了。。。其实这个问题也可以理解,在很多类似的模拟插件中如果不禁用掉系统默认事件或者效果的话,达不到完美的用户体验效果,印象中桌面端的那个mousewheel插件就是如此。。。
那我就看API,找度娘~~原来很早有很多人已经遇到这样的问题了,比如园里的Tony同学(http://www.cnblogs.com/lostyu/p/3907256.html)哈哈,有人进过坑,就意识着有人成功跳出过坑~~直接把解决方法拿来用是我们前端城狮的必要技术之一,于是我也复制之~~ ^o^
iScroll作者当时一刀砍啊,所有默认行为全部干掉了:
onBeforeScrollStart: function (e) { e.preventDefault(); }
大家的解决方法:
onBeforeScrollStart: function (e) {
var nodeType = e.explicitOriginalTarget ? e.explicitOriginalTarget.nodeName.toLowerCase() : ( e.target ? e.target.nodeName.toLowerCase() : '' );
if( nodeType != 'select'&& nodeType != 'option' && nodeType != 'input' && nodeType != 'textarea' ) e.preventDefault();
}
这个方法很直接,很有效,将最为常用的系统组件select、option、input、textarea等等在iScroll中点击无效的问题解决了;
但是如果我们想让Button也能点击且有点击效果的话,就要手动再加 && nodeType != 'button' 到代码里去,也行吧~~~
但是如果我们想让<a class="btn">也有点击效果~~~,就要进一步改造啦。
对了,不是有iScroll 5了吗,它会不会有这个问题呢?看一下API, 新版本已经有相关的控制参数了: options.preventDefaultException
iScroll 5官网API:
http://iscrolljs.com/#advanced-options
要不直接换iScroll 5? 了解过iScroll 5的同学要先呵呵一下,因为iScroll 5已经不是4+1=5那么简单了。
iScroll 5已经完全重写了,不少接口都做了改变,就连实例化的方式都不同了,这么说吧,iScroll 4与5完全是两个东西,你甚至可以在同一个页面中同时使用它们俩:
iScroll 4使用:
new iScroll('scroll-wrapper-1');
iScroll 5使用:
new IScroll('#scroll-wrapper-2');
iScroll 5提供的那个配置接口参数可以解决我们之前遇到的问题:
new IScroll('#pro-detail',{
preventDefaultException: { tagName: /^(INPUT|TEXTAREA|BUTTON|SELECT)$/, className: /(^|\s)btn(\s|$)/ }
});
看到 className: /(^|\s)btn(\s|$)/ 了吗? 这样就可以使.btn的元素不被preventDefault()方法干扰。
由于换用iScroll5的劳动成本略大于对iScroll4的改进(其实是不改心里有点难受,我不是处女座),我们开始改动工~
我们学习iScroll 5的样子,为iScroll 4也添加配置参数(大概在107行):
// Default options
that.options = {
hScroll: true,
vScroll: true,
x: 0,
y: 0,
bounce: true,
bounceLock: false,
momentum: true,
lockDirection: true,
useTransform: true,
useTransition: false,
topOffset: 0,
checkDOMChanges: false, // Experimental
handleClick: true,
preventDefaultException: "", // ex: "A|BUTTON|.btn-class|#btn-id" 。。。
然后将那个onBeforeScrollStart方法在同学们改造过的基础之上变得更丰满,如下:
onBeforeScrollStart: function (e) {
var nodeType = e.explicitOriginalTarget ? e.explicitOriginalTarget.nodeName.toLowerCase() : (e.target ? e.target.nodeName.toLowerCase() : '');
var excpt = that.options.preventDefaultException.replace(/\s/g, ""), excptArr = null, targetNode = null;
if (nodeType != 'select' && nodeType != 'option' && nodeType != 'input' && nodeType != 'textarea' && !isExcptNode(e.target, excpt)) {
e.preventDefault();
}
function isExcptNode(_node, _excptStr) {
var result = false;
if (_excptStr) {
targetNode = _node;
excpt += _excptStr.match("|") ? "" : "|";
excptArr = excpt.split("|");
for (i in excptArr) {
if (targetNode.nodeName.toString().toLowerCase() == excptArr[i].toLowerCase()) {
result = true;
break;
}
else if (excptArr[i].match("#")) {
if (targetNode.id.match(excptArr[i].replace("#", ""))) {
result = true;
break;
}
}
else if (excptArr[i].match(".")) {
if (targetNode.className.match(excptArr[i].replace(".", ""))) {
result = true;
break;
}
}
}
}
return result;
}
}
于是,我们也可以在使用iScroll4时这样啦:
new iScroll('wrapper', {
useTransition: false,
vScrollbar: false,
preventDefaultException:".btn|.btn-b|#btn-submit"
});
iScroll 4,把禁掉的:active样式还给我~的更多相关文章
- 移动端bug~~移动端:active伪类无效的解决方法【移动端 :active样式无效】
移动端:active伪类无效的解决方法[移动端 :active样式无效]2016-09-26 15:46:50 问题: 移动端开发的时候实现按钮的点击样式变化,但是在iphone[safiri Mo ...
- unity, 在OnDisable里一定要将Cloth禁掉
如果在OnDisable中不将Cloth组件禁掉,则当物体再次激活时布料将变形.
- Qt中如何禁掉所有UI操作以及注意事项(处理各个widget的eventFilter这一层,但是感觉不好,为什么不使用QApplication呢)
刚做完的一个项目,在测试时出现了一个问题:由于多线程的存在,当进行语音识别时:如果用户点击程序界面上的button或者其他接受点击事件后会发出信号的widget时,程序会crash ! 后来尝试着从多 ...
- html5 vedio 播放器,禁掉进度条快进快退事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 在新安装的Linux系统中,防火墙默认是被禁掉的,一般也没有配置过任何防火墙的策略,所有不存在/etc/sysconfig/iptables文件。
原因:在新安装的Linux系统中,防火墙默认是被禁掉的,一般也没有配置过任何防火墙的策略,所有不存在/etc/sysconfig/iptables文件. 解决办法: .随便写一条iptables命令配 ...
- vue 如何通过监听路由变化给父级路由菜单添加active样式
1.项目需求:在项目开发中,多级菜单的情况下,勾选子菜单时,需要在父级菜单添加active样式. 2.遇到的问题:一级路由菜单的话,点击当前路由会自动在路由标签上添加router-link-exact ...
- VUE 动态切换列表active样式
参考VUE官方文档样式绑定 https://cn.vuejs.org/v2/guide/class-and-style.html 需求是动态加载出来了所有菜单列表,点击其中一个li元素改变这个元素的背 ...
- 5. iphone 的:active样式
如果给按钮定义 :hover 样式,在 iPhone 上按钮点击一次是 hover 态,再点击一次 hover 态才会消失,这不是我们想要的,继而想通过定义 :active 样式来实现按钮按下时的效果 ...
- vue active样式显示
html:代码 <ul> <li @click="current='xxxx'" :class="{active:current=='xxxx'}&qu ...
随机推荐
- Matlab定义子函数
上篇博客介绍了在Matlab中自己定义简单函数的方法,本篇博客将介绍定义子函数的方法.本文承接上篇博客的样例,即随机生成一个3行4列的矩阵,矩阵中的元素设定上下限为(low,high).并返回矩阵全部 ...
- Windows消息传递函数SendMessage参数属性
Windows消息传递函数SendMessage参数属性 转载于:http://www.cr173.com/html/5605_1.html Windows是一个消息驱动式系统,SendMessage ...
- vue+webpack一些知识
使用mac的用户需要获取权限才可以使用npm install指令 设置node目录的权限指令 sudo chmod -R 777 /usr/local/lib/node_modules/ 大家都知道国 ...
- java 获取两个日期相差的毫秒数
方法一可以使用date的getTime()方法来将当前日期格式的时间转换为毫秒数,进而相减. long systime = new Date().getTime();//当前系统时间 l ...
- 利用VS自带的命令行工具查看和生产PublicKeyToken (转)
使用VS2013(或其他版本)命令行工具,键入:SN -T C:\*****.dll 就会显示出该dll具体的PublicKeyToken数值. 如果该程序集没有强命 名,则不会有PublicKeyT ...
- JQuery一句话实现全选/反选
$("#checkAll").click(function () { if (this.checked) { $("input[name='checkbox']& ...
- js基础——属性操作
html属性:属性名——属性值 操作:读 . 写 读操作:用来获取.找到属性名对应的属性值,方法:元素.属性名 例如:var oBtn = document.getElementById('btn1' ...
- 浅谈C中的指针和数组(一)
本文转载地址:http://www.cnblogs.com/dolphin0520/archive/2011/11/09/2242138.html 在原文的基础上加入自己的想法作为修改. 指针是C/C ...
- High Context とLow Context文化
社会の様々な文化を分類するのに.Low context culture, High context cultureという分け方がある.ビジネススクールのグローバル・マーケティングの授業などでよく取り上 ...
- python基础知识讲解——@classmethod和@staticmethod的作用
python基础知识讲解——@classmethod和@staticmethod的作用 在类的成员函数中,可以添加@classmethod和@staticmethod修饰符,这两者有一定的差异,简单来 ...