中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

node.js中EJS模板快速入門(mén)教程

Node 開(kāi)源模板的選擇很多,但推薦像我這樣的老人去用 EJS,有 Classic ASP/PHP/JSP 的經(jīng)驗(yàn)用起 EJS 來(lái)的確可以很自然,也就是說(shuō),你能夠在 <%...%> 塊中安排 JavaScript 代碼,利用最傳統(tǒng)的方式 <%=輸出變量%>(另外 <%-輸出變量是不會(huì)對(duì) & 等符號(hào)進(jìn)行轉(zhuǎn)義的)。安裝 EJS 命令如下:

創(chuàng)新互聯(lián)公司專(zhuān)業(yè)為企業(yè)提供郁南網(wǎng)站建設(shè)、郁南做網(wǎng)站、郁南網(wǎng)站設(shè)計(jì)、郁南網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、郁南企業(yè)網(wǎng)站模板建站服務(wù),十多年郁南做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

npm install ejs

JS 調(diào)用

JS 調(diào)用的方法主要有兩個(gè):

ejs.compile(str, options); 
// => Function 
 
ejs.render(str, options); 
// => str 

實(shí)際上 EJS 可以游離于 Express 獨(dú)立使用的,例如:

var ejs = require(''), str = require('fs').readFileSync(__dirname + '/list.ejs', 'utf8'); 
 
var ret = ejs.render(str, { 
 names: ['foo', 'bar', 'baz'] 
}); 
 
console.log(ret); 

見(jiàn) ejs.render(),第一個(gè)參數(shù)是 模板 的字符串,模板如下。

<% if (names.length) { %> 
 <ul> 
  <% names.forEach(function(name){ %> 
   <li foo='<%= name + "'" %>'><%= name %></li> 
  <% }) %> 
 </ul> 
<% } %> 

names 成了本地變量。

選項(xiàng)參數(shù)

第二個(gè)參數(shù)是數(shù)據(jù),一般是一個(gè)對(duì)象。而這個(gè)對(duì)象又可以視作為選項(xiàng),也就是說(shuō)數(shù)據(jù)和選擇都在同一個(gè)對(duì)象身上。

如果不想每次都都磁盤(pán),可需要緩存模板,設(shè)定 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); 

相關(guān)選項(xiàng)如下:

  1. cache Compiled functions are cached, requires filename
  2. filename 緩存的鍵名稱(chēng)
  3. scope 函數(shù)執(zhí)行的作用域
  4. debug Output generated function body
  5. compileDebug When false no debug instrumentation is compiled
  6. client Returns standalone compiled function

inculde 指令

而且,如果要如

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

一般插入公共模板,也就是引入文件,必須要設(shè)置 filename 選項(xiàng)才能啟動(dòng) include 特性,不然 include 無(wú)從知曉所在目錄。

模板:

<h2>Users</h2> 
 <% function user(user) { %> 
 <li><strong><%= user.name %></strong> is a <%= user.age %> year old <%= user.species %>.</li> 
<% } %> 
 
<ul> 
 <% users.map(user) %> 
</ul> 

EJS 支持編譯模板。經(jīng)過(guò)模板編譯后就沒(méi)有 IO 操作,會(huì)非常快,而且可以公用本地變量。下面例子 user/show 忽略 ejs 擴(kuò)展名:

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

自定義 CLOSE TOKEN

如果打算使用 <h2>{{= title }}</h2> 般非 <%%>標(biāo)識(shí),也可以自定義的。

 var ejs = require('ejs'); 
ejs.open = '{{'; 
ejs.close = '}}'; 

格式化輸出也可以哦。

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

調(diào)用

<p><%=: users | last %></p> 

EJS 也支持瀏覽器環(huán)境。

<html> 
 <head> 
  <script src="../ejs.js"></script> 
  <script id="users" type="text/template"> 
   <% if (names.length) { %> 
    <ul> 
     <% names.forEach(function(name){ %> 
      <li><%= name %></li> 
     <% }) %> 
    </ul> 
   <% } %> 
  </script> 
  <script> 
   onload = function(){ 
    var users = document.getElementById('users').innerHTML; 
    var names = ['loki', 'tobi', 'jane']; 
    var html = ejs.render(users, { names: names }); 
    document.body.innerHTML = html; 
   } 
  </script> 
 </head> 
 <body> 
 </body> 
</html> 

不知道 EJS 能否輸出多層 JSON 對(duì)象呢?

對(duì)了,有網(wǎng)友爆料說(shuō),jQ 大神 John 若干年前寫(xiě)過(guò) 20 行的模板,汗顏,與 EJS 相似但短小精悍!

簡(jiǎn)單實(shí)用的js模板引擎

不足 50 行的 js 模板引擎,支持各種 js 語(yǔ)法:

<script id="test_list" type="text/html"> 
<%= 
  for(var i = 0, l = p.list.length; i < l; i++){ 
    var stu = p.list[i]; 
=%> 
  <tr> 
    <td<%=if(i==0){=%> class="first"<%=}=%>><%==stu.name=%></td> 
    <td><%==stu.age=%></td> 
    <td><%==(stu.address || '')=%></td> 
  <tr> 
  
<%= 
  } 
=%> 
</script> 

“<%= xxx =%>”內(nèi)是 js 邏輯代碼,“<%== xxx =%>”內(nèi)是直接輸出的變量,類(lèi)似 php 的 echo 的作用。“p”是調(diào)用下面 build 方法時(shí)的 k-v 對(duì)象參數(shù),也可以在調(diào)用 “new JTemp” 時(shí)設(shè)置成別的參數(shù)名

調(diào)用:

$(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 生成以后,可以多次調(diào)用 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語(yǔ)句 
          str_ += p; 
        }else{//普通語(yǔ)句 
          str_ += 'f+=' + p.substring(1) + ';'; 
        } 
        str = str.substring(e + el); 
        s = str.indexOf(_.TEMP_S); 
      } 
      str_ += 'f+=\'' + str + '\';'; 
      str_ = str_.replace(/\n/g, '');//處理?yè)Q行 
      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; 
}(); 

核心是將模板代碼轉(zhuǎn)變成了一個(gè)拼接字符串的 function,每次拿數(shù)據(jù) call 這個(gè) function。

因?yàn)橹饕墙o手機(jī)(webkit)用的,所以沒(méi)有考慮字符串拼接的效率問(wèn)題,如果需要給 IE 使用,最好將字符串拼接方法改為 Array.push() 的形式。

附:connect + ejs 的一個(gè)例子。

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 的則是動(dòng)態(tài)網(wǎng)頁(yè),否則為靜態(tài)內(nèi)容 
  if(url == '/' || ~url.indexOf('/?') || url.indexOf('.asp') != -1 || url[url.length - 1] == '/'){ 
    var tplPath; 
     
    if(url == '/' || ~url.indexOf('/?') || url[url.length - 1] == '/'){ 
      // 默認(rèn) 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('文件系統(tǒng)異常', ''); 
    },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');   
    }); 
  } 
} 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)頁(yè)名稱(chēng):node.js中EJS模板快速入門(mén)教程
文章源于:http://m.2m8n56k.cn/article42/jdshhc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈微信小程序網(wǎng)站建設(shè)全網(wǎng)營(yíng)銷(xiāo)推廣網(wǎng)站改版動(dòng)態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
主站蜘蛛池模板: 国产精品一区高清在线观看 | 午夜在线观看cao | 国产视频久久久久 | 老妇综合久久香蕉蜜桃 | 性刺激欧美三级在线现看中文 | 亚洲国产精品久久精品成人 | 欧美精品人爱c欧美精品 | 亚洲成a人在线观看 | 色www亚洲 | 亚洲国内| 国产一区二区三区视频在线观看 | 91福利国产在线观一区二区 | 日本精品一区二区三区在线 | 精品91一区二区三区 | 成人黄色免费网址 | 欧美成人资源 | 九九视频精品全部免费播放 | 99久久精品费精品国产一区二区 | 亚洲成人福利在线 | 亚洲视频免费在线观看 | 国产一区二区三区精品久久呦 | 在线观看亚洲免费 | 黄色a网站| 亚洲视频手机在线 | 国产在线观看精品一区二区三区91 | 日本特级黄毛片毛片视频 | 久久99亚洲精品一区二区 | 亚洲午夜久久久久国产 | 国产成人精品视频频 | 男的操美女 | 呦女精品| 精品综合久久久久久88小说 | 国产精品国产国产aⅴ | 久久久99精品免费观看 | 兔子先生节目在线观看免费 | 亚洲一区二区三区久久精品 | 一区二区三区精品视频 | 99国产在线播放 | 欧美亚洲国产成人不卡 | 国内国产真实露脸对白 | 亚洲成年|