作者: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标签的知识。
你可以使用下面的模板开始创建你的应用程序:
有了上面的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主题:
!dojox.mobile不会侦测设备的种类来导入设备对应的主题。一个很好的做法是在服务器端侦测设备的种类从而向页面写入对应的样式表。HTML页面仅仅用来创建widgets,这样页面就不会受到设备种类的影响了。
导入Dojo和dojox.mobile
使用传荣的SCRIPT标签导入Dojo
dojox.mobile和dojox.mobile.parser可以通过传荣的dojo.require方法来导入。
还记得我说过dojox.mobile与Dijit很相似么?另外一个相似之处就是dojox.mobile也有自己的parser来找出那些需要被转换成widget的节点。dojox.mobile下的widget也将和Dijit的widget一样在标签中使用dojoType(或是其他自定义)属性。
导入dojox.mobile的最后一步是使用一个requireIf语句来确保当你的客户端不是WebKit内核时为你提供良好的兼容。(比如说你在使用Firefox浏览站点):
!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了,我们这就创建一个带有标题栏,一些列表和一个开关的视图:
!当用户点击“Carrier”元素并切换到“General”视图(或除了主页外任何其他视图),一个iPhone风格的“back”按钮将显示在左上角。而你并不需要在你的视图中添加一个“Back”按钮,你只需要在子视图的Heading(标题栏) widget中设置“back”属性即可。
上面我们创建了一个简单的视图。当然,大多数应用程序需要更多的视图。现在就让我们为上面的列子创建“general”视图和“about”视图。
演示
!请注意widget使用的自定义属性。完整的自定义属性列表可以参见dojox.mobile API docs for each widget 。同时请注意,标签形式的widget对搜索引擎更友好。
恭喜,你已经创建了你第一个dojox.mobile web应用程序!dojox.mobile让创建移动应用程序中的基本元素变得轻而易举!以后你的移动应用程序变得更加复杂,请记住dojox.mobile提供基本的主题,widgets和创建多视图应用程序的方法。
dojox.mobile相关资源
继续学习!
现在我们已经学习了dojox.mobile的基础,本系列的下面几篇教程将介绍如何创建一个动态的,数据驱动的移动应用程序“TweetView”。TweetView将会用到很多dojox.mobile widget,并且将兼容Android和iOS设备。该应用程序将从Twitter获取微博信息并格式化后漂亮地输出给用户。
TweetView系列中文教程
Dojo mobile TweetView 系列教程之一 —— dojox.mobile入门
Dojo mobile TweetView 系列教程之二 —— TweetView 启程
Dojo mobile TweetView 系列教程之三 —— Tweets和Mentions视图
Dojo mobile TweetView 系列教程之四 —— 创建Setting视图
分享到:
相关推荐
标题中的“多文件上传 dojo组件 dojox.form.FileUploader”是指使用Dojo JavaScript库中的dojox.form.FileUploader组件来实现网页上的多文件上传功能。Dojo是一个强大的JavaScript框架,它提供了丰富的UI组件和工具...
dojox.gfx是DOJO的一个图形库,提供了丰富的图形绘制功能,支持矢量图形的创建,非常适合用于制作图表、图形界面等。甘特图是一种常用的时间线表示法,用于可视化项目进度和任务安排。 描述中简短地提到了甘特图的...
随着RIA的兴起,Dojo成为了JavaScript开发者的首选之一,尤其是对于那些有Java背景的开发者,它提供了一种结构化的、面向对象的方式来处理Web前端的复杂性。 Dojo的核心是一个模块化的体系架构,允许开发者按需加载...
dojo入门系列教程,包含入门简介,在javascript基础上介绍dojo的语法特色,ajax的dojo包装---xhr框架的编程要点, Dojo 事件机制.以及对dojo最具特色的web UI设计的全面介绍.
Dojo Toolkit是JavaScript的一个强大的、模块化的开发框架,其中的dojox.gfx库为浏览器端的2D图形提供了抽象层,支持多种渲染后端,如SVG、VML、Canvas和Silverlight。 这个开源项目“SVG to dojox.gfx Convertor”...
手册中列举了一些常用的Dojo包,如dojo.io用于不同类型的IO传输,dojo.dnd提供拖放功能的API,dojo.string提供了字符串处理方法,dojo.date帮助解析和操作日期,dojo.event处理事件驱动和AOP开发,dojo.back管理撤销...
开发人员可以在引用 dojo.js 前声明 djConfig 对象,以便在加载 dojo.js 的时候取得所设置的值。 Dojo API 提供了一个功能强大且灵活的开发平台,支持开发人员快速构建 Rich Internet Applications。
### Dojo技术入门知识点概述 #### 一、Dojo简介 Dojo是一个开源的JavaScript工具包,主要用于构建富互联网应用(Rich Internet Applications, RIA)。它具有轻量级且易于安装的特点,在Web 2.0时代,随着Ajax技术...
1. **Dojo基础**:首先,读者会了解到Dojo的核心概念,如dojo.js加载器、dojo.declare用于类定义、dojo.connect用于事件处理,以及dojo.query用于DOM查询。这些基础知识是理解Dojo工作的关键。 2. **模块系统(AMD...
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.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...
dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...
例如,`dojo.html`模块包含了处理HTML内容的一系列函数,而`dojo.dnd`模块则提供了拖放功能的类。每个模块的命名遵循一定的规则,函数名首字母小写,类名首字母大写,以提高可读性。 在Dojo中,包是一种组织模块的...
《dojo权威入门教程》是一本专注于JavaScript库Dojo Toolkit的学习指南,主要面向Java开发者或对Web前端技术感兴趣的人员。Dojo Toolkit是一个强大的JavaScript框架,它提供了丰富的组件、工具和API,帮助开发者高效...
Dojo API中文参考手册是一个面向初学者的指导性文件,它详细介绍了Dojo框架的体系结构、常用包及功能,并通过附加注释实例帮助开发者理解和使用Dojo。以下是根据给定内容整理的知识点: 1. Dojo体系架构分层: - ...
dojo学习笔记(一)-dojo.io.IO & dojo.io.BrowserIO) dojo学习笔记(三) dojo学习笔记(二) dojo.lang.array & dojo.lang.func & dojo.string.extras dojo学习笔记(六)- ContentPane dojo学习笔记(四)...
Dojo的模块化设计是其一大特色,通过`dojo.require`或`require`方法可以按需加载所需模块,降低页面加载负担。此外,Dojo Toolkit提供了`dojo.declare`用于类的定义,支持面向对象编程。 Dojo中的Widget系统是另一...
Dojo 是一个强大的JavaScript工具库,它为Web开发提供了丰富的功能和组件,支持现代浏览器以及对旧版浏览器的兼容。这个包下载包含了四个主要的文件目录:dijit、dojo、dojox 和 util,这些都是Dojo框架的核心部分。...
3 设置和配置Dojo................................. 4 3.1 选择正确的Dojo........... 4 3.1 选择正确的Dojo创建.............4 3.2 动态加载 package....5 3.3 定制的创建............. 5 4 应用:旅行路线...