精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Titanium TiMVC框架:介紹與使用

移動開發(fā)
Titanium本身已做得很不錯了,所以網(wǎng)上也已有一些優(yōu)秀的MVC框架和插件等,不過試了下,感覺比較好用的就是一個叫TiMVC的框架,這個在官方market上就有,可以免費下載。

這段時間一有空就都在研究Titanium的MVC框架,因為幾個項目做下來,發(fā)現(xiàn)一套好的框架實在是很重要,所以這也成為了當(dāng)務(wù)之急!

Titanium本身已做得很不錯了,所以網(wǎng)上也已有一些優(yōu)秀的MVC框架和插件等,不過試了下,感覺比較好用的就是一個叫TiMVC的框架,這個在官方market上就有,可以免費下載:http://timvc.com/

之所以選擇這個框架,是因為發(fā)現(xiàn)其架構(gòu)清晰,有非常具體的MVC層次,使用起來方便,上手容易,而且更重要的是經(jīng)過上真機(jī)測試也沒什么問題,對2個系統(tǒng)(ios&android)的兼容性也比較好。由于官方網(wǎng)站上并沒有詳細(xì)的使用說明,只是簡單地例出了層次目錄和文件是什么,所以具體使用和功能我也只有直接查看其源碼,經(jīng)過對其源碼越深入的分析,就越感覺其用起來挺順手,呵呵~~

要學(xué)習(xí)一個框架,先要搞清楚的是其整體架構(gòu),以下就是整個TiMVC的項目結(jié)構(gòu):

TiMVC結(jié)構(gòu)

上圖可以看到在MVC目錄下的層次結(jié)構(gòu)是比較清楚的:

assets:這個是資源文件目錄,包括圖片和數(shù)據(jù)庫文件的存放。

components:這個是組件目錄,包括框架里的核心組件,一般不需修改這里的文件。

controllers:控制器目錄,包含了項目里所需用到的控制器,根據(jù)需要自己創(chuàng)建。

core:此為框架核心文件目錄,其他目錄的代碼均要以此為中心啦,呵呵。

models:數(shù)據(jù)模型目錄,主要是與數(shù)據(jù)庫交互的實體類的操作。

views:視圖目錄,里面每個子目錄均對應(yīng)一個控制器名稱,子目錄里的文件就是具體的action了。

OK,介紹完層次結(jié)構(gòu)后,就說說其原理和使用。MVC的原理就不需我多說啦,如果不了解MVC模式的話,可上google看看。首先說一下此框架的配置,打開app.js文件就可以看到一大堆配置信息,這也是我喜歡使用它的原因之一,可以有很靈活的配置選項,非常方便哦!

不過不得不說的是,雖然其配置項不少,但基本上都不需要去更改的,大部分是框架路徑的配置,所以如果只用其默認(rèn)這些配置,一般來說其實意義不是很大,我之所以使用它,就是因為我可以對這些配置信息進(jìn)行擴(kuò)展,以達(dá)到真正方便控制整個項目流程的效果,這個在以后的文章中我會慢慢介紹.現(xiàn)在說一下框架的運(yùn)行流程和使用吧。核心代碼分析暫且不說,直接打開controller目錄下的main.js文件,這個是主要的入口文件,其是繼承components/controller.js文件的,在main.js里定義了一個action—home:

  1. this.home = function(r){ 
  2.         //build table data to be used in table ui 
  3.         var list = []; 
  4.         list.push({title:"Tab Example",route:"example/tabgroup",request:{},hasChild:true,newWindow:false,height:self.App.util.dP(50)}); 
  5.         if(self.App.iPhone){ 
  6.             list.push({title:"iPhone Only Dashboard Example",route:"example/dashboard",request:{},hasChild:true,newWindow:true,height:self.App.util.dP(50)}); 
  7.         } 
  8.         list.push({title:"Multi-Dashboard Example",route:"example/multidashboard",request:{},hasChild:true,newWindow:true,height:self.App.util.dP(50)}); 
  9.         list.push({title:"Database Example",route:"example/database",request:{message:'Hello from the database!'},hasChild:true,newWindow:true,height:self.App.util.dP(50)}); 
  10.  
  11.         //render /mvc/views/main/home.js view file with data 
  12.         self.render('home',{"list":list}); 

在home里主要是創(chuàng)建了一個list的數(shù)組,然后存放了相關(guān)的數(shù)據(jù)信息,每一條數(shù)據(jù)就是一個導(dǎo)航信息,包括標(biāo)題,路由,請求數(shù)據(jù)等,最后一句是重點,直接render到名字為home的view里,同時將整個list數(shù)據(jù)傳遞過去。然后我們再打開views/main/home.js文件,其他代碼先不需理會,主要看:

  1. this.addContent = function(){ 
  2.         self.rootView = Titanium.UI.createTableView({ 
  3.             data:self.data.list 
  4.         }); 
  5.         self.rootView.addEventListener('click',function(e){ 
  6.             if(e.rowData.newWindow){ 
  7.                 self.App.loadRoute(e.rowData.title,e.rowData.route,e.rowData.request); 
  8.             }else{ 
  9.                 self.App.setWindowRoute(e.rowData.route,e.rowData.request); 
  10.                 self.App.routeWindow(); 
  11.             } 
  12.         }); 

這段是為當(dāng)前視圖添加相關(guān)的UI代碼,所有view里都以一個rootView為基礎(chǔ),因此要在view里創(chuàng)建界面,就要先創(chuàng)建一個self.rootView對象,然后將所有東西都放到這個view里來。而通過self.data.list,就可以獲取之前controller傳過來的list數(shù)據(jù)了,這個名字就與controller里寫的一致。

因為以上代碼創(chuàng)建的是一個TableView,所以在其點擊事件里就可以直接調(diào)用list的數(shù)據(jù)了。這里用到了此MVC的幾個核心方法:

  1. /** 
  2. * Execute controller call via route. 
  3. * @param {String} title new window title 
  4. * @param {String} route controller/action route string 
  5. * @param {Object} data json data to be passed to route (new window) 
  6. */ 
  7. this.loadRoute = function(title,route,data); 

這個是加載路由的方法,即可跳轉(zhuǎn)到另一個action,再通過action跳轉(zhuǎn)到另一個view界面,同時可以設(shè)置下一界面的標(biāo)題和數(shù)據(jù),數(shù)據(jù)是JSON格式。

  1. /** 
  2. * Update current window with route and request object (stringified) 
  3. * @param {String} route 
  4. * @param {Object} request 
  5. * @private 
  6. */ 
  7. this.setWindowRoute = function(route,request); 

以上是設(shè)置當(dāng)前窗口的路由信息和傳遞的數(shù)據(jù),一般設(shè)置完后再調(diào)用以下方法進(jìn)行跳轉(zhuǎn):

  1. /** 
  2. * Route window to requested controller and action 
  3. * @private 
  4. * @returns boolean on fail 
  5. */ 
  6. this.routeWindow = function(); 

運(yùn)行項目后,首先看到的將是home里的TableView視圖,同時點擊里面項目的話,就會根據(jù)所設(shè)置list里的數(shù)據(jù)跳轉(zhuǎn)到不同的視圖頁面了。以上代碼就簡單演示了一個頁面的跳轉(zhuǎn)過程。

除了控制器到視圖的跳轉(zhuǎn)外,其實還可以動態(tài)調(diào)用不同頁面的layout,在控制器里,可以調(diào)用以下方法以設(shè)置不同的layout:

  1. /** 
  2. * Set Layout string 
  3. * @param {String} set layout name string 
  4. */ 
  5. this.setLayout = function(layoutName); 

這個layout又是如何用的呢?只要打開views/layouts/default.js就可以看到默認(rèn)的layout代碼,通過不同的layout設(shè)置,我們可以方便地定義不同頁面的結(jié)構(gòu),如所有頁面都要包含headerandfooter等,就可以在layout里設(shè)置,原理和一般的MVC框架差不多(.NET或者cakephp里就有l(wèi)ayout的概念了)

最后再總結(jié)下一些基本用法:

1.要在控制器或者視圖調(diào)用核心方法,都必須以self.App開頭,其實self就是等于this,至于有什么核心方法,大家打開core/timvc.js文件就知道了。

2.在控制器里跳到相應(yīng)的view,使用self.render(viewName,{“data”:data});

3.路由跳轉(zhuǎn)只需在view里調(diào)用self.App.loadRoute(title,controller/action,data);

4.可通過setLayout使用views/layouts目錄下不同的頁面結(jié)構(gòu)

OK,今天就先說到這,關(guān)于此框架的研究和加強(qiáng),我打算在之后文章里再慢慢介紹,也希望大家多多捧場[[67872]]

最后大家可到以下2個地址下載此框架:

http://timvc.com

https://github.com/deboorn/TiMVC

責(zé)任編輯:佚名 來源: coderblog.in
相關(guān)推薦

2012-04-19 13:52:16

TitaniumMVCRedux

2012-04-19 14:16:22

TitaniumTiMVC

2012-04-20 11:07:12

Titanium

2012-04-19 16:22:12

TitaniumTabGroup

2012-05-17 09:09:05

Titanium單元測試

2012-04-19 12:58:26

TitaniumJSS

2022-11-25 07:59:02

SpringJava

2012-05-18 11:34:03

Titaniumcons

2012-05-18 11:29:55

Titaniumpros

2012-02-13 14:41:50

Titanium架構(gòu)分析

2014-05-15 09:43:11

CloudaMobile WebANodejs

2011-07-05 17:29:56

2012-04-19 17:42:46

Titanium布局

2012-04-19 10:52:52

2011-06-22 13:27:04

QT QMap

2012-02-01 09:59:05

TitaniumPhoneGapiOS

2009-12-22 16:10:21

ADO.NET框架

2009-06-22 16:24:33

JSF框架中使用的設(shè)計

2012-04-19 16:17:24

TitaniumAndroidtabbar

2012-04-19 16:55:48

Titanium視頻jQuery Mobi
點贊
收藏

51CTO技術(shù)棧公眾號

国产成人啪精品午夜在线观看| 国产黑丝在线视频| 毛片免费在线| 麻豆国产欧美一区二区三区| 久久精品国产2020观看福利| 国产调教打屁股xxxx网站| 偷拍自拍在线看| 亚洲欧洲精品一区二区三区| 国产精品久久国产精品| 人人妻人人爽人人澡人人精品| 国产精品福利在线观看播放| 亚洲第一区第一页| xxx国产在线观看| 天使と恶魔の榨精在线播放| 久久蜜臀精品av| 亚洲一区二区中文| 久久久久久久久久成人| 欧美日韩视频| 国产亚洲人成a一在线v站| 天天综合成人网| 欧美成人影院| 亚洲成人激情av| 亚洲欧洲精品一区二区三区波多野1战4| 精品人妻一区二区三区换脸明星 | 精品91久久| 亚洲精品欧美综合四区| 欧美一区二区三区精美影视| 性一交一乱一乱一视频| 麻豆精品蜜桃视频网站| 热久久这里只有| 麻豆changesxxx国产| 久久美女视频| 亚洲日韩欧美视频| 人妻av一区二区| 国产精品亚洲欧美一级在线| 欧美日韩精品免费| 中文字幕欧美人妻精品一区| 国产三级电影在线播放| 亚洲激情五月婷婷| 亚洲精品偷拍视频| 男人天堂手机在线| 国产精品欧美极品| 日韩精品最新在线观看| 日本啊v在线| 99久久精品国产精品久久| 97人人模人人爽人人少妇| 国产一区二区三区中文字幕| 青青青爽久久午夜综合久久午夜| 国产69精品久久久久久| 久久精品亚洲无码| 一区三区视频| 久久免费视频在线观看| 久久久久久久9999| 欧美日韩四区| 性欧美在线看片a免费观看| 免费一级片在线观看| 中文字幕免费精品| 欧美精品生活片| 国产女人18水真多毛片18精品 | 少妇高潮大叫好爽喷水| 欧美成人精品一区二区男人看| 国产女人18毛片水真多成人如厕| 日韩激情视频| www 日韩| 国产精品白丝在线| 最近中文字幕免费mv| www.久久ai| 亚洲一区二区三区三| 婷婷五月综合缴情在线视频| 中文字幕一区在线播放| 伊人精品成人久久综合软件| 欧美激情欧美激情| 日韩精品一卡二卡| 老鸭窝亚洲一区二区三区| 日本精品视频在线观看| 成人一级免费视频| 经典三级在线一区| 91网站在线看| 污污的视频网站在线观看| 91网站最新网址| 日本不卡一区| 欧美成人精品一区二区男人看| 亚洲美女视频一区| 97超碰人人澡| 经典三级一区二区| 欧美一区二区视频在线观看2020 | 国产综合成人久久大片91| 91色视频在线导航| 日韩一级中文字幕| 国产欧美精品一区二区色综合| 一级全黄肉体裸体全过程| 青青在线视频| 色综合网色综合| 蜜臀一区二区三区精品免费视频| 国产精品亚洲欧美一级在线| 日韩精品黄色网| 欧美日韩生活片| 国内精品久久久久久久影视麻豆| 欧美又大粗又爽又黄大片视频| 在线观看亚洲国产| 粉嫩嫩av羞羞动漫久久久| 欧美日本国产精品| 国产在线高清视频| 五月天激情小说综合| 性chinese极品按摩| 盗摄系列偷拍视频精品tp| 伊人av综合网| 日韩乱码人妻无码中文字幕| 美女性感视频久久| 国产精成人品localhost| 国产在线一二| 午夜视频一区二区三区| 伊人网在线综合| 日韩有码一区| 久久国产精品久久久| 精品免费囯产一区二区三区| 国产麻豆成人精品| 日韩亚洲视频| 国产亚洲成av人片在线观看| 4438成人网| 亚洲黄色免费视频| 最新亚洲视频| 亚洲综合日韩在线| 成年人视频免费在线观看| 亚洲第一成年网| 亚洲黄色片免费看| 日韩av大片| 日韩av电影手机在线| 亚洲国产精品视频在线| 国产精品久线在线观看| 日本熟妇人妻xxxxx| 99久久免费精品国产72精品九九 | 国产精品国产精品| 国产盗摄在线观看| 欧美日本在线看| 一色道久久88加勒比一| 99国产精品久久久久久久 | 亚洲成熟丰满熟妇高潮xxxxx| 精品伊人久久| 日韩在线播放一区| 中文在线最新版天堂| 久久久影视传媒| 免费成人午夜视频| 精品国内亚洲2022精品成人| 欧美区二区三区| 99久久精品日本一区二区免费 | 亚洲精品在线一区二区| 欧美特黄一级片| 麻豆国产精品视频| 亚洲 国产 日韩 综合一区| 深夜成人福利| 亚洲一二三在线| 亚洲s码欧洲m码国产av| 久久亚洲捆绑美女| 亚洲色欲综合一区二区三区| 亚洲人成亚洲精品| 奇米成人av国产一区二区三区| 欧美 日韩 国产 成人 在线| 亚洲国产一区二区在线播放| 无码av免费精品一区二区三区| 午夜日韩在线| 成人动漫视频在线观看免费| 日韩av官网| 精品sm在线观看| 日本三级午夜理伦三级三| 成人精品鲁一区一区二区| 美脚丝袜脚交一区二区| 欧美精品中文| 国产成人av在线播放| 久久久久久女乱国产| 欧美亚一区二区| 色偷偷www8888| 国产在线视频不卡二| 国产性生活免费视频| 99国产精品免费网站| 欧美一级黄色网| avav免费在线观看| 欧美一区二区三区四区五区| 久久这里只有精品免费| 91在线视频观看| 亚洲老女人av| 欧美精品一卡| 久久久久九九九| 国产成人77亚洲精品www| 神马久久桃色视频| 国产福利第一页| 欧美日韩午夜剧场| 无码人中文字幕| 国产成人av福利| 三级4级全黄60分钟| 99久久婷婷国产综合精品电影√| 成人羞羞视频免费| 88xx成人免费观看视频库 | 国产视频123区| 国产成人精品亚洲777人妖| 欧美极品欧美精品欧美| 久久综合电影| 国产日韩欧美综合精品| 福利一区二区| 97精品视频在线播放| 在线观看黄av| 亚洲精品在线一区二区| 亚洲熟妇无码久久精品| 亚洲一区二区av在线| 日韩女同一区二区三区| 国产精品一级二级三级| 国产二区视频在线播放| 亚洲欧洲中文字幕| 欧美性色黄大片人与善| 2020最新国产精品| 国产精品青草久久久久福利99| 国产经典三级在线| 日韩中文在线视频| 欧美在线一卡| 日韩精品一区二区在线观看| 真实新婚偷拍xxxxx| 亚洲成人av一区二区| 欧美福利在线视频| 91浏览器在线视频| 午夜影院福利社| 精品一区二区三区视频在线观看| 白嫩少妇丰满一区二区| 黑人一区二区三区四区五区| 一区二区高清视频| 九九免费精品视频在线观看| 国产精品sss| 亚洲日韩中文字幕一区| 国产aⅴ夜夜欢一区二区三区 | 国产草草影院ccyycom| 91高清在线观看| 中文字幕第28页| 亚洲男人的天堂av| 精品在线观看一区| 欧美激情资源网| 少妇大叫太粗太大爽一区二区| 丰满白嫩尤物一区二区| 色男人天堂av| 激情六月婷婷久久| 男生操女生视频在线观看 | 亚洲国产日韩一级| 国产黄色的视频| 亚洲丝袜自拍清纯另类| 日日操免费视频| 国产亚洲欧美一级| 色婷婷av777| 久久亚洲欧美国产精品乐播| 亚洲精品乱码久久久久久不卡| 成人毛片在线观看| 亚洲黄色小说在线观看| 国产福利91精品一区二区三区| 777一区二区| 久久爱www久久做| 亚洲一区日韩精品| 久久超级碰视频| 一级黄色在线播放| 国产一区二区免费看| 99999精品| 国产精品99久久久久久宅男| 性生活在线视频| 激情五月激情综合网| www.久久久久久久久久久| 麻豆成人综合网| 香蕉视频999| 国产精品系列在线播放| 99热超碰在线| av男人天堂一区| www.超碰97| 国产午夜精品一区二区三区嫩草| 国产1区2区在线观看| 中文字幕在线不卡一区二区三区| 永久免费看片直接| 亚洲国产日韩a在线播放| 日韩成人高清视频| 色先锋资源久久综合| 中文字幕在线观看你懂的| 欧美区视频在线观看| 99热这里是精品| 亚洲成人网在线观看| 农村寡妇一区二区三区| 国产欧美日韩综合精品一区二区三区| 欧美精品九九99久久| 国产aⅴ一区二区三区| 精品国产乱子伦一区| 秋霞av在线| xvideos亚洲| 久久免费电影| 日韩免费在线看| 亚洲成人1区| 国产精品二区在线| 国产亚洲一卡2卡3卡4卡新区 | av在线无限看| 狠狠色丁香九九婷婷综合五月| 国产午夜在线一区二区三区| 久久久午夜电影| 91在线播放观看| 一本一道波多野结衣一区二区| 中文字幕理论片| 精品国产乱子伦一区| 国产一区电影| 欧美激情奇米色| 国产福利亚洲| 国产亚洲情侣一区二区无| 波多野结衣在线播放一区| 日韩精品久久一区二区| 秋霞午夜av一区二区三区| 无码成人精品区在线观看| 国产精品卡一卡二| 欧美日韩精品区| 欧美一级欧美三级| 国产玉足榨精视频在线观看| 欧美国产日韩视频| 欧美xxxx网站| 欧美极品视频一区二区三区| 中文字幕乱码亚洲无线精品一区| 久久久久久久久久久久久国产精品 | 91亚洲大成网污www| 极品久久久久久| 欧美无人高清视频在线观看| 五月婷婷综合久久| 九九久久综合网站| 国产原创一区| 欧美日韩一区二区视频在线| 在线欧美视频| 一级黄色免费毛片| 国产精品毛片a∨一区二区三区| 99热国产在线观看| 欧美xxxxxxxxx| 国精产品一区| 成人精品视频在线| 精品视频免费在线观看| 国产乱子伦农村叉叉叉| 岛国精品一区二区| 一区二区在线观看免费视频| 91超碰这里只有精品国产| 日韩毛片久久久| 国产精品美女久久久免费| 国产欧美日韩| 国产成人久久777777| 久久久五月婷婷| 黄色在线免费观看| 亚洲另类图片色| 中文在线免费二区三区| 精品欧美国产一区二区三区不卡| 好看的av在线不卡观看| 日本少妇xxx| 亚洲综合一区二区| 亚洲第一成年人网站| 欧美成人自拍视频| 一区二区三区在线免费看| 妞干网这里只有精品| 国产一区二区电影| 老女人性淫交视频| 日韩精品中午字幕| av影视在线看| 国产伦精品一区二区三区四区免费| 欧美三区不卡| 日本精品一二三区| 五月综合激情网| 深夜福利免费在线观看| 欧美中在线观看| 免费av一区| 国产精品igao| 中文字幕五月欧美| av中文字幕第一页| 久久免费少妇高潮久久精品99| 美女扒开腿让男人桶爽久久动漫| 97国产在线播放| 国产校园另类小说区| 一本一道精品欧美中文字幕| 欧美xxxx综合视频| 国产精品2023| 无码aⅴ精品一区二区三区浪潮 | 日韩欧美视频免费观看| 91麻豆精品国产综合久久久久久| 在线免费观看的av| 国产在线精品二区| 久久久久久一区二区| 国产探花视频在线播放| 91精品黄色片免费大全| av福利导福航大全在线| 欧美日韩国产不卡在线看| 蜜桃精品在线观看| 免费在线观看黄视频| 亚洲精品美女在线| 成人网ww555视频免费看| 国产四区在线观看| 波多野结衣91| 在线免费看av片| 久久久久久免费精品| 国产毛片一区二区三区| 午夜福利123| 精品美女久久久久久免费| 成年人在线观看| 官网99热精品| 美女视频黄免费的久久 | 日韩中文欧美| 国产国语老龄妇女a片| 欧美午夜片在线观看| 色呦呦在线播放| 日韩一本精品|