当前位置:  编程技术>移动开发
本页文章导读:
    ▪XCode5 去除 StatusBar        XCode5 去掉 StatusBar 要隐藏StatusBar, 在iOS7之前,只需要添加 [[UIApplication sharedApplication] setStatusBarHidden:YES]; 现在需要在plist文件中添加键值 UIStatusBarHidden:YES UIViewControllerBasedStatusBarAppearance:NO ......
    ▪ 写文件,真机跟模拟器是不一样的        写文件,真机和模拟器是不一样的      在真机上,只能往  Documents 和 tmp 目录下写文件。因为文件夹Resouces是只读的,无法写入。document 和temp文件夹的东西才是可读写的。      在模.........
    ▪ Dojo mobile TweetView 系列课程之一 —— dojox.mobile入门       Dojo mobile TweetView 系列教程之一 —— dojox.mobile入门 作者:David Walsh 翻译:Siqi (siqi.zhong@gmail.com) 原文:Get started with dojox.mobile   Web技术飞速更新,而现在Web的趋势也是逐渐向移动设备上迁.........

[1]XCode5 去除 StatusBar
    来源: 互联网  发布时间: 2014-02-18
XCode5 去掉 StatusBar

要隐藏StatusBar, 在iOS7之前,只需要添加

[[UIApplication sharedApplication] setStatusBarHidden:YES];

现在需要在plist文件中添加键值

UIStatusBarHidden:YES

UIViewControllerBasedStatusBarAppearance:NO


    
[2] 写文件,真机跟模拟器是不一样的
    来源: 互联网  发布时间: 2014-02-18
写文件,真机和模拟器是不一样的
     在真机上,只能往  Documents 和 tmp 目录下写文件。因为文件夹Resouces是只读的,无法写入。document 和temp文件夹的东西才是可读写的。
      在模拟器上没有这个限制。
      血泪教训啊!

    
[3] Dojo mobile TweetView 系列课程之一 —— dojox.mobile入门
    来源: 互联网  发布时间: 2014-02-18
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在不同平台大致的样子:

  • iPhone 界面
  • Andriod 界面
  • iPad 界面
  • 查看所有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
 
  • <!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
     
  • <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
     
  • <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
     
  • // 加载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
     
  • // 如果不是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
     
  • <!-- 视图或是“页”;它将是主页 --><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  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
     
  • <!-- "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相关资源

     

    • dojox.mobile API
    • dojox.mobile Reference Guide
    • dojox.mobile 1.6 Tests

        
    最新技术文章:
    ▪Android开发之登录验证实例教程
    ▪Android开发之注册登录方法示例
    ▪Android获取手机SIM卡运营商信息的方法
    ▪Android实现将已发送的短信写入短信数据库的...
    ▪Android发送短信功能代码
    ▪Android根据电话号码获得联系人头像实例代码
    ▪Android中GPS定位的用法实例
    ▪Android实现退出时关闭所有Activity的方法
    ▪Android实现文件的分割和组装
    ▪Android录音应用实例教程
    ▪Android双击返回键退出程序的实现方法
    ▪Android实现侦听电池状态显示、电量及充电动...
    ▪Android获取当前已连接的wifi信号强度的方法
    ▪Android实现动态显示或隐藏密码输入框的内容
    ▪根据USER-AGENT判断手机类型并跳转到相应的app...
    ▪Android Touch事件分发过程详解
    ▪Android中实现为TextView添加多个可点击的文本
    ▪Android程序设计之AIDL实例详解
    ▪Android显式启动与隐式启动Activity的区别介绍
    ▪Android按钮单击事件的四种常用写法总结
    ▪Android消息处理机制Looper和Handler详解
    ▪Android实现Back功能代码片段总结
    ▪Android实用的代码片段 常用代码总结
    ▪Android实现弹出键盘的方法
    ▪Android中通过view方式获取当前Activity的屏幕截...
    ▪Android提高之自定义Menu(TabMenu)实现方法
    ▪Android提高之多方向抽屉实现方法
    ▪Android提高之MediaPlayer播放网络音频的实现方法...
    ▪Android提高之MediaPlayer播放网络视频的实现方法...
    ▪Android获取当前已连接的wifi信号强度的方法 iis7站长之家
     


    站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3