Backbone 中的 View 用來反映你 app 中 Model 的模樣。它們會監聽事件並作出相應的反應。
接下來的教學我不會告訴你如何把 Model 和 Collection 綁定到 View 上,而是主要討論 View 是如何使用 javascript 模板庫的,尤其是 Underscore.js's _.template。
這裡我們使用 jQuery 來操作 DOM 元素,當然你也可以使用其他的函式庫,例如 MooTools 或 Sizzle,但是 Backbone 的官方文件推薦我們使用 jQuery。
接下來,我們以搜尋框為例來新建一個 View:
SearchView = Backbone.View.extend({ initialize: function(){ alert("Welcome to Backbone!"); } }); var search_view = new SearchView();
無論是 Model,View 或 Collection,當被實例化時,initialize() 方法都會被自動觸發。
el 屬性
el 屬性指的是已經在瀏覽器中建立好的 DOM 對象,每個 View 都有一個 el 屬性,如果它未被定義,Backbone 將會自行建立一個空的 div 元素作為 el 屬性。
下面讓我們來為 View 建立一個 el 屬性,並設為 #search_containe。
<div id="search_container"></div> <script type="text/javascript"> SearchView = Backbone.View.extend({ initialize: function(){ alert("Welcome to Backbone!"); } }); var search_view = new SearchView({ el: $("#search_container") }); </script>
此時,View 的 el 屬性指的是 id 為 search_container 的 div 元素。我們此時變綁定了這個 div 元素,那麼任何我們希望觸發的事件都必須在這個 div 元素中。
載入範本
Backbone 是強烈依賴 Underscore.js 的,所以我們可以使用 Underscore.js 中的小型模板。
現在,讓我們新增一個 render() 方法,並且在 initialize() 中呼叫它,這樣當 View 初始化時便會自動觸發 render() 方法。
這個 render() 方法將會透過 jQuery 把模板載入到 View 的 el 屬性中去。
<script type="text/template" id="search_template"> <label>Search</label> <input type="text" id="search_input" /> <input type="button" id="search_button" value="Search" /> </script> <div id="search_container"></div> <script type="text/javascript"> SearchView = Backbone.View.extend({ initialize: function(){ this.render(); }, render: function(){ // 通过 Underscore 编译生成模板 var template = _.template( $("#search_template").html(), {} ); //讲生成的模板加载到 el 属性中 this.$el.html( template ); } }); var search_view = new SearchView({ el: $("#search_container") }); </script>
新增監聽事件
我們使用 View 的 events 屬性來新增監聽事件,記住監聽事件只能加入 el 屬性的子元素上。現在,我們來為子元素 button 新增一個監聽事件。
<script type="text/template" id="search_template"> <label>Search</label> <input type="text" id="search_input" /> <input type="button" id="search_button" value="Search" /> </script> <div id="search_container"></div> <script type="text/javascript"> SearchView = Backbone.View.extend({ initialize: function(){ this.render(); }, render: function(){ var template = _.template( $("#search_template").html(), {} ); this.$el.html( template ); }, events: { "click input[type=button]": "doSearch" }, doSearch: function( event ){ // 当 button 被点击时触发 alert alert( "Search for " + $("#search_input").val() ); } }); var search_view = new SearchView({ el: $("#search_container") }); </script>
向模板傳遞參數
模板可以透過 的形式使用從 View 傳來的參數。
<script type="text/template" id="search_template"> <!-- 通过 <%= %> 形式使用传来的参数 --> <label><%= search_label %></label> <input type="text" id="search_input" /> <input type="button" id="search_button" value="Search" /> </script> <div id="search_container"></div> <script type="text/javascript"> SearchView = Backbone.View.extend({ initialize: function(){ this.render(); }, render: function(){ //定义需要传递的参数 var variables = { search_label: "My Search" }; // 通过 Underscore 生成模板,同时传递参数 var template = _.template( $("#search_template").html(), variables ); // Load the compiled HTML into the Backbone "el" this.$el.html( template ); }, events: { "click input[type=button]": "doSearch" }, doSearch: function( event ){ alert( "Search for " + $("#search_input").val() ); } }); var search_view = new SearchView({ el: $("#search_container") }); </script>
處理DOM事件
視圖很重要的一個功能是幫助我們自動綁定介面事件。回想一下我們以前是如何為介面標籤綁定事件的?可能就像這樣:
<p> <input type="button" value="Create" id="create" /> <input type="button" value="Read" id="read" /> <input type="button" value="Update" id="update" /> <input type="button" value="Delete" id="delete" /> </p> <script type="text/javascript"> function createData() { // todo } function readData() { // todo } function updateData() { // todo } function deleteData() { // todo } $('#create').on('click', createData); $('#read').on('click', readData); $('#update').on('click', updateData); $('#delete').on('click', deleteData); </script>
這是一個典型的透過jQuery綁定DOM事件的例子,如果你正在開發或曾經開發過一些複雜的應用,你可能嘗試過透過某種方式將這些程式碼更好的組織起來,以便使它們看起來結構更清晰,也更容易維護。
Backbone的視圖物件為我們提供了事件的自動綁定機制,用於更好地維護DOM和事件間的關係,來看看下面的範例:
<p id="view"> <input type="button" value="Create" id="create" /> <input type="button" value="Read" id="read" /> <input type="button" value="Update" id="update" /> <input type="button" value="Delete" id="delete" /> </p> <script type="text/javascript"> var MyView = Backbone.View.extend({ el : '#view', events : { 'click #create' : 'createData', 'click #read' : 'readData', 'click #update' : 'updateData', 'click #delete' : 'deleteData' }, createData : function() { // todo }, readData : function() { // todo }, updateData : function() { // todo }, deleteData : function() { // todo } }); var view = new MyView(); </script>
在這個範例中,我們將4個按鈕放在一個id為view的標籤中,並將這個標籤與視圖類別MyView進行了關聯。
在定義視圖類別時,我們聲明了一個events屬性,它表示視圖中的使用者事件列表,描述方式如下:
事件名称 选择器 : 事件处理函数
視圖物件會自動解析events清單中的描述,即使用jQuery或Zepto取得選擇器所描述的DOM對象,並將事件處理函數綁定至事件名稱。這些操作都會在視圖類別被實例化時自動完成,我們可以更關心視圖類別本身的結構,而不是刻意地去考慮如何綁定事件。
你可能在擔心另一個問題:如果視圖的DOM結構是動態產生的,Backbone是否提供了相應的方法用於動態綁定和解除事件?
其實你並不需要關心這個問題,因為events中的事件是透過delegate()方法綁定到視圖物件的el元素上,而並非是選擇器所描述的元素。因此視圖內的結構無論如何變化,events中的事件都是有效的。
(如果你對jQuery比較熟悉,可能了解它所提供的delegate()方法。該方法實際上將事件綁定在父層元素,然後在事件冒泡過程中,透過檢查目標子元素來觸發事件。)
視圖物件透過delegate()方法綁定事件,表示我們不需要關心視圖結構變化對事件產生的影響,同時也說明events中選擇器所對應的元素必須處於視圖的el元素之內,否則綁定的事件是無法生效的。
儘管如此,有些情況下可能我們仍然需要手動綁定和解除事件,視圖對象提供了delegateEvents()和undelegateEvents()方法用於動態綁定和解除events事件列表,你可以通過查看API文檔來了解它們。
渲染視圖與資料
視圖主要用於介面事件的綁定和資料渲染,然而視圖物件僅僅提供了一個和渲染相關的方法render(),並且它是一個沒有任何邏輯、也沒有任何地方引用到的空方法,我們需要重載它來實現自己的渲染邏輯。
視圖中可能包含許多介面邏輯,這裡建議所有的視圖子類別都重載render()方法,並將它作為最終渲染的入口方法。在團隊開發中,嚴格遵守規範編碼可以幫助別人更好地理解和維護你的程式碼。

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

WebStorm Mac版
好用的JavaScript開發工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境