修复IScroll点击无效,增加scrollTo数值容错处理

Posted McChen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了修复IScroll点击无效,增加scrollTo数值容错处理相关的知识,希望对你有一定的参考价值。

最近半年都处于一个非常忙碌的状态,直到现在才有功夫腾出时间记录这段时间以来踩过的一个个坑。

今天先记录关于IScroll 5.1.3版本的坑吧,以及自己打的一个小补丁

=============================

调用IScroll的时候,在IScorll区域有需要点击时部分安卓机点击无效。若设置click为true,则IOS需双击才能触发。 

解决方案:针对不同机型进行iscroll配置参数click的修改。

 1 function IScroll (el, options) {
 2 // INSERT POINT: DEFAULTS
 3     // fix click in bad Andriod
 4     this.options.click = this.fixIScrollClickInAndriod();
 5 }
 6 IScroll.prototype = {
 7     version: ‘5.1.3‘,
 8     fixIScrollClickInAndriod: function (){
 9         if (/iPhone|iPad|iPod|Macintosh/i.test(navigator.userAgent)) return false;
10         if (/Chrome/i.test(navigator.userAgent)) return (/android/i.test(navigator.userAgent));
11         if (/Silk/i.test(navigator.userAgent)) return false;
12         if (/Android/i.test(navigator.userAgent)) {
13             var s = navigator.userAgent.substr(navigator.userAgent.indexOf(‘Android‘)+8,5);
14             //return parseFloat(s[0]+s[3]) < 44 ? false : true}
15             return parseFloat(s[0]+s[2]+s[4]) <= 442 && parseFloat(s[0]+s[2]+s[4]) > 430 ? true : false}
16     }
17 }

  

  在返回页面的时候需要定位,所以把第一次进入的位置存入sessionStorage了,取出来时调用scrollTo(0,pos)无效。 

  出现原因:IScroll对于数值设置为Number,当存入sessionStorage会转为字符串,若取出来不进行parseFloat处理,将返NaN导致无法定位 
  解决方案:1、对从sessionStorage中取出来的数值,进行parseFloat处理。2、修改IScroll关于scrollTo位置的源码,增加 || 0 操作

1 var myScroll = new Scroll("#wrapper");
2 window.sessionStorage.setItem("pos",myScroll.y);
3 myScroll.scrollTo(parseFloat(window.sessionStorage.getItem("pos"))); // 也可修改scrollTo方法做 || 0 转换为数值处理

 

 

以上是关于修复IScroll点击无效,增加scrollTo数值容错处理的主要内容,如果未能解决你的问题,请参考以下文章

Android ScrollView在滚动中调用scrollTo(0,0)回到顶部无效

iscroll5在使用情况下click事件失效的问题

Android 7.0 TextView点击事件无效修复方案

iScroll 重叠 textarea 触摸或点击书写

为啥使用Iscroll.js之后,a不能触发点击事件?

iScroll - 保留原生垂直滚动 - 适用于 iOS,不适用于 Android