web app开发利器 - iscroll4 解决方案

简介:
  • 存在即是道理,iscroll会诞生,主要是因为无论是在iphone、ipod、android 或是更早前的移动webkit都没有提供一种原生的方式来支持在一个固定高度的容器内滚动内容,
  • 这个不幸的规则导致所有web-app要模拟成app的样子时,只能由一个绝对定位的header 或是footer再加上一个可以内容的滚动的中间区域组成。
  • 幸运的是移动webkit提供了一种强大的硬件加速的CSS属性,这个属性可以用来模拟这个缺失的功能,Iscroll从这里开始了前进之路,但是没有不带刺的玫瑰。让内容滚动像原生方式一般比想象中要难
  • 兼容万恶的IE6一样,作者希望通过写一个控件,让所有web浏览器支持这种滚动,于是iscroll4应运而生。

在解决了兼容性的问题之外,它还提供了需求许多交互的解决方案,如:

    (1)缩放(Pinch/Zoom)

    (2)拉动刷新(Pull up/down to refresh)

    (3)速度和性能提升

    (4)精确捕捉元素

    (5)自定义滚动条

IOS5 已经能够支持区域滚动了。但是andriod4 还是不行..

overflow:scroll;  
-webkit-overflow-scrolling:touch;

 

已知的兼容bugs

 

区域滚动

  • 安卓的2x. 元素不支持 overflow:scroll (android自带浏览器) 4.x以上都支持
  • ios 5以下好像也不支持

固定定位:

  • 话说iphone很先进,但就是不支持position:fixed, 真奇葩

实际项目开发中使用iscroll遇到的问题:

大概说下解决的方案,你不一定遇到,遇到了至少有个参考~

  • iscroll支持在pc端浏览器中使用鼠标滚轮控制区域滚动,但操作起来很不灵敏
  • 在iscroll4的滚动容器范围内,点击input框、select等表单元素时没有响应
复制代码
onBeforeScrollStart : function(e){ e.preventDefault(); },
    这一行,iSroll禁止了事件的默认行为,导致select,option,textarea等元素无法点击。
     解决方法也很简单,只需做一下判断,如下:

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();
  }
},
复制代码
  • 这样只要你touch的元素是 select || option || input || textarea时,它就不会执行e.preventDefault(),默认的事件就不会被屏蔽了

 


 

  • 往iscroll容器内添加内容时,容器闪动的bug                              (实际遇到了,已解决)
    • 做上拉加载更多内容的时候,肯定需要把新的内容插入到容器内,这时发现有时容器会出现闪动,一开始认为是insert进去的内容太多,后来又觉得是不是因为里面布局用了float的原因导致重新渲染,最后通通排除
    • has3d = 'WebKitCSSMatrix' in window && 'm11' in new WebKitCSSMatrix()
    • has3d = false
    • 和在配置iscroll时,useTransition设置成false就可以了(useTransition默认是false的)。

 


 

 

  • 过长的滚动内容,导致卡顿和app直接闪退 (实际遇到了,已解决)
    • 说白了iscroll都是用js+css3实现的,对浏览器的消耗肯定是可观的,避免无限制的内容加载本身就是web产品应该避免的。
    • 假如无可避免,我们可以尽量减低iscroll对浏览器内存的消耗
    • 1)不要使用checkDOMChanges。虽然checkDOMChanges很方便,定时检测容器长度是否变化来refresh,但这也意味着你要消耗一个Interval的内存空间
    • 2)隐藏iscroll滚动条,配置时设置hScrollbar和vScrollbar为false。
    • 3)不得已的情况下,去掉各种效果,momentum、useTransform、useTransition都设置为false

 


 
在手机中做滑动条,有几百条下啦列表的是时候,上下滑动爆卡(实际遇到了,已解决)
  • 检查原因发现跟布局有很大的关系,布局的子元素li都用了绝对定位,去掉就OK了,有此可见定位也是会影响能行滴

 


 

左右滚动时,不能正确响应正文上下拉动                                  (实际遇到了,已解决)

  • 在做这种效果时 ,假如这个幻灯片模块只是你页面的一部分,你还需要上下拉动页面去浏览其它内容时,你的手指在这个模块上做上下拨动时,恐怕会没有反应。原因还是和问题1一样的,因为屏蔽了默认事件。
  • 完美的解决方法是没有的,如果把 e.preventDefault() 去掉,幻灯片的滚动效果就会大打折扣,而且有时用户上下拨动的操作会被误操作成幻灯片的滚动。所以在效果还是体验上,大家还是自己选择吧。在技术上解决不了的问题,我认为还是多和产品和UI沟通比较好,共同协商一个良好的方案。

 


 

  • 4.1.9版本中,mouseout事件,2次触发end事件                        (实际遇到了,已解决)

            呵呵,这个我改了源码,添加了一个flag处理的,具体在

复制代码
_start 方法中
that.swipe = false;

_mouseout 方法中
        _mouseout:function (e) {
            var t = e.relatedTarget;    

            if(this.swipe){
                return;
            }
复制代码

 


  • 4.1.9版本中,preventDefault没有妥善处理,导致svg不可选的问题 (实际遇到了,已解决)

如图把  打字累了

QQ20130620233427_thumb

 

附上:运用webkit绘制渲染页面原理解决iscroll4闪动的问题

本文转自艾伦 Aaron博客园博客,原文链接:http://www.cnblogs.com/aaronjs/p/3147470.html,如需转载请自行联系原作者


相关文章
|
15天前
|
监控 JavaScript 前端开发
《理解 WebSocket:Java Web 开发的实时通信技术》
【4月更文挑战第4天】WebSocket是Java Web实时通信的关键技术,提供双向持久连接,实现低延迟、高效率的实时交互。适用于聊天应用、在线游戏、数据监控和即时通知。开发涉及服务器端实现、客户端连接及数据协议定义,注意安全、错误处理、性能和兼容性。随着实时应用需求增加,WebSocket在Java Web开发中的地位将更加重要。
|
26天前
|
Web App开发 前端开发 开发工具
介绍Web开发的基础知识
介绍Web开发的基础知识
26 7
|
27天前
|
API 数据安全/隐私保护 iOS开发
利用uni-app 开发的iOS app 发布到App Store全流程
利用uni-app 开发的iOS app 发布到App Store全流程
83 3
|
28天前
|
Android开发 开发者 UED
个人开发 App 成功上架手机应用市场的关键步骤
个人开发 App 成功上架手机应用市场的关键步骤
|
28天前
|
开发工具 数据安全/隐私保护 Android开发
【教程】APP 开发后如何上架?
【教程】APP 开发后如何上架?
|
1月前
|
缓存 关系型数据库 API
后端开发:构建高效、可扩展的Web应用程序的关键
后端开发:构建高效、可扩展的Web应用程序的关键
20 0
|
30天前
Could not open ServletContext resource [/WEB-INF/springmvc-servlet.xml]【解决方案】
Could not open ServletContext resource [/WEB-INF/springmvc-servlet.xml]【解决方案】
14 0
|
4天前
|
PHP
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
|
4天前
|
前端开发 数据挖掘 API
使用Python中的Flask框架进行Web应用开发
【4月更文挑战第15天】在Python的Web开发领域,Flask是一个备受欢迎的轻量级Web框架。它简洁、灵活且易于扩展,使得开发者能够快速地构建出高质量的Web应用。本文将深入探讨Flask框架的核心特性、使用方法以及在实际开发中的应用。
|
16天前
|
XML JSON JavaScript
使用JSON和XML:数据交换格式在Java Web开发中的应用
【4月更文挑战第3天】本文比较了JSON和XML在Java Web开发中的应用。JSON是一种轻量级、易读的数据交换格式,适合快速解析和节省空间,常用于API和Web服务。XML则提供更强的灵活性和数据描述能力,适合复杂数据结构。Java有Jackson和Gson等库处理JSON,JAXB和DOM/SAX处理XML。选择格式需根据应用场景和需求。