0

0

node.js中EJS 模板的使用教程

零下一度

零下一度

发布时间:2017-05-09 10:08:52

|

1319人浏览过

|

来源于php中文网

原创

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

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

npm install ejs

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(),第一个参数是 模板 的字符串,模板如下。

<% if (names.length) { %> 
 
    <% names.forEach(function(name){ %>
  • '><%= name %>
  • <% }) %>
<% } %>

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);

相关选项如下:

  1. cache Compiled functions are cached, requires filename

  2. filename 缓存的键名称

  3. scope ASP0执行的作用域

  4. debug Output generated function body

  5. compileDebug When false no debug instrumentation is compiled

  6. client ASP1s standalone compiled function

inculde 指令

而且,如果要如

    <% users.forEach(function(user){ %> <% include user/show %> <% }) %>

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

模板:

Users

<% function user(user) { %>
  • <%= user.name %> is a <%= user.age %> year old <%= user.species %>.
  • <% } %>
      <% users.map(user) %>

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

    UQ云商B2B2C系统
    UQ云商B2B2C系统

    UQCMS云商是一款B2B2C电子商务软件 ,非常适合初创的创业者,个人及中小型企业。程序采用PHP+MYSQL,模板采用smarty模板,二次开发,简单方便,无需学习其他框架就可以自行模板设计。永久免费使用,操作简单,安全稳定。支持PC+WAP+微信三种浏览方式,支持微信公众号。

    下载
      <% users.forEach(function(user){ %> <% include user/show %> <% }) %>

    自定义 CLOSE TOKEN

    如果打算使用

    {{= title }}

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

    ASP2也可以哦。

     ejs.filters.last = function(obj) { 
     return obj[obj.length - 1]; 
    };

    调用

    <%=: users | last %>

    EJS 也支持浏览器环境。

     
      
       
       
       
      
      
      
    

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

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

    简单实用的jsASP4

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

    “”内是 js 逻辑代码,“”内是直接输出的变量,类似 php 的 ASP5 的作用。“p”是调用下面 build 方法时的 k-v 对象参数,也可以在调用 “ASP6 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 使用,最好将字符串拼接方法改为 ASP7.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.124124.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');   
        }); 
      } 
    }

    【相关推荐】

    1. ASP8

    2.ASP9

    3. JSP0

    相关专题

    更多
    PS使用蒙版相关教程
    PS使用蒙版相关教程

    本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

    23

    2026.01.19

    java用途介绍
    java用途介绍

    本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

    11

    2026.01.19

    java输出数组相关教程
    java输出数组相关教程

    本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

    3

    2026.01.19

    java接口相关教程
    java接口相关教程

    本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

    2

    2026.01.19

    xml格式相关教程
    xml格式相关教程

    本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

    4

    2026.01.19

    PHP WebSocket 实时通信开发
    PHP WebSocket 实时通信开发

    本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

    13

    2026.01.19

    微信聊天记录删除恢复导出教程汇总
    微信聊天记录删除恢复导出教程汇总

    本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

    93

    2026.01.18

    高德地图升级方法汇总
    高德地图升级方法汇总

    本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

    112

    2026.01.16

    全民K歌得高分教程大全
    全民K歌得高分教程大全

    本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

    155

    2026.01.16

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Node.js 教程
    Node.js 教程

    共57课时 | 8.9万人学习

    【web前端】Node.js快速入门
    【web前端】Node.js快速入门

    共16课时 | 2万人学习

    Node.js-前端工程化必学
    Node.js-前端工程化必学

    共19课时 | 3万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号