本篇文章主要介绍了EJS 模板快速入门学习,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

Node 开源模板的选择很多,但推荐像我这样的老人去用 EJS,有 Classic ASP/PHP/JSP 的经验用起 EJS 来的确可以很自然,也就是说,你能够在 块中安排 JavaScript 代码,利用最传统的方式 (另外

JS 调用

JS 调用的方法主要有两个:ejs.compile(str, options);

// => Function

ejs.render(str, options);

// => str

实际上 EJS 可以游离于 Express 独立使用的,例如:var ejs = require(''), str = require('fs').readFileSync(dirname + '/list.ejs', 'utf8');

var ret = ejs.render(str, {

names: ['foo', 'bar', 'baz']

});

console.log(ret);

见 ejs.render(),第一个参数是 模板 的字符串,模板如下。

  • '>

names 成了本地变量。

选项参数

第二个参数是数据,一般是一个对象。而这个对象又可以视作为选项,也就是说数据和选择都在同一个对象身上。

如果不想每次都都磁盘,可需要缓存模板,设定 options.filename 即可。例如:var ejs = require('../')

, fs = require('fs')

, path = dirname + '/functions.ejs'

, str = fs.readFileSync(path, 'utf8');

var users = [];

users.push({ name: 'Tobi', age: 2, species: 'ferret' })

users.push({ name: 'Loki', age: 2, species: 'ferret' })

users.push({ name: 'Jane', age: 6, species: 'ferret' })

var ret = ejs.render(str, {

users: users,

filename: path

});

console.log(ret);

相关选项如下:cache Compiled functions are cached, requires filename

filename 缓存的键名称

scope 函数执行的作用域

debug Output generated function body

compileDebug When false no debug instrumentation is compiled

client Returns standalone compiled function

inculde 指令

而且,如果要如

一般插入公共模板,也就是引入文件,必须要设置 filename 选项才能启动 include 特性,不然 include 无从知晓所在目录。

模板:

Users

is a year old .

EJS 支持编译模板。经过模板编译后就没有 IO 操作,会非常快,而且可以公用本地变量。下面例子 user/show 忽略 ejs 扩展名:

自定义 CLOSE TOKEN

如果打算使用

{{= title }}

般非 标识,也可以自定义的。var ejs = require('ejs');

ejs.open = '{{';

ejs.close = '}}';

格式化输出也可以哦。ejs.filters.last = function(obj) {

return obj[obj.length - 1];

};

调用

EJS 也支持浏览器环境。

onload = function(){

var users = document.getElementById('users').innerHTML;

var names = ['loki', 'tobi', 'jane'];

var html = ejs.render(users, { names: names });

document.body.innerHTML = html;

}

不知道 EJS 能否输出多层 JSON 对象呢?

对了,有网友爆料说,jQ 大神 John 若干年前写过 20 行的模板,汗颜,与 EJS 相似但短小精悍!

简单实用的js模板引擎

不足 50 行的 js 模板引擎,支持各种 js 语法:

for(var i = 0, l = p.list.length; i < l; i++){

var stu = p.list[i];

=%>

class="first">

}

=%>

“”内是 js 逻辑代码,“”内是直接输出的变量,类似 php 的 echo 的作用。“p”是调用下面 build 方法时的 k-v 对象参数,也可以在调用 “new JTemp” 时设置成别的参数名

调用:$(function(){

var temp = new JTemp('test_list'),

html = temp.build(

{list:[

{name:'张三', age:13, address:'北京'},

{name:'李四', age:17, address:'天津'},

{name:'王五', age:13}

]});

$('table').html(html);

});

上面的 temp 生成以后,可以多次调用 build 方法,生成 html。以下是模板引擎的代码:var JTemp = function(){

function Temp(htmlId, p){

p = p || {};//配置信息,大部分情况可以缺省

this.htmlId = htmlId;

this.fun;

this.oName = p.oName || 'p';

this.TEMP_S = p.tempS || '

this.TEMP_E = p.tempE || '=%>';

this.getFun();

}

Temp.prototype = {

getFun : function(){

var _ = this,

str = $('#' + _.htmlId).html();

if(!str) _.err('error: no temp!!');

var str_ = 'var ' + _.oName + '=this,f=\'\';',

s = str.indexOf(_.TEMP_S),

e = -1,

p,

sl = _.TEMP_S.length,

el = _.TEMP_E.length;

for(;s >= 0;){

e = str.indexOf(_.TEMP_E);

if(e < s) alert(':( ERROR!!');

str_ += 'f+=\'' + str.substring(0, s) + '\';';

p = _.trim(str.substring(s+sl, e));

if(p.indexOf('=') !== 0){//js语句

str_ += p;

}else{//普通语句

str_ += 'f+=' + p.substring(1) + ';';

}

str = str.substring(e + el);

s = str.indexOf(_.TEMP_S);

}

str_ += 'f+=\'' + str + '\';';

str_ = str_.replace(/\n/g, '');//处理换行

var fs = str_ + 'return f;';

this.fun = Function(fs);

},

build : function(p){

return this.fun.call(p);

},

err : function(s){

alert(s);

},

trim : function(s){

return s.trim?s.trim():s.replace(/(^\s*)|(\s*$)/g,"");

}

};

return Temp;

}();

核心是将模板代码转变成了一个拼接字符串的 function,每次拿数据 call 这个 function。

因为主要是给手机(webkit)用的,所以没有考虑字符串拼接的效率问题,如果需要给 IE 使用,最好将字符串拼接方法改为 Array.push() 的形式。

附:connect + ejs 的一个例子。var Step = require('../../libs/step'),

_c = require('./utils/utils'),

fs = require('fs'),

ejs = require('ejs'),

connect = require('connect');

exports.loadSite = function(request, response){

var siteRoot = 'C:/代码存档/sites/a.com.cn';

// _c.log(request.headers.host);

var url = request.url;

// 如果有 html 的则是动态网页,否则为静态内容

if(url == '/' || ~url.indexOf('/?') || url.indexOf('.asp') != -1 || url[url.length - 1] == '/'){

var tplPath;

if(url == '/' || ~url.indexOf('/?') || url[url.length - 1] == '/'){

// 默认 index.html

tplPath = siteRoot + request.url + 'default.asp';

}else{

tplPath = siteRoot + request.url.replace(/\?.*$/i,''); // 只需要文件名

}

// 从文件加载模板

Step(function(){

_c.log('加载模板:' + tplPath);

fs.exists(tplPath, this);

}, function(path_exists){

if(path_exists === true)fs.readFile(tplPath, "utf8", this);

else if(path_exists === false) response.end404(request.url);

else response.end500('文件系统异常', '');

},function(err, tpl){

var bigfootUrl, cssUrl, projectState = 0; // 0 = localhot/ 1 = Test Server / 2 = Deployed

switch(projectState){

case 0:

bigfootUrl = "http://127.0.0.1/bigfoot/";

cssUrl = "http://127.0.0.1/lessService/?isdebug=true";

break;

case 1:

bigfootUrl = "http://112.124.13.85:8080/static/";

cssUrl = "/asset/style/";

break;

case 2:

bigfootUrl = "http://localhost:8080/bigfoot/";

break;

}

var sitePath = request.getLevelByUrl(require(siteRoot + '/public/struct')),

first = sitePath[0];

var htmlResult = ejs.render(tpl, {

filename : tplPath,

bigfootUrl: bigfootUrl,

cssUrl : cssUrl,

projectState: projectState,

query_request: request.toJSON(),

request: request,

config: require(siteRoot + '/public/config'),

struct: require(siteRoot + '/public/struct'),

sitePath : sitePath,

firstLevel : first

});

// _c.log(first.children.length)

response.end200(htmlResult);

});

}else{

connect.static(siteRoot)(request, response, function(){

// if not found...

response.writeHead(404, {'Content-Type': 'text/html'});

response.end('404');

});

}

}

【相关推荐】

node.js php模板,node.js中EJS 模板的使用教程相关推荐

  1. express中ejs模板引擎的使用,consolidate模块的使用

    在express动态页面的渲染,用的比较多的模板引擎就是 ejs 还有一种是jade 个人觉得吧 jade是靠缩进来实现 代码结构的话 像我这种比较喜欢看 htm标签的人来说 太难受了 如果是使用ex ...

  2. jade模板引擎修改为ejs模板引擎

    如果我们使用jade模板引擎,里面的页面应该是这样的: 后缀名都是jade 如果想使用ejs 模板引擎要怎么做呢? (1)安装 ejs npm install ejs --save (2)在项目的ap ...

  3. C语言中比较大小的函数模板,C语言中实现模板函数小结 : 不敢流泪

    --by boluor 2009/5/20 如果要写个函数支持多种数据类型,首先想到的就是C++的模板了,但是有时候只能用C语言,比如在linux内核开发中,为了减少代码量,或者是某面试官的要求- 考 ...

  4. c++模板(函数模板,类中函数模板,类模板)

    作用: 减少程序中的冗余信息.如:多个函数或类的除了参数类型外,其余都完全相同时,可以使用模板来减少重复信息(参考函数重载时,输入参数数量也相同的情况) 1.函数模板 即建立一个通用函数,只不过该函数 ...

  5. Node.js | 一文带你了解 EJS 模板引擎

  6. java按模板生成pdf_java中根据模板生成pdf文件

    简介 本文使用java引入apache提供的pdf操作工具生成pdf文件,主要是根据需求开发了一个util类,记录一下学习和开发过程. 业务需求 因为业务需要,对于不同的用户要生成一个不同的pdf文件 ...

  7. flask中jinjia2模板引擎详解3

    接上文 模板继承 Jinji2中的模板继承是jinjia2比较强大的功能之一. 模板继承可以定义一个父级公共的模板,把同一类的模板框架定义出来共享. 这样做一方面可以提取共享代码,减少代码冗余和重复的 ...

  8. django 引用css失效_如何使用Python中Django模板?

    译者:穆胜亮 https://www.mattlayman.com/understand-django/templates-user-interfaces/ 篇文章将学习如何使用Django模板.模板 ...

  9. 初中计算机课程教案模板,初中体育课电子表格教案模板(共12篇)

    第1篇:电子表格教案 七年级EXCEL教案 Excel基本应用教案 一.内容分析 内容如下:初识电子表格.我的工作簿.工作表.Excel中公式的使用.Excel中函数的应用.数据的排序及筛选.Exce ...

最新文章

  1. 如何实现一个malloc
  2. RestTemplate--解决中文乱码
  3. chrome浏览器本地文件支持ajax请求的解决方法
  4. 【数据结构笔记】B树和B+树的实现,哈希查找,STL中的hash_map和unordered_map容器用法
  5. dmtracedump
  6. 均值滤波器类型_均值滤波适用于处理什么样的噪声
  7. 集线器、交换机和路由器之间的区别
  8. 快速查找对方IP地址经典技巧汇总
  9. Nodejs KOA服务搭建打包
  10. 聚类分析通俗易懂解释
  11. 从0开始,如何设计一个社交电商产品
  12. 转载 | 上汽集团云计算中心的开源之路
  13. ipad计算机功能,ipad功能如此强大,为何不能取代电脑,网友:已经可以取代电脑了...
  14. MFC 图标 icon 如何制作?
  15. win10系统升级后mysql找不到服务及数据消失问题
  16. UI设计中标签设计总结
  17. 程序员在在哪个网站上找工作?
  18. 【学习编程】献给迷茫中的你,教你如何快速入门编程,如何从编程小百到 IT 巨佬?零基础自学请收下这份学习指南(经验分享)
  19. php artisan migrate,laravel php artisan migrate错误
  20. java遍历易百教程_Java LineNumberReader示例

热门文章

  1. R语言使用ggplot2包geom_jitter()函数绘制分组(strip plot,一维散点图)带状图(编写自定义函数添加均值、标准偏差)实战
  2. R语言使用str_replace函数和str_replace_all函数替换字符串中匹配到的模式:str_replace函数替换第一个匹配到的字符串、str_replace_all函数替换所有匹配到的
  3. pandas使用nlargest函数返回特定数据列中前N个最大值(搜寻最大的n个元素)、pandas使用nlargest函数返回特定数据列中前N个最大值所对应的数据行
  4. R语言生存分析COX回归分析实战:放疗是否会延长胰脏癌症患者的生存时间
  5. 机器学习调参与贝叶斯优化及其典型python实现hyperopt
  6. Rstudio查看关联的R
  7. trimmomatic对fastq质控
  8. 红黑树+java+删除_红黑树深入剖析及Java实现
  9. R语言ggplot2绘制平滑曲线的折线图简单小例子
  10. python3环境搭建(利用Anaconda+pycharm+pytorch)