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

在我们这个框架中,一个页面由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. Centos 下编译安装Redis

    安装环境说明: 操作系统:Centos 6.5 -64bit 安装路径:/usr/local/redis 开始编译redis tar -zxvf redis-2.8.19.tar.gz cd redi ...

  2. js new

    如果一个函数前面带上new来调用该函数,那么将创建一个隐藏连接到该函数的prototype成员的新对象,同时this将被绑定到那个新对象上 即: function B(){} var a=new B( ...

  3. 3.4.4 数据预留和对齐(skb_reserve, skb_push, skb_put, skb_pull)

    转自:http://book.51cto.com/art/201206/345043.htm <Linux内核源码剖析:TCP/IP实现>本书详细论述了Linux内核2.6.20版本中TC ...

  4. Qt基本框架介绍

    #include <QApplication>#include <QWidget> int main(int argc, char *argv[]){ QApplication ...

  5. 高性能的JavaScript--数据访问(2)

    动态作用域 无论是with表达式还是try-catch表达式的catch子句,以及包含()的函数,都被认为是动态作用域.一个动态作用域只因为代码运行而存在.因此无法通过静态分析(查看代码机构)来确定( ...

  6. 4.View绘制分析笔记之onDraw

    上一篇文章我们了解了View的onLayout,那么今天我们来学习Android View绘制三部曲的最后一步,onDraw,绘制. ViewRootImpl#performDraw private ...

  7. web前端开发学习内容

    应该 具备的 知识技能 :懂web标准,熟练手写 xhtml css3 并符合 符合w3c标准                       代码能 兼容主流浏览器.ie6.7.8.9 ff 等.    ...

  8. AutoCAD .net 开发 SelectionFilter Foreach Linq 性能比较

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  9. 并查集+树链剖分+线段树 HDOJ 5458 Stability(稳定性)

    题目链接 题意: 有n个点m条边的无向图,有环还有重边,a到b的稳定性的定义是有多少条边,单独删去会使a和b不连通.有两种操作: 1. 删去a到b的一条边 2. 询问a到b的稳定性 思路: 首先删边考 ...

  10. hack

    1.Firefox @-moz-document url-prefix() { .selector { property: value; } }上面是仅仅被Firefox浏览器识别的写法,具体如: @ ...