页面在项目架构中是一个很重要的概念,它让我们能够将一个功能复杂的项目拆分成一个一个功能比较独立的小区域,这极大的提高了代码的可读性和可维护性。

在我们这个框架中,一个页面由JS和HTML两部分组成,首先让我们来看看JS部分吧。

以上的这部分代码就是一个在命名空间“at.pages”下的“Details”页面的定义。你可能已经注意到了,在第2行代码,有一个“pages/details.html”。对,就是这样,HTML文件的相对路径在这个页面的构造函数中进行了指定。这样,这个页面的JS部分和HTML部分就联系起来了。

在这个框架中,所有页面都应该继承自"nova.Page", 当然,你可以定义一个适合你项目的基类,比如DemoPageBase (仍然继承自nova.Page),然后你定义的其他页面继承自这个自定义的基类。

再让我们来看看HTML部分的代码:

怎么样?这个HTML页面的定义是不是非常清爽呢。

下面,让我们看看神奇的页面跳转和传值吧。

3.1 页面跳转

页面跳转在我们这个框架中其实非常简单,我甚至都想不到能有更简单的页面跳转方式了。

首先,我们来看看另一个示例页面的定义吧。

这实际上是一个菜单页面,只放了一些链接。这个页面包含了3种页面跳转的方式:

  1. 直接回退到上一个页面(如果指定了参数url的值,那么会一直回退到这个url对应的页面);
  2. 指定HTML页面路径进行跳转,适用于一些静态或简单页面;
  3. 构建一个目标页面的实例,然后进行跳转(此处可以传递任意参数),适用于大多数页面。

怎么样,这样的页面跳转是不是非常简单呢?既能够快速跳转到简单页面,有能够拥有足够的自由来控制跳转到复杂的页面。

注意:这段代码中的变量"at"扩展自"nova.application",所以你看到的"at.gotoPage"实际上是"nova.application.gotoPage"。

3.2 页面传值

页面传值比页面跳转更简单。

请看上节的这段代码:

首先我们实例化了一个目标页面,然后直接给这个实例的某个属性赋值,然后再跳转到这个页面。 是不是很简单并且一目了然呢?

再看看目标页面的定义:

我们看到"editingTarget" 实际上是这个页面的一个属性,这样目标页面中的所有代码都可以基于这个属性独立工作,当其他页面传过来的值发生改变时,这个页面就会呈现不一样的内容了。

3.3 页面事件

目前在我们项目中大量用到的事件只有onLoaded 和 onNavigatingAway,因此到现在为止,我们这个框架只实现了这两个事件。但是如果你想添加更多的事件,你也可以很容易的修改我们的框架实现。

需要特别注意的是,这里所说的事件,并不是像jquery中定义的那样,即一个对象可以为某个事件绑定多个处理程序,然后在事件发生的时候,每个处理程序都将运行。这里所说的事件实际更像是方法的定义,因为它不是用于多次绑定,且在事件发生的时候只会执行一次。

3.3.1 onLoaded事件

还记得我们在定义页面的构造函数中指定的HTML的路径吗?你可能已经猜到了,我们就是用的jquery的ajax去动态加载这个HTML页面的。默认情况下,ajax返回的HTML会被放到div#body中,然后,页面的onLoaded事件(实际上是方法)被调用。

于是你明白了,onLoaded事件是页面的主入口。当代码执行到onLoaded里面的时候,那个HTML已经加载到了document里面,因此你可以在onLoaded事件里面去绑定数据、绑定单击事件了。

3.3.2 onNavigatingAway事件

这个事件会在页面即将离开的时候调用,它有一个参数callback。当你不显示的调用这个callback的时候,页面是不会离开的。这样设计的主要原因是,javascript里面到处都是异步的调用和回调,只有用callback才能在这个事件中做一些异步的操作。

通常我们还会在这个事件中做一件事,那就是释放这个页面的实例所占用的资源。

Nova PhoneGap框架 第三章 页面的更多相关文章

  1. Nova PhoneGap框架 第七章 设备事件处理

    我们的框架包含了几种设备事件的处理,目的是为了让我们的程序员更容易的完成代码.这些事件包括:回退键(Android)和横竖屏切换事件. 7.1 Android回退键 首先来说说回退键的事件处理.当用户 ...

  2. Nova PhoneGap框架 第四章 本地数据库

    我一直想把EntityFramework(简称EF)的那一套搬过来,应用于HTML5 SQLite. 幸运的是,我几乎做到了,有些功能无法完成的那是因为SQLite本身不支持.至少从现在已经完成的功能 ...

  3. Nova PhoneGap框架 第五章 文件结构

    一个好的项目架构必然有着合理的文件结构,如果一个项目的文件组织混乱,那么可以断言一定是项目架构有问题. 合理的文件结构能够帮你更清晰的管理你的文件,并且当需要添加新的文件的时候,你的程序员很清楚应该加 ...

  4. Nova PhoneGap框架 第六章 使用Mock

    在我们的框架中引入了一个很重要的设计,那就是使用Mock. 这里的mock是指cordova.mock.js文件,它模拟了PhoneGap(Cordova)的API,从而可以在浏览器中运行测试我们的程 ...

  5. Nova PhoneGap框架 第一章 前言

    Nova PhoneGap Framework诞生于2012年11月,从第一个版本的发布到现在,这个框架经历了多个项目的考验.一直以来我们也持续更新这个框架,使其不断完善.到现在,这个框架已比较稳定了 ...

  6. Nova PhoneGap框架 第八章 滚动条

    你可能会疑惑为什么滚动条这么常见的功能会在这里单独列出,但如果你有过PhoneGap开发经验的话,你就会发现要在Android 2.3 里面实现滚动条那真不是一件容易的事. 8.1 概述 目前主流的P ...

  7. Nova PhoneGap框架 总结

    Nova PhoneGap Framework 是完全针对PhoneGap应用程序量身定做的,在这个框架下开发的应用程序很容易实现高质量的代码,很容易让程序拥有很好的性能和用户体验. 在经历了多个项目 ...

  8. Nova PhoneGap框架 第二章 理解index.html

    跟绝大多数PhoneGap程序一样,Index.html是程序的入口.这个页面应该完成应用程序的初始化工作. 首先,让我们来看看这个页面通常都长什么样子: 下面我将一一解释这个页面都做了哪些初始化工作 ...

  9. Nova PhoneGap框架 第九章 控件

    我们的框架中也提供了一些常用的控件,这些控件大多都依赖于我们的框架,也正是在我们的框架下才使得实现这些控件的变得更简单.但是我们的框架是不依赖与这些控件的,如果你用不上这些控件,你完全可以把相关的代码 ...

随机推荐

  1. AutoCAD 2007-2012 长度统计工具

    长度统计工具 下载 1 解压到磁盘 2 CAD 中输入命令 netload 3 选择文件 "CADLittleProgram.dll" 4 点击 Ps:后续会打包并支持2013-2 ...

  2. SQL执行效率和性能测试方法总结

    对于做管理系统和分析系统的程序员,复杂SQL语句是不可避免的,面对海量数据,有时候经过优化的某一条语句,可以提高执行效率和整体运行性能.如何选择SQL语句,本文提供了两种方法,分别对多条SQL进行量化 ...

  3. 【转】apache 二级域名设置完整步骤

    原文链接:http://blog.sina.com.cn/s/blog_5375d76b01014fnt.html 最近在折腾网站二级域名的事情,在网上查了很多零碎的文档,不完整,有些也没有自己验证, ...

  4. haahah

    #DB ``` import os basedir = os.path.abspath(os.path.dirname(__file__))   SQLALCHEMY_DATABASE_URI = ' ...

  5. [Android]依赖注入框架google的dagger

    分享一下Android依赖注入框架--Google升级版Dagger2框架 Google的Dagger2是对上一版squareup的Dagger改版,话不多说直接上项目代码. Dagger2源码 Da ...

  6. Redis_密码管理(转)

    一. 如何初始化redis的密码? 总共2个步骤: a.在配置文件中有个参数: requirepass  这个就是配置redis访问密码的参数. 比如 requirepass test123 b.配置 ...

  7. 【SQL语句】update ... ... from ......

    要求:修改vaj表中的vaj02字段的值,vaj02字段的值=cag.cag03的值,vaj 表与 cag 表无直接关联 实现: update vaj set vaj02=c.cag03 from l ...

  8. php随机ip

    $ip_long = array( array('607649792', '608174079'), //36.56.0.0-36.63.255.255 array('1038614528', '10 ...

  9. 把C#程序(含多个Dll)合并成一个Exe的超简单方法

    开发程序的时候经常会引用一些第三方的DLL,然后编译生成的exe文件就不能脱离这些DLL独立运行了. 但是,很多时候我们本想开发一款只需要一个exe就能完美运行的小工具.那该怎么办呢? 下文介绍一种超 ...

  10. PHP定界符使用技巧

    为什么要使用定界符 : 因为PHP是一个Web编程语言,在编程过程中难免会遇到用echo来输出大段的html和javascript脚本的情况,如果用传统的输出方法——按字符串输出的话,肯定要有大量的转 ...