解决iscorlljs的文本中绑定点击事件不能触发的问题
解决iscroll5在手机页面上onclick事件失效
摘要:解决iscroll5在手机页面上onclick事件失效
解决办法:
第一种办法:实例化IScroll的时候把preventDefault设为false,默认为true的
var myScroll;
function loaded () {
myScroll = new IScroll('#wrapper', {
//preventDefault为false这行就是解决onclick失效问题
//为true就是阻止事件冒泡,所以onclick没用
preventDefault:false,
scrollX: true,
scrollY: false,
momentum: false,
snap: true,
snapSpeed: 400,
keyBindings: true,
indicators: {
el: document.getElementById('indicator'),
resize: false
}
});
}
window.onload=loaded;
第二种办法:
Bug描述:
ios、android4.4+下不能触发click事件。
Bug解决:
调用iscroll插件,增加配置参数:click:true/false
click的值是要根据移动终端设备进行判断,如果只是简单的判断终端类型的话,android4.4+还是不能点击,这就是安卓的一个坑,毕竟没有IOS系统做的统一。
故增加一个函数去判断:
// #########
function iScrollClick(){
if (/iPhone|iPad|iPod|Macintosh/i.test(navigator.userAgent)) return false;
if (/Chrome/i.test(navigator.userAgent)) return (/Android/i.test(navigator.userAgent));
if (/Silk/i.test(navigator.userAgent)) return false;
if (/Android/i.test(navigator.userAgent)) {
var s=navigator.userAgent.substr(navigator.userAgent.indexOf('Android')+8,4);
return parseFloat(s[0]+s[3]) < 44 ? false : true
}
}
配置实例:
myScroll = new IScroll("#ID", {
click:iScrollClick(), //调用判断函数
scrollbars: true,//有滚动条
mouseWheel: true,//允许滑轮滚动
fadeScrollbars: true//滚动时显示滚动条,默认影藏,并且是淡出淡入效果
});
以上两种办法基本解决这个问题。

浙公网安备 33010602011771号