`
markone
  • 浏览: 6405 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

在前端开发中应用javascript模板引擎 - 事半功倍!

阅读更多
我们在使用JavaScript进行前端开发的时候,做的最多的事情,除了dealing with dom以外,就是围绕json数据的操作了。而数据操作最麻烦的就是用json生成dom对象了,通常我们会写一堆for, switch, if之类的代码来支持data向view的转化, 这样的代码一般会像:

var data = [{name: ‘Claire’, sex: ‘female’, age: 18, flag: true},

{name: ‘Mark’, sex: ‘male’, age: 25, flag: true},

{name: ‘Dennis’, sex: ‘male’, age: 32, flag: false},

{name: ‘Tracy’, sex: ‘female’, age: 23, flag: true},

{name: ‘Wane’, sex: ‘male’, age: 18, flag: true}],    

html = [‘<ul>’], 
    item; 
 
for (var i = 0, l = data.length; i < l; i++) { 
 item = data[i]; 
 if (item.flag) {

html.push(‘<li>’);

switch (item.sex) {

case ‘male’:

html.push(‘<span style=”color: blue”>’);

break;

case ‘female’:

default:

html.push(‘<span style=”color: red”>’);

break;

}

html.push(‘name: ‘ + item.name + ‘,  age: ‘ + item.age);

html.push(‘</span></li>’);

}

} 
html = html.push(‘</ul>’).join(‘’); 


最终生成的html如下:
<ul> 
 <li><span color=”red”>name: Claire,  age: 18</span></li> 
 <li><span color=”blue”>name: Mark,  age: 25</span></li> 
 <li><span color=”red”>name: Tracy,  age: 23</span></li> 
 <li><span color=”blue”>name: Wane,  age: 18</span></li> 
</ul> 

这样做,随着数据结构越来越复杂很快你就会发现代码越来越臃肿,而且html完全嵌入代码,几乎不可维护。实际上,将展现逻辑同数据分开在服务器端脚本中是很容易的事情,因为服务器端脚本一般都支持模板技术。相信大家对<% %>之类的标记已经熟悉到烦了。模板语言的好处是能用一种灵活、易扩展的方式来将展现标记(如 html)、数据(如json)和控制代码(如javascript)解耦。
现在也有不少浏览器端用javascript实现的模板引擎,如extjs的xtemplate,,jTemplate,TrimPath等。实现的思路都一样:将一段定义好的模板代码(像 <% do something %>之类的)compile为js代码;然后将json data作为这段js代码的输入,最终产生一段需要的文本(如html)。

我在项目里使用过不少js模板引擎,下面列一下他们的优缺点,其中会用到两个性能指标,compile speed(从一段模板代码生成js代码的速度) 和 apply speed(应用json data产生最终输出文本的速度)



Extjs:

Xtemplate是extjs的基础组件,extjs中不少控件都是靠xtemplate来生成html。当然,就为了用个模板引擎就把1m多的extjs include进来显然不是什么明智之举。所以我用的时候将其剥离了出来,大概也就10k吧。这个引擎的使用感觉是速度快,小,语法简单,没什么学习曲线。但是在模板语句中很难调用外部代码,难以扩展,而且,每compile一次都得n次eval,一不小心就会造成内存泄露。

Compile speed: 中等    apply speed:快



jTemplate:

这是一个开源的小程序,目前版本1.1(好像1.1很久了),32k。定义了一套完整的模板语法,然而这也正是问题所在,要想用这个程序还必须学一套没什么大用的语法。分析了它的代码后我发现它并没有什么compile过程,大部分工作都放到apply data阶段了,导致它转换数据的速度很慢。

Compile speed: 快      apply speed: 慢



TrimPath template:

Trimpath本来是一个js框架,也和extjs一样基于一个模板引擎,只不过作者直接将模板引擎拿出来作为了一个可以单独调用的组件,20k左右。有一套简单的语法,功能一般,性能也不突出。

Compile speed: 慢     apply speed: 中等



把这几个引擎都用了一遍以后,感觉都不太顺手,不过也总结出了一个优秀的模板引擎应该具有的特点:

1.     使用javascript的流程控制语句,并做适当增强

2.     在模板代码中可自由引用任何global对象,模板代码中的scope(即this对象)可任意扩展

3.     性能优良(compile speed和apply speed)



于是,按照这三条标准,我自己写了一个很轻量的模板引擎,使用这个引擎,上面那段替换代码就可以换成:


var html = (new Sweet('<ul><[foreach($data as people) { if (people.flag) {]>'
+ '<li>'
+ '<span style=”color: <[=people.sex == "female" ? "red" : "blue"]>”>'
+ 'name: <[=name]>, age: <[=age]>'
+ '</li>'
+ '<[}}]></ul>')).applyData(data);


不废话了 ,更多信息请查看:

http://code.google.com/p/sweet-template/

或者:

http://plugins.jquery.com/project/sweet-template
分享到:
评论

相关推荐

    JavaScript模板引擎 - Elapse

    此外,Elapse可能还支持与现有JavaScript库和框架的整合,如React、Vue或Angular,使得模板引擎能在单页应用中无缝工作。 Elapse的压缩包文件可能包含了以下内容: 1. `elapse.js`:主要的JavaScript库文件,包含了...

    JavaScript前端开发案例教程-源代码.rar

    这个名为"JavaScript前端开发案例教程-源代码.rar"的压缩包文件提供了一系列实践案例,帮助开发者深入理解和掌握JavaScript在网页开发中的应用。 首先,JavaScript是一种解释型、弱类型、基于原型的脚本语言,它的...

    前端开发简历模板-前端开发工程师-1年.doc

    本资源是前端开发工程师的简历模板,具有1年的工作经验,擅长前端开发技术,熟悉HTML5、CSS3、JavaScript、Vue框架、Bootstrap框架、jQuery函数库、MySQL数据库等技术。同时,拥有微信小程序开发经验,熟悉原生小...

    前端开发简历模板-web前端-三年-北京.docx

    * 了解 NodeJS、MongoDB 后端应用开发 7. 前端布局和响应式设计 * 熟悉移动端 App 百分百布局、rem 布局和响应式布局 * 能解决不同设备之间的兼容问题和适配问题 8. 项目经验 * 房天下房产项目:使用 React+...

    JavaScript前端开发程序设计教程(微课版)-PPT课件.zip

    JavaScript作为Web开发中的重要语言,是前端开发的核心技术之一,尤其在构建动态、交互式的网页应用中发挥着关键作用。本教程《JavaScript前端开发程序设计教程(微课版)》旨在帮助初学者和有一定基础的开发者深入...

    前端前端静态模板-动画网站-学生作业毕设实训素材.zip

    在"毕业设计"中,选择前端模板作为项目可以锻炼学生的实际开发能力,同时也能提高项目的完成度和专业性。通过分析和修改现有的源码,学生可以学习到前端开发的最佳实践,了解项目结构和文件组织方式。 "论文"部分,...

    PHOTOS手机APPS应用官网模板下载-前端 wow 动画 应用开发 产品 大气 bootstrap

    描述中提到的“绿色 app 手机 应用 单页 官网 开发 前端”表明模板采用的是单页面应用(SPA)设计,这种设计方式使整个网站在一个HTML页面内完成加载和导航,提高了用户体验。同时,模板采用了绿色作为主色调,可能...

    前端前端静态模板-宠物网站-学生作业毕设实训素材.zip

    宠物网站前端静态模板是针对学生进行前端开发学习和毕业设计实践的理想素材,它提供了一个完整的前端应用源码,可以帮助学生理解和掌握前端开发的基本流程和技术。这个模板可能包含了HTML、CSS、JavaScript等核心...

    前端前端静态模板-大学-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页和应用程序的基础。这个名为“前端前端静态模板-大学-学生作业毕设实训素材.zip”的压缩包提供了一个完整的前端应用源码开发Demo,非常适合大学生进行毕业设计学习。它涵盖了从...

    JavaScript前端开发案例教程-PPT(2).rar

    《JavaScript前端开发案例教程》是面向计算机相关专业的一门Web前端基础课程,涉及JavaScript语言基础、数组、函数、对象、BOM、DOM、事件、正则表达式、Ajax、jQuery等内容。

    做着玩的NodeJS服务器端模板引擎--Elf

    在IT行业中,Node.js作为一款强大的JavaScript运行环境,因其异步非阻塞I/O模型和高效的性能,深受开发者喜爱,尤其在构建服务器端应用时。而模板引擎是前端与后端交互的重要桥梁,它能够帮助我们快速地生成动态HTML...

    前端静态模板-手机商城零食-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页应用的一种高效方式,尤其对于快速原型设计、学生作业、毕业设计等项目,它们提供了便捷的起点。本资源"前端静态模板-手机商城零食-学生作业毕设实训素材.zip"就是这样一个适用于...

    前端前端静态模板-滚动屏-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页应用的基础,它们提供了预设计的布局和样式,使得开发者可以快速构建出美观的用户界面。这个名为"前端前端静态模板-滚动屏-学生作业毕设实训素材.zip"的压缩包文件,显然是为前端...

    前端前端静态模板-404搜索-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页应用的一种常见方式,尤其适用于个人作业、学生毕设以及快速原型设计。"前端前端静态模板-404搜索-学生作业毕设实训素材.zip"这个压缩包包含了用于学习和实践的完整前端应用源码...

    前端前端静态模板-个人工作室-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页或应用程序的常用方式,尤其对于个人工作室或学生作业、毕设项目来说,它们提供了快速开发和实践的基础。"前端前端静态模板-个人工作室-学生作业毕设实训素材.zip"这个压缩包包含...

    前端开发手册大全11个(CSS-javascript-jquery-w3c-XHTML-XML).zip

    前端开发手册大全11个(CSS-javascript-jquery-w3c-XHTML-XML).zip CSS参考手册-Web前端开发参考手册系列 Web前端开发规范手册必备 CSS参考手册 javascript参考手册 CSS参考手册 jquery参考手册 XML参考手册 XHTML...

    templatejs的webpakc编译loader一款javascript模板引擎

    **模板引擎在Web开发中的重要性** 在现代Web开发中,模板引擎扮演着至关重要的角色。它们允许开发者将数据和视图逻辑分离,使代码更易于维护和复用。Template.js是一个JavaScript模板引擎,它专注于提供高效且灵活...

    前端前端静态模板-个人展示-学生作业毕设实训素材.zip

    在IT行业中,前端开发是构建Web应用程序的重要组成部分,它涉及到用户与网站互动的界面设计和实现。本资源“前端前端静态模板-个人展示-学生作业毕设实训素材.zip”提供了一个完整的前端应用源码,特别适合学生进行...

    前端静态模板-黑图文说明-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是构建网页应用的基础。"前端静态模板-黑图文说明-学生作业毕设实训素材.zip" 文件提供了一个完整的前端应用源码示例,特别适合那些正在进行毕业设计或者论文编写的学生作为学习资源。这个...

    前端静态模板-婚礼主题模板-学生作业毕设实训素材.zip

    在前端开发领域,静态模板是一种常见的工具,尤其适用于快速构建网站原型或特定主题的应用。"前端静态模板-婚礼主题模板-学生作业毕设实训素材.zip" 提供了一个完整的前端应用源码,对于学习和实践前端技术,特别是...

Global site tag (gtag.js) - Google Analytics