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

来源: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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...