`
shuai1234
  • 浏览: 932474 次
  • 性别: Icon_minigender_1
  • 来自: 山西
社区版块
存档分类
最新评论

Dojo mobile TweetView 系列教程之一 —— dojox.mobile入门

 
阅读更多

作者:David Walsh

翻译:Siqi (siqi.zhong@gmail.com

原文:Get started with dojox.mobile

 

Web技术飞速更新,而现在Web的趋势也是逐渐向移动设备上迁移。如同其他Web存在的问题一样,Dojo Toolkit已经为你提供了解决方案——dojox.mobile。dojox.mobile是一个由controllers、基于CSS3的主题以及一些外观与你的移动设备契合的widgets组成的。有了dojox.mobile,你可以轻松的创建智能、灵活、跨平台的移动Web应用程序。本文是dojox.mobile系列教程的第一篇。在这个系列中,我们将创建一个很棒的基于Twitter的web应用程序“TweetView”。在我们开始之前,先让我们学习一下怎么使用dojox.mobile。

 

难度:初学者

版本:1.6

系列:TweetView

 

dojox.mobile简介

dojox.mobile是Dojo Toolkit根据用户对移动Web应用程序的需要而量身定制的。dojox.mobile的架构特点是轻量、灵活以及可扩展。同时dojox.mobile也模仿了iOS和Andriod设备的界面,因此你用dojo.mobile创建出的应用程序将带给你的用户无缝的体验。dojox.mobile的核心特点包括:

  • 轻量、最小化互相依赖性
  • 提供iOS以及Andriod的CSS主题。
  • 提供iOS以及Andriod样式的空间。
  • 使用基于CSS3的动画(如果设备支持CSS3的话)
  • 为不支持CSS3的设备提供JavaScript动画
  • 可响应移动设备的位置变化
  • dojox.mobile是一套完整的移动widget框架——不需要再从很多地方寻找widget东拼西凑。

 

下面你可以看到dojox.mobile在不同平台大致的样子:

 

有了dojox.mobile,我们将创建一个简单的移动web应用程序:TweetView。

 

!这些界面也可以在桌面浏览器使用,但还是推荐花点时间在你的iOS和Andriod设备上试一下每一个样例。你会对dojox.mobile的widgets和CSS主题感到映像深刻的。

 

构建你的移动页面

像任何其他移动应用程序一样,页面结构的设计是很重要的。而dojox.mobile基本不需要任何特殊的页面结构,你只需要加入几项关键的东西就可以了:

 

  • 合适的DOCTYPE
  • 针对Mobile的META标签
  • 一个用来包含视图(views)的BODY元素

 

!你可以参考Mobile Safari Supported Meta Tags 来学习更多关于META标签的知识。

你可以使用下面的模板开始创建你的应用程序:

 

 

[xhtml] view plaincopy
 
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"><html>    <head>    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no"/>    <meta name="apple-mobile-web-app-capable" content="yes" />    <title>Your Application Name</title>    <link href="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojox/mobile/themes/iphone/iphone.css" mce_href="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojox/mobile/themes/iphone/iphone.css" rel="stylesheet"></link>     <!-- stylesheet will go here -->     <!-- dojo/javascript will go here -->     </head>    <body>     <!-- application will go here -->     </body></html>  

 

 


有了上面的HTML模板,我们现在可以向页面添加Dojo和dojox.mobile了!

 

将dojox.mobile加入你的移动页面

dojox.mobile看上去就像一个简化、定制版的Dijit。添加dojox.mobile到你的页面,你需要:

 

  • 一个主题:现在有两种主题可供选择:iPhone和Andriod
  • 带有dojox.mobile的Dojo库:你将用到的JavaScript代码
  • 一个或多个视图(views):视图(views)将在你的应用程序中起到“页面”的作用。

 

接下来我们将对每一部分分别进行讲解。

 

主题

像前面提到的,dojox.mobile提供了两种主题:iPhone和Andriod。iPhone主题提供适用于iPhone/iPod和iPad设备的样式表。dojo.mobile引入了一个兼容层来使得这两种iOS设备最大限度地兼容。同时针对非Webkit内核的设备,dojox.mobile 也提供了一套特殊的样式表。为了简化我们的页面,我们将使用iPhone主题:

 

[xhtml] view plaincopy
 
  1. <link href="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojox/mobile/themes/iphone/iphone.css" mce_href="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojox/mobile/themes/iphone/iphone.css" rel="stylesheet" type="text/css"></link>  

 

 

!dojox.mobile不会侦测设备的种类来导入设备对应的主题。一个很好的做法是在服务器端侦测设备的种类从而向页面写入对应的样式表。HTML页面仅仅用来创建widgets,这样页面就不会受到设备种类的影响了。

导入Dojo和dojox.mobile

使用传荣的SCRIPT标签导入Dojo

 

[javascript] view plaincopy
 
  1. <mce:script src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js" mce_src="http://ajax.googleapis.com/ajax/libs/dojo/1.6/dojo/dojo.xd.js"    djConfig="isDebug:true, parseOnLoad:true"></mce:script>  

 


dojox.mobile和dojox.mobile.parser可以通过传荣的dojo.require方法来导入。

 

[javascript] view plaincopy
 
  1. // 加载widget parserdojo.require("dojox.mobile.parser");// 加载基本库dojo.require("dojox.mobile")  

 


还记得我说过dojox.mobile与Dijit很相似么?另外一个相似之处就是dojox.mobile也有自己的parser来找出那些需要被转换成widget的节点。dojox.mobile下的widget也将和Dijit的widget一样在标签中使用dojoType(或是其他自定义)属性。

 

导入dojox.mobile的最后一步是使用一个requireIf语句来确保当你的客户端不是WebKit内核时为你提供良好的兼容。(比如说你在使用Firefox浏览站点):

 

[javascript] view plaincopy
 
  1. // 如果不是Webkit客户端,加载compat模块dojo.requireIf(!dojo.isWebKit, "dojox.mobile.compat");  

 

 

!dojox.mobile暂不支持data-dojo-type和data-dojo-props这些Dojo 1.6中新的widget声明属性。期待在将来的把本中这些属性在dojox.mobile中得到支持。当前版本中,请暂时使用dojoType和其他内联属性。

 

dojox.mobile.compat加载额外的样式表和JavaScript来确保dojox.mobile可以使用基于JavaScript的动画效果来解决无法使用Webkit内核提供的CSS3动画效果导致widget无法工作的问题。

 

!dojox.mobile.compat并不是必须的。但是使用它是一个很好的习惯。它没有被加入到dojox.mobile的核心是为了尽可能的保持dojo.mobile核心的紧凑。

 

现在我们加载了iPhone主题和dojox.mobile资源,接下来我们就可以往页面上添加widget啦!

 

创建视图(views)和widgets

 

如你所见,创建一个可以使用dojox.mobile的页面就是那么简单。而向页面添加dojox.mobile的widget也一点不难。在我们开始创建widgets之前,让我们先看一下dojox.mobile提供哪些widget:

 

  • View(视图)- 视图是移动应用程序中一个虚拟的“页(page)”。它可以通过左右滚动切换到前一个或是后一个视图。一个页面可以有任意数量的视图。
  • ScrollingView(滚动视图)- 具有一个固定的页眉(header)和页脚 (footer),中间的内容可以被滚动。
  • Button(按钮)- 一个简单的的按钮
  • Switch(开关)- 一个简单的开关
  • Heading(标题)- 一个简单的标题
  • ListItem(列表)- 一个基础列表
  • TabBar & TabBarButton(选项卡栏&选项卡栏按钮)- 选项卡内容管理,可以用以下两种形式:导航控件(蓝色,通常在页面顶端),选项卡栏(黑色,通常在页面底部)
  • ...还有其他的!

 !记住所有widgets的样式都和设备上的控件相似(在你提供的样式表中定制了)。你肯定会想要让你的widget和图标与你将要支持的设备风格一致。

 

现在你已经知道了一些dojox.mobile内置的widget了,我们这就创建一个带有标题栏,一些列表和一个开关的视图:

 

 

[xhtml] view plaincopy
 
  1. <!-- 视图或是“页”;它将是主页 --><div id="settings" dojoType="dojox.mobile.View" selected="true">     <!-- 一个简单的标题栏 -->    <h1 dojoType="dojox.mobile.Heading">"Homepage" View</h1>     <!-- 一个圆角的列表 -->    <ul dojoType="dojox.mobile.RoundRectList">         <!-- 一个带有图标和开关的列表元素 -->        <li dojoType="dojox.mobile.ListItem" icon="images/icon-1.png">            Airplane Mode            <!-- 开关 -->            <div class="mblItemSwitch" dojoType="dojox.mobile.Switch"></div>        </li>         <!-- 一个带有图标的列表元素,用来切换到另一个视图 -->        <li dojoType="dojox.mobile.ListItem" icon="images/icon-2.png" rightText="mac">            Wi-Fi        </li>         <!-- 一个带有图标的列表元素,用来切换到叫“general”的视图 -->        <li dojoType="dojox.mobile.ListItem" icon="images/icon-3.png" rightText="AcmePhone" moveTo="general">            Carrier        </li>    </ul></div>  

 

 

 

!当用户点击“Carrier”元素并切换到“General”视图(或除了主页外任何其他视图),一个iPhone风格的“back”按钮将显示在左上角。而你并不需要在你的视图中添加一个“Back”按钮,你只需要在子视图的Heading(标题栏) widget中设置“back”属性即可。

 

上面我们创建了一个简单的视图。当然,大多数应用程序需要更多的视图。现在就让我们为上面的列子创建“general”视图和“about”视图。

 

 

[xhtml] view plaincopy
 
  1. <!-- "General" 子视图 --><div id="general" dojoType="dojox.mobile.View">    <!-- 标题栏 -->    <h1 dojoType="dojox.mobile.Heading" back="Settings" moveTo="settings">General View</h1>    <!-- 一个圆角的列表 -->    <ul dojoType="dojox.mobile.RoundRectList">        <li dojoType="dojox.mobile.ListItem" moveTo="about">        About        </li>        <li dojoType="dojox.mobile.ListItem" rightText="2h 40m" moveTo="about">        Usage        </li>    </ul></div> <!-- 添加另一个"About"视图 --><div id="about" dojoType="dojox.mobile.View">    <!-- 主视图标题栏 -->    <h1 dojoType="dojox.mobile.Heading" back="General" moveTo="general">About</h1>    <!-- 子标题栏 -->    <h2 dojoType="dojox.mobile.RoundRectCategory">Generic Mobile Device</h2>    <!-- 圆角的列表 -->    <ul dojoType="dojox.mobile.RoundRectList">        <li dojoType="dojox.mobile.ListItem" rightText="AcmePhone">        Network                                                   </li>                                                       <li dojoType="dojox.mobile.ListItem" rightText="AcmePhone">        Line        </li>        <li dojoType="dojox.mobile.ListItem" rightText="1024">        Songs        </li>        <li dojoType="dojox.mobile.ListItem" rightText="10">        Videos        </li>    </ul></div>  

 

 

演示

 

!请注意widget使用的自定义属性。完整的自定义属性列表可以参见dojox.mobile API docs for each widget 。同时请注意,标签形式的widget对搜索引擎更友好。

 

恭喜,你已经创建了你第一个dojox.mobile web应用程序!dojox.mobile让创建移动应用程序中的基本元素变得轻而易举!以后你的移动应用程序变得更加复杂,请记住dojox.mobile提供基本的主题,widgets和创建多视图应用程序的方法。

 

dojox.mobile相关资源

 

分享到:
评论

相关推荐

    多文件上传 dojo组件 dojox.form.FileUploader

    NULL 博文链接:https://mojianpo.iteye.com/blog/753665

    用DOJO中的dojox.gfx做甘特图

    用DOJO中的dojox.gfx做甘特图 用DOJO中的dojox.gfx做甘特图

    Dojo 入门 + Dojo 工具包系列 + Dojo 使用技巧 ......

    随着富互联网应用程序(Rich Internet Application,RIA)的发展,一批 JavaScript Toolkit 也随之兴起 , Dojo 便是其中的优秀代表,本系列文章 将由浅入深带领读者走进 Dojo 的世界。本文作为这个系列的开篇 , 主要...

    dojo入门系列教程.rar

    dojo入门系列教程,包含入门简介,在javascript基础上介绍dojo的语法特色,ajax的dojo包装---xhr框架的编程要点, Dojo 事件机制.以及对dojo最具特色的web UI设计的全面介绍.

    Mastering Dojo-JavaScript and Ajax Tools for Great Web Experiences

    3.3 A Wish List with dojo.data and dojox.grid.Grid . 46 3.4 Researching Cigars Using JSONP . . . 56 3.5 Reviews with dojo.xhrGet . . 63 3.6 Errors and Debugging . . . . 67 II The Dojo APIs 70 4 Dojo ...

    DOJO 学习笔记 dojo

    dojo.lang.array & dojo.lang.func & dojo.string.extras) 13 六、 Dojo学习笔记(6. dojo.io.IO & dojo.io.BrowserIO) 18 七、 Dojo学习笔记(7. dojo.dom) 22 八、 Dojo学习笔记(8. dojo.event & dojo.event.topic ...

    edt.mobile.widgets.v.20120628.zip

    org.eclipse.edt.rui.dojo.mobile.nightly: provides dojo egl mobile widgets support.(使用请参考sample) b. org.eclipse.edt.rui.phonegap.mobile.nightly: provides mobile device native feature support....

    dojo精品中文教程(包一)

    dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...

    dojo精品中文教程(全)

    dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...

    Dojo包下载 包含dijit dojo dojox util四个文件目录

    Dojo开发包: 包含以下目录dijit dojo dojox util

    dojo权威入门教程

    dojo权威入门教程

    SVG to dojox.gfx Convertor-开源

    该项目旨在提供一种简化SVG图形和Javascript代码之间的转换的方法,使用Dojo Toolkit的dojox.gfx库重新创建相似的图形是必需的。

    dojo精品中文教程(包二)

    dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...

    Dojo入门手册.rar

    3 设置和配置Dojo................................. 4 3.1 选择正确的Dojo........... 4 3.1 选择正确的Dojo创建.............4 3.2 动态加载 package....5 3.3 定制的创建............. 5 4 应用:旅行路线...

    Dojo学习资料 入门教材

    Dojo入门教程之dojo.io.bind详解 Post的例子 dojo.io.queueBind 详解

    Addison.Wesley.Dojo.Using.the.Dojo.JavaScript.Library.to.Build.Ajax.Applications.Jun.2008.pdf

    Addison.Wesley.Dojo.Using.the.Dojo.JavaScript.Library.to.Build.Ajax.Applications.Jun.2008.pdf

    dojo学习...........

    dojo学习 dojo学习 dojo学习 dojo学习 dojo学习

    dojo精品中文教程(包三)

    dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...

    EDT Mobile Runtime v5

    org.eclipse.edt.rui.dojo.mobile.nightly: provides dojo egl mobile widgets support.(使用请参考sample) b. org.eclipse.edt.rui.phonegap.mobile.nightly: provides mobile device native feature support....

    EDT Mobile Runtime v6

    org.eclipse.edt.rui.dojo.mobile.nightly: provides dojo egl mobile widgets support.(使用请参考sample) b. org.eclipse.edt.rui.phonegap.mobile.nightly: provides mobile device native feature support....

Global site tag (gtag.js) - Google Analytics