JavaScript模板入門介紹
比如要在一個列表中利用ajax一個li的時候,我會直接把數(shù)據(jù)跟html標簽拼接成一句完整的html,然后到ul中。無論數(shù)據(jù)是從服務器端拿回的,或者是從用戶的input輸入中拿到的——無論哪種方法都是一樣。
這個拼接過程放在JavaScript文件中,顯得非常不優(yōu)雅。如果還把style也放在JavaScript中,那數(shù)據(jù)、結構還有樣式整個就是一鍋粥了,要維護這樣的代讓人想。最過分的就是把頁面上最終要生成的HTML都直接放在服務器端,ajax吐出數(shù)據(jù)就包含了<li>標簽,這樣的頁面幾乎不存在擴展性了,修改一個前臺樣式都要涉及后臺代碼的修改。
后來我們知道了不要在JavaScript中對DOM進行style定制,而是只需要在CSS文件中定義好對應的class,然后在JavaScript中使用這個class就好。
接下來我們要做的就是用JavaScript模板把HTML結構(在這個案例中,是<li>標簽)也從JavaScript中分離。
市面上的JavaScript模板很多了,以handlebars這個優(yōu)秀的模板為例吧:
我們在頁面的html中定義模板:
<script id="list-template" type="text/x-handlebars-template">
<li>{{title}}</li>
</script>
然后在我們的邏輯JavaScript代碼中可以把數(shù)據(jù)拼接到這一模版中:
var source = $("#list-template").html(); //模板源,一般放在html的script中,這里我們使用jQuery,也可以使用其它方法直接獲得內容字符串
var template = Handlerbars.compile(source); //編譯生成一個模板template
var context = {title:"This is a todo item"} //獲得數(shù)據(jù),數(shù)據(jù)一般從ajax或者input中取得
var html = template(context); //數(shù)據(jù)+模板=新的html
這就是基本的 用法了,更多邏輯可以參考官方文檔:http://handlebarsjs.com/
相關文章
js實現(xiàn)前端跨域postMessage的具體使用
這篇文章主要介紹了js實現(xiàn)前端跨域postMessage的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04uniapp實現(xiàn)微信小程序的電子簽名效果(附demo)
本文主要介紹了uniapp實現(xiàn)微信小程序的電子簽名效果,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05javascript html5搖一搖功能的實現(xiàn)
這篇文章主要為大家詳細介紹了javascript html5搖一搖功能的實現(xiàn)過程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-04-04