原生开发移动web单页面(step by step)3——App对象

简介:        为了让Page对象更专注于业务逻辑,将其它的操作转移出去,因此引入了App对象。App对象起到了管理多个Page对象的作用。有了App对象后, Page对象只需要负责渲染页面以及绑定事件,其它的都让App自动帮Page解决。

       为了让Page对象更专注于业务逻辑,将其它的操作转移出去,因此引入了App对象。App对象起到了管理多个Page对象的作用。有了App对象后, Page对象只需要负责渲染页面以及绑定事件,其它的都让App自动帮Page解决。类似以下代码:

     首先创建一个App对象

     var app = new App();

     再创建一个Page对象,只需要重写getDomObj方法以及相关的事件方法。然后调用

     var indexPage = new Page();

     indexPage.getDomObj = function () {};

     相关事件的方法定义(省略),最后通过一下代码切换

     app.render(indexPage);

     启用app.render方法后,将会自动卸载之前的页面,将当前的页面初始化插入页面中,从而简化了开发流程。App对象的代码如下

App的对象的代码

        让App对象更好的管理Page对象,改造Page对象,新增_dispose和_initialize方法,分别指向装载和卸载操作,Page构造函数如下代码

Page对象的代码

        其中domList与eventList存放着对应dom元素以及事件方法,通过规范化的数据结构,用于自动化绑定以及卸载。

_dispose和_initialize方法的源代码

         这里是卸载与装载的实现,分别调用了以下方法

         _removeEventListeners(): 移除所有的挂在页面的事件

        _removeDom() : 清除dom元素

        getDomObj(container): 缓存元素以及缓存事件存于domList和eventList     中,然后通过_addEventListener()方法一起绑定,需要开发者重写

        _addEventListeners(); 将事件绑定到页面上。

        这里的命名规则,内部使用的方法以下划线开头,提供用户实现的以驼峰命名。


       以下为domList与eventList存储数据的格式

       domList为简单对象,以key-value的格式, value代表dom元素,通过attachDom方法来存储,比如page.attachDom("#id", "id", dom);  id为key, value为该代码document.querySelector("#id")获得的元素

        eventList是一个数组,每个元素都是一个对象eventObj, eventObj拥有key字段和eventArray字段, key字段与domList的key对应,eventArray是一个数组,存储绑定事件的详情,每个事件详情都有method字段代表事件类型, eventArray字段代表事件函数的数组,每个事件函数都有函数本身,以及事件的传播方向(冒泡或者捕获),还有一个自定义的与bind函数,用于把事件函数的作用域转移到该Page对象,从而达到更好的封装作用。通过attachEvent方法进行存储事件。

         以下为attachDom与attachEvent方法的代码定义

attachDom方法的代码
attachEvent方法的代码

attachEvent事件中,调用了_getEvent方法,主要起到防止多次绑定完全相同的事件。

getEvent方法的代码

         定义完数据结构以及数据的存储方式,下面就是关于数据操作处理,以下是_remvoeDom方法, _addEventListeners方法以及_removeEventListener方法的定义

removeDom方法的代码
addEventListeners方法的代码
removeEventListeners方法的代码

        进行代码重写之前,引入两个常用辅助函数,分别挂在App函数下面。

extend方法的代码
创建Page对象的工厂函数

        预备代码完毕, 接下开始重写页面代码, 这里html以及css完全不变, 只要更改js代码

indexPage的js代码
loginPage的js代码
registerPage的js代码
goalPage的js代码

       最后初始化app

初始化app代码

        总结:引入了App对象管理Page对象是有必要的,可以让使用者更专注自己的习惯来编写代码。与现实中类似的,既然有管理者,被管理者必须要服从管理,因此对于Page对象做了很多相应的更改。这篇的代码有点多,但是这是做单页面的核心部分,通过代码的分离,可以为以后更好的维护打下坚实的基础。

        后续更新:下一篇将引入tap事件和slide事件,这两个事件是移动端非常常用的,通过tap事件来代替click事件, slide事件用于简单的手势操作。

案例链接


原生开发移动web单页面(step by step)1——传统页面的开发

原生开发移动web单页面(step by step)2——Page对象

原生开发移动web单页面(step by step)4——tap事件与slide事件

原生开发移动web单页面(step by step)5——nodejs服务器的搭建

原生开发移动web单页面(step by step)6——history api应用

相关文章
|
1月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
498 7
|
1月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
582 1
|
20天前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
21天前
【Azure App Service】PowerShell脚本批量添加IP地址到Web App允许访问IP列表中
Web App取消公网访问后,只允许特定IP能访问Web App。需要写一下段PowerShell脚本,批量添加IP到Web App的允许访问IP列表里!
|
1月前
|
JavaScript 前端开发 UED
Vue与uni-app开发中通过@font-face巧妙引入自定义字体
Vue与uni-app开发中通过@font-face巧妙引入自定义字体
76 9
|
1月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
196 1
|
17天前
|
机器人
布谷直播App系统源码开发之后台管理功能详解
直播系统开发搭建管理后台功能详解!
|
1月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
568 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
26天前
|
NoSQL PHP Redis
布谷语音app源码服务器环境配置及技术开发语言
布谷语音app源码服务器环境配置及技术语言研发。。
|
1月前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
328 0

热门文章

最新文章

下一篇
无影云桌面