Nova PhoneGap框架 第八章 滚动条
你可能会疑惑为什么滚动条这么常见的功能会在这里单独列出,但如果你有过PhoneGap开发经验的话,你就会发现要在Android 2.3 里面实现滚动条那真不是一件容易的事。
8.1 概述
目前主流的PhoneGap框架或者库都花了很大的力气来实现滚动条,比如jQueryMobile, Sencha Touch,KendoUI,Intel App Framework (以前叫jqMobi),甚至还有一个专门只做滚动条而变得很出名的iScroll。
出现滚动条百家争鸣的原因是,低版本的Android和iOS不支持CSS样式overflow: scroll。于是才会写JS来处理触摸三事件。
我们的框架也处理了滚动条,因此可以运行于低版本的Android和iOS设备。跟其他主流的PhoneGap框架不一样,我们的滚动条只用了很少的代码就实现了,这是因为得益于我们有固定尺寸的div#body,而其他框架都不会去要求程序员这样设计HTML。当你越多的使用我们的框架,做的程序越复杂,你就会发现固定尺寸的div#body会给你带来意想不到的惊喜,这些都是其他框架无法比拟的。
在我们的框架下使用滚动条也非常简单,通常只需要一行代码,如:new nova.Scroller("#content").init(); 如果你需要对这个scroller进行配置,那么在调用scroller实例的init方法前,可以设置scroller的相关属性。目前支持的特性包括:
l 横向滚动
l 纵向滚动
l 嵌套的滚动
8.2 已知问题
尽管我们通过触摸三事件实现了滚动条,但是这个滚动条对于表单的兼容性不好。滚动条和表单元素的兼容性也是所有其他滚动条的痛处,到现在为止,我还没有发现哪一家的滚动条能够完美兼容表单。
我们框架在滚动功能和表单元素的功能取舍上,牺牲了部分滚动功能,而让表单元素的功能更加强壮。这句话说得很抽象,实现的效果就是,所有表单元素会正常工作,但是滚动触摸的起点不能在表单元素上,也就是说,你不能把手指按住一个textbox然后再下拉滚动页面。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)