使用DCloud+Framework7制作移动APP应用

十度 Android 2016年04月18日 收藏

现在使用Html+Css+Js制作移动应用是越来越火,所以在此记录下我个人使用DCloud+Framework7进行移动APP开发过程,方便以后查阅。

一、准备

环境:Win7 64位

开发工具:HBuilder(下载地址:http://www.dcloud.io/  ) 

设计到的原型工具:

DCloud(地址:http://www.html5plus.org/doc/zh_cn/accelerometer.html   )  

Framework7(中文地址:http://framework7.taobao.org       英文地址:http://www.idangero.us/framework7  )

二、进行开发

1、打开HBuilder,建议一个HelloWorld的空模板移动应用

20151015093718_670.jpg

2、下载Framwork7,解压,将dist文件夹拷贝到项目中,并重命名为Framework7,然后我们的项目文件大概为这样:

20151015093723_837.jpg

注:一下操作流程大多数是对Framework7的使用,可以参考(http://framework7.taobao.org/get-started)

3、修改你的index.html文件,编写你的主文件,代码如下:(这段代码来自于Framework7的基本IOS样式,进行了简单文字修改)

  1. <!DOCTYPE html>
  2. <html>
  3.   <head>
  4.     <!-- Required meta tags-->
  5.     <meta charset="utf-8">
  6.     <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, minimal-ui">
  7.     <meta name="apple-mobile-web-app-capable" content="yes">
  8.     <meta name="apple-mobile-web-app-status-bar-style" content="black">
  9.     <!-- Your app title -->
  10.     <title>Hello World</title>
  11.     <!-- Path to Framework7 Library CSS, iOS Theme -->
  12.     <link rel="stylesheet" href="Framework7/css/framework7.ios.min.css">
  13.     <!-- Path to Framework7 color related styles, iOS Theme -->
  14.     <link rel="stylesheet" href="Framework7/css/framework7.ios.colors.min.css">
  15.     <!-- Path to your custom app styles-->
  16.     <link rel="stylesheet" href="css/my-app.css">
  17.   </head>
  18.   <body>
  19.     <!-- Status bar overlay for full screen mode (PhoneGap) -->
  20.     <div class="statusbar-overlay"></div>
  21.     <!-- Views -->
  22.     <div class="views">
  23.       <!-- Your main view, should have "view-main" class -->
  24.       <div class="view view-main">
  25.         <!-- Top Navbar-->
  26.         <div class="navbar">
  27.           <div class="navbar-inner">
  28.             <!-- We need cool sliding animation on title element, so we have additional "sliding" class -->
  29.             <div class="center sliding">Hello World</div>
  30.           </div>
  31.         </div>
  32.         <!-- Pages container, because we use fixed-through navbar and toolbar, it has additional appropriate classes-->
  33.         <div class="pages navbar-through toolbar-through">
  34.           <!-- Page, "data-page" contains page name -->
  35.           <div data-page="index" class="page">
  36.             <!-- Scrollable page content -->
  37.             <div class="page-content">
  38.               <p>这是首页,你可以在打开的时候就看到我了</p>
  39.               <!-- Link to another page -->
  40.               <a href="about.html">关于我</a>
  41.             </div>
  42.           </div>
  43.         </div>
  44.         <!-- Bottom Toolbar-->
  45.         <div class="toolbar">
  46.           <div class="toolbar-inner">
  47.             <!-- Toolbar links -->
  48.             <a href="#" class="link">链接1</a>
  49.             <a href="#" class="link">链接2</a>
  50.           </div>
  51.         </div>
  52.       </div>
  53.     </div>
  54.     <!-- Path to Framework7 Library JS-->
  55.     <script type="text/javascript" src="Framework7/js/framework7.min.js"></script>
  56.     <!-- Path to your app js-->
  57.     <script type="text/javascript" src="js/my-app.js"></script>
  58.   </body>
  59. </html>

你也需要添加必须要的css/my-app.css和js/my-app.js文件

4、在index.html上右键--》运行--》web应用程序进行调试(或者点击编辑器上面的运行调试,或者使用真机调试都可以,这里不一 一 讲解),效果如下:

20151015093725_67.jpg

5、大概有个效果样子了,现在我们来添加一个新页面功能:关于我

①编辑js/my-app.js文件

  1. // 初始化APP
  2. var myApp = new Framework7();
  3. // If we need to use custom DOM library, let's save it to $$ variable:
  4. var $$ = Framework7.$;
  5. // Add view
  6. var mainView = myApp.addView('.view-main', {
  7.   // Because we want to use dynamic navbar, we need to enable it for this view:
  8.   dynamicNavbar: true
  9. });

②、在根目录添加一个about.html的页面

  1. <!-- We don't need full layout in this file because this page will be parsed with Ajax. It is just enough to put here .navbar and .page-->
  2. <!-- Top Navbar-->
  3. <div class="navbar">
  4.   <div class="navbar-inner">
  5.     <div class="left">
  6.       <a href="#" class="back link">
  7.         <i class="icon icon-back-blue"></i>
  8.         <span>返回</span>
  9.       </a>
  10.     </div>
  11.     <div class="center sliding">关于我</div>
  12.     <div class="right">
  13.       <a href="#" class="link icon-only open-panel"><i class="icon icon-bars-blue"></i></a>
  14.     </div>
  15.   </div>
  16. </div>
  17. <div class="pages">
  18.   <div data-page="about" class="page">
  19.     <div class="page-content">
  20.       <div class="content-block">
  21.         <p>关于我</p>
  22.         <p>这是Hello World项目的一个关于我的页面,你是通过首页的关于我链接打开的。</p>
  23.         <p>这个项目是一个基础演示项目,使用DCloud+Framework7进行开发。</p>
  24.       </div>
  25.     </div>
  26.   </div>
  27. </div>

③、给我们的about页面添加一个必要的ajax引导,编辑my-app.js,增加如下内容:

  1. $$(document).on('pageInit', '.page[data-page="about"]', function(e) {
  2.     //这里你可以做很多事情
  3. });

④、修改我们的index.html文件,在需要点击打开关于我们的页面添加链接:

  1. <div class="page-content">
  2.               <p>这是首页,你可以在打开的时候就看到我了</p>
  3.               <!-- Link to another page -->
  4.               <a href="about.html">关于我</a>
  5.             </div>

⑤、像第4步一样运行一下,点击“关于我”就可以得出如下效果:

20151015093730_870.jpg

6、一个演示APP基础制作就完成了,可是现在还不是APP,想要弄到安卓(或者IOS)上面运行,就需要进行打包

PS:真机测试就像使用APP样,如果只是简单学习,可以真机演示

下面进行打包:

①、点击HBuilder编辑器上面的  运行--》打包APP,根据你的机型进行打包

20151015093732_808.jpg

②、打包完成后会生成一个APP,将APP拷贝到你的手机中进行安装即可

7、这样,一个简单的APP就制作完成了

三、附件

1、演示代码没有进行GIT托管,请通过http://pan.baidu.com/s/1ukwV0下载

2、如果要进行更加丰富的APP开发,你需要学习Framework7和Dcloud的Html5+,官方网站都有丰富的文档,认真阅读,开发一个普通APP不是问题。

3、Framework的替代产品:mui、jquery mobile、其他UI框架等

4、DCloud的替代产品:APICloud,PhoneGap,AppCan等