深入理解移動開發的模板復用機制

来源:http://www.cnblogs.com/andbut/archive/2016/04/13/5385601.html
-Advertisement-
Play Games

模板復用機制是android,ios等移動開發技術中類似listview,gridview,slideview等等之類組件常用的技術,deviceone的模板復用完全是和他們一致,deviceone有很多組件基本上涉及到多數據和模板的都會用到復用機制,有必要專門介紹一下。以下都是以listview為 ...


模板復用機制是android,ios等移動開發技術中類似listview,gridview,slideview等等之類組件常用的技術,deviceone的模板復用完全是和他們一致,deviceone有很多組件基本上涉及到多數據和模板的都會用到復用機制,有必要專門介紹一下。
以下都是以listview為例,但是其實整個機制適合所有deviceone類似的組件。

通過do_ScrollView展示多個View

我們先假定沒有do_ListView組件,但是我們需要展示10個View,這10個View樣式基本上是一樣的,10個View加起來高度超過了屏幕,我們這個時候需要用到do_ScrollView組件,參考下圖:

do_ScrollView的高度和屏幕高度一樣,10個View組成的do_ALayout/do_LinearLayout比Scrollview高不少,作為do_ScorllView的子View,這樣在運行時上下滑動。

這種情況使用do_SrcollView是很好的方式。但是我們假定如果需要顯示100條數據,或者1000條數據,還能用Scrollview嗎?顯然是不行的,每一個View都會占用一部分記憶體,10個View的記憶體App輕易處理,但是100個1000個View在記憶體里App會馬上崩潰。

通過do_ListView展示多個View

這個時候就要用到復用機制了,我們以do_ListView來說明。我們假定有100條數據,假定屏幕的大小正好是6個小View的高度和。那麼我們就用8個View來顯示這100條數據,而不是用100個View來顯示。看下圖:

我們可以看到初始狀態View1和View8看不到,我們只能看到View2—>View7,這6個View分別對應數據Data1—>Data6.

如果我們手勢下滑,View8就會上滑動,但是同時會把View1移動到最下麵,如下圖:

我們可以看到這個時候View2和View1看不到,我們只能看到View3—>View8,這6個View分別對應數據Data2—>Data7.

就這樣我們不管怎麼上下滑動,顯示100條數據只需要8個View,這8個View不斷的更新數據,不斷的復用來達到這個效果。

復用機制要註意的問題

1. 因為每一個View的樣式是通過數據來決定的,同時View又是復用的,對一個View的操作導致樣式變化需要更新到data,否則復用的View會樣式錯亂。

我們來看這個例子,這個模板view包含一個do_Label顯示對應數據里的id欄位,另外還有一個do_CheckBox組件,預設是沒有選中,目前顯示的是第3條到第8條數據,顯示後,用手勢點擊把第4條數據對應的view3里的checkbox勾選上。

當我們往下滑動,view不斷的被覆用,當滑動到第7條數據的時候,view3被第12條數據復用了,用戶就會發現第12條數據對應的checkbox被勾選了,這不是用戶期望的。

如何處理這個問題? 其實就是給對應的data每一項增加一個新的欄位,比如叫checked用來標示選中的狀態,如果我們點中了一項,就更新一下對應的data的checked屬性。

這樣,checkbox的選中狀態是由data里的checked屬性來控制,就不會出現這個問題了。
這個可以參考示例里的test1和test2

2. dataRefreshed事件

因為listview對應的每一行的view的ui都是復用的,所以對應的ui.js邏輯代碼也是復用的,只會執行一次,但是每一個view不斷的更新數據,我們有時候需要在更新數據後做某些操作,就可以使用dataRefreshed事件.參考示例代碼:

  1. root.setMapping({
  2. "index_label.text" : "name",
  3. "do_CheckBox_1.checked" : "checked"
  4. });
  5. root.on("dataRefreshed", function() {
  6. // 當數據更新到這個view之後才會觸發,這個時候根據checked值,修改背景色
  7. // 這個事件在listview上下滑動的時候會執行多次,所以儘量不要在這個函數裡加太多操作,否則會卡頓
  8. change_bgcolor();
  9. })
  10. function change_bgcolor() {
  11. if (check_label.checked)
  12. index_label.bgColor = "FF0000FF";
  13. else
  14. index_label.bgColor = "FF000000";
  15. }

我們可以看到這個模板並沒有bind那個label的背景顏色,但是需要根據checkbox的狀態變化而變化背景色,則需要訂閱dataRefreshed事件。
詳細的示例參考這裡

3. 多模板

我們上面看到的所有示例都是以listview的單模板為例,也就是每一行的模板對應的ui文件都是一樣的。
但是實際上deviceone的模板機制支持多模板,可以模板文件完全不一樣。設置的方式也很簡單,只需要給listview的templates設置多個模板ui文件即可,中間用逗號隔開。
綁定數據也類似,每一行對應的數據結構和模板一致就可以。
詳細的示例參考這裡


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 效果預覽:http://hovertree.com/texiao/css/22/代碼如下: 源碼下載:http://hovertree.com/h/bjaf/l243x19a.htm 轉自:http://hovertree.com/h/bjaf/2hhi6cjy.htm 更多特效:http://ww ...
  • ...
  • div內嵌套p,div等元素出現的問題 http://caiceclb.iteye.com/blog/428085 文章內有些問題,可能不適應今天了。 正在學習前端,小問題是不能忽視的。 解決方案1是有問題的,margin:-1px;並不能解決高度增大問題,chrome,FF,Opara測試了下都不 ...
  • 用語義化標簽去寫你的HTML,相容IE6,7,8 HTML5增加了更多語義化的標簽,如header,footer,nav……讓我們在頁面編寫的時候,不需要再用下麵這種方法去佈局了: ? <div class="header">這是頭部</div> <div class="content">這是中間內 ...
  • 隨著科技的不斷發展,需要改變營銷策略的一個企業就變得非常重要。你不能指望用你的營銷工具來留住你的客戶。智能手機和平板電腦已經改變了消費者的行為方式。現在,人們甚至不想去他們的電腦或筆記本電腦,以檢查產品或服務,他們的願望。用智能手機在他們的手中,他們擁有的所有信息,他們需要在他們的指尖。因此,它已成 ...
  • 我們在很多網站看到,當我們滾動網頁時,網頁內的廣告或某個小區域並不會消失,而是浮動在屏幕的某個地方,特別是一些局域廣告。那麼這是怎麼實現的呢?本文將引用烏徒幫的跟隨屏幕滾動代碼,對此效果做詳解。 一、原始代碼 下麵是烏徒幫的跟隨屏幕滾動代碼,它的作用域為烏徒幫網頁兩側的邊欄,以及雙擊屏幕後的右側隱藏 ...
  • 一: 右側固定寬度 左側自適應 第一種方法:左側用margin-right,右側float:right 就可以實現。 HTML代碼可以如下寫: <div class="box-left"> <a href="" target="_blank">我是龍恩</a> </div> <div class=" ...
  • 在B/S結構客戶端越來越“胖”的今天,作為一名全端程式員,您很可能會在前端操作html字元串,註意,是操作html字元串,不是操作當前頁面的html。 舉個例子,百度推出的線上HTML富文本編輯器Ueditor,可以線上製作富文本文檔,功能堪比精簡版的Microsoft Word。雖然Ueditor ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...