有關JavaScript模板入門參考

學識都 人氣:3W

比如要在一個列表中利用ajax插入一個li的時候,我會直接把數據跟html標籤拼接成一句完整的html,然後插入到ul中。無論數據是從服務器端拿回的,或者是從用戶的input輸入中拿到的——無論哪種方法都是一樣。

有關JavaScript模板入門參考

這個拼接過程放在JavaScript文件中,顯得非常不優雅。如果還把style也放在JavaScript中,那數據、結構還有樣式整個就是一鍋粥了,要維護這樣的代碼會讓人想自殺。最過分的就是把頁面上最終要生成的HTML都直接放在服務器端,ajax吐出數據就包含了

標籤,這樣的頁面幾乎不存在擴展性了,修改一個前臺樣式都要涉及後臺代碼的修改。

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

接下來我們要做的就是用JavaScript模板把HTML結構(在這個案例中,是

標籤)也從JavaScript中分離。

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

我們在頁面的html中定義模板:

複製代碼 代碼如下:

{{title}}

然後在我們的邏輯JavaScript代碼中可以把數據拼接到這一模版中:

複製代碼 代碼如下:

var source = $("#list-template")(); //模板源,一般放在html的script中,這裏我們使用jQuery,也可以使用其它方法直接獲得內容字符串

var template = ile(source); //編譯生成一個模板template

var context = {title:"This is a todo item"} //獲得數據,數據一般從ajax或者input中取得

var html = template(context); //數據+模板=新的html

TAGS:模板