博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
原生开发移动web单页面(step by step)3——App对象
阅读量:5946 次
发布时间:2019-06-19

本文共 1926 字,大约阅读时间需要 6 分钟。

       为了让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事件用于简单的手势操作。


转载地址:http://gkdxx.baihongyu.com/

你可能感兴趣的文章
计算机网络术语总结4
查看>>
新手小白 python之路 Day3 (string 常用方法)
查看>>
soapUI的简单使用(webservice接口功能测试)
查看>>
框架 Hibernate
查看>>
python-while循环
查看>>
手机端上传图片及java后台接收和ajaxForm提交
查看>>
【MSDN 目录】C#编程指南、C#教程、ASP.NET参考、ASP.NET 4、.NET Framework类库
查看>>
jquery 怎么触发select的change事件
查看>>
angularjs指令(二)
查看>>
<气场>读书笔记
查看>>
领域驱动设计,构建简单的新闻系统,20分钟够吗?
查看>>
web安全问题分析与防御总结
查看>>
React 组件通信之 React context
查看>>
Linux下通过配置Crontab实现进程守护
查看>>
ios 打包上传Appstore 时报的错误 90101 90149
查看>>
Oracle推出轻量级Java微服务框架Helidon
查看>>
密码概述
查看>>
jQuery的技巧01
查看>>
基于泛型实现的ibatis通用分页查询
查看>>
gopacket 使用
查看>>