JavaScript模板入門介紹

來源:互聯網
上載者:User

比如要在一個列表中利用ajax插入一個li的時候,我會直接把資料跟html標籤拼接成一句完整的html,然後插入到ul中。無論資料是從伺服器端拿回的,或者是從使用者的input輸入中拿到的——無論哪種方法都是一樣。
這個拼接過程放在JavaScript檔案中,顯得非常不優雅。如果還把style也放在JavaScript中,那資料、結構還有樣式整個就是一鍋粥了,要維護這樣的代碼會讓人想自殺。最過分的就是把頁面上最終要產生的HTML都直接放在伺服器端,ajax吐出資料就包含了<li>標籤,這樣的頁面幾乎不存在擴充性了,修改一個前台樣式都要涉及後台代碼的修改。

後來我們知道了不要在JavaScript中對DOM進行style定製,而是只需要在CSS檔案中定義好對應的class,然後在JavaScript中使用這個class就好。

接下來我們要做的就是用JavaScript模板把HTML結構(在這個案例中,是<li>標籤)也從JavaScript中分離。

市面上的JavaScript模板很多了,以handlebars這個優秀的模板為例吧:

我們在頁面的html中定義模板: 複製代碼 代碼如下:<script id="list-template" type="text/x-handlebars-template">
<li>{{title}}</li>
</script>

然後在我們的邏輯JavaScript代碼中可以把資料拼接到這一模版中: 複製代碼 代碼如下:var source = $("#list-template").html(); //模板源,一般放在html的script中,這裡我們使用jQuery,也可以使用其它方法直接獲得內容字串
var template = Handlerbars.compile(source); //編譯產生一個模板template
var context = {title:"This is a todo item"} //獲得資料,資料一般從ajax或者input中取得
var html = template(context); //資料+模板=新的html

這就是基本的 用法了,更多邏輯可以參考官方文檔:http://handlebarsjs.com/

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.