成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

整合jQuery Mobile+AngularJs 經驗談

開發 前端
兩者都是不錯的JS編程框架,但是各自用途不同,像jQuery Mobile提供了不錯的圖形空間,以及依賴于jQuery本身,提供了不少空間操作的API,Angular沒有啥控件,但是是一個很好的JS的MVC框架,以及提供了空間的數據綁定功能。

兩者都是不錯的JS編程框架,但是各自用途不同

1. jQuery Mobile提供了不錯的圖形空間,以及依賴于jQuery本身,提供了不少空間操作的API

2. Angular沒有啥控件,但是是一個很好的JS的MVC框架,以及提供了空間的數據綁定功能。

 

于是,開始有些開源的項目把兩者整合在一起,比如

https://github.com/opitzconsulting/jquery-mobile-angular-adapter

但是有了這個adapter,兩者就可以很好的工作了么,NO。有些問題,比如 兩者page加載方式是不一樣的,對于每個page, Angular是導航的使用route在需要的時候把page片段加載到瀏覽器的,URL類似于http://angular.github.io/angular-phonecat/step-7/app/#/phones/motorola-xoom-with-wi-fi,注意在#后面才是真正的資源地址,然后初始化資源對應的controller,這樣你可以初始化顯示數據。然后jQuery Mobile是需要一次性把所有page都加載到客戶端。這樣子的話,如果如果在jQuery Mobile中你為每個page定義一個angular的controller,那么初始化你的angular controller的時候頁面還未顯示

我們需要一個設計實現,為每個jQuery Mobile Page定義一個Angular的controller,每個controller完成對應的page的數據綁定,如何實現

1. 頁面開發使用jQuery Mobile, 我們為root body定義一個root的angular controller比如<body ng-controller="AppCtrl">

2. 導航問題:導航使用jQuery Mobile的$.mobile.changePage而不使用angular的route,因為頁面使用的jQuery Mobile寫的。頁面導航除了切換page,最重要的一點是初始化頁面數據,而因為在jQuery mobile下面,在頁面加載階段所有的controller都初始化了,你只能導航時在root controller里再去重新刷新顯示頁面的綁定數據,這樣要求所有頁面的綁定數據需要在root controller里面定義,按照angular的規則,所有的子controller都會繼承這些數據定義。定義的時候***使用結構而不是用primary type,這樣子controller可以直接飲用,比如定義一個shop的數據結構

  1. $scope.shop&nbsp;=&nbsp;{};  
  2. $scope.shop.catelogs&nbsp;=&nbsp;null;  
  3. $scope.shop.advices&nbsp;=&nbsp;[];  
  4. $scope.shop.child&nbsp;=&nbsp;[];  
  5. $scope.shop.products&nbsp;=&nbsp;[]; 

3. 我往往會個導航定義一個單獨的控制器,使用它初始化page controller,比如

  1. angular  
  2. .module(  
  3. 'ngPageNav',  
  4. [],  
  5. [  
  6. '$provide',  
  7. function($provide)&nbsp;{  
  8. $provide  
  9. .factory(  
  10. 'ngPageNavigator',  
  11. [  
  12. '$http',  
  13. function($http)&nbsp;{  
  14. function&nbsp;nav($scope,  
  15. $http,&nbsp;action,  
  16. data,  
  17. ignoreStack)&nbsp;{  
  18. .....  
  19. }  
  20. return&nbsp;{  
  21. nav&nbsp;:&nbsp;nav,  
  22. back&nbsp;:&nbsp;back  
  23. };  
  24. &nbsp;  
  25. }  
  26. }&nbsp;]); 

} ]).value('name', 'ngPageNav');
 

3. 你調用$.mobile.changePage往往頁面綁定數據變了,但是頁面不會刷新page頁面,最簡單的處理方式是往后臺send 一個dummy的請求。

4. 如果你在打開你的jQuery Mobile的時候需要直接切換到某個page,請在你的root controller里面監聽jqmInit

  1. $scope.$on("jqmInit",function() {   
  2.  
  3. }  

原文鏈接:http://my.oschina.net/trumanspace/blog/207449

責任編輯:林師授 來源: oschina
相關推薦

2011-09-09 09:50:40

Oracle

2010-12-09 13:15:31

數據中心虛擬化整合

2024-05-28 07:01:29

2009-09-14 15:04:44

2011-06-21 16:26:19

SEO內部優化

2011-08-15 10:27:48

2013-08-02 11:23:45

2010-08-17 13:23:49

2009-06-29 15:39:53

Servlet和JSPServlet引擎

2012-07-13 14:25:59

2017-01-20 09:43:12

日志告警挖掘

2015-09-16 10:13:16

游戲性能

2009-11-02 11:11:07

VB.NET OOP設

2012-06-18 10:59:12

WEB開發項目

2015-09-23 14:01:51

2009-08-03 10:13:13

開發框架

2009-08-07 17:38:08

C#無詞尾符號

2009-10-29 09:40:35

VB.NET Text

2009-07-11 10:30:17

綜合布線工作體會

2009-07-02 11:49:44

JSP學習步驟
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品一区国产 | 日本免费一区二区三区四区 | 激情五月婷婷综合 | av影音在线| 国产精品视频一二三 | 韩国av网站在线观看 | 精品乱码一区二区 | 免费黄色片在线观看 | 免费在线观看黄色av | 成人在线免费观看 | 午夜激情视频 | 免费黄色录像视频 | 亚洲天堂中文字幕 | 久久三区 | 日韩欧美国产一区二区三区 | 一区二区三区四区不卡视频 | 免费毛片网站 | 性视频网 | 国产一级一级 | 午夜精品久久久久99蜜 | 国产精品毛片一区二区在线看 | 欧洲视频一区二区 | 福利网址| 亚洲综合在线视频 | 91精品久久 | 欧美一卡二卡在线观看 | 夜夜骑综合| 91性高湖久久久久久久久_久久99 | 久久久久国产一区二区三区四区 | 日韩免费高清视频 | 99热这里都是精品 | 天天天操操操 | 欧美1区 | 中文字幕在线二区 | 亚洲精品一区二区三区蜜桃久 | 久久人人网 | 国产精品日韩欧美一区二区 | 午夜伦理影院 | 国产精品美女久久久久久久网站 | 极品国产视频 | 日本三级在线视频 |