這篇文章主要介紹了Node.js項(xiàng)目中調(diào)用JavaScript的EJS模板庫(kù)的方法,通過(guò)EJS模板引擎可以制作出維護(hù)性良好的HTML代碼結(jié)構(gòu),需要的朋友可以參考下
作為外部模塊,調(diào)用的方法和mysql模塊是相同的,不再贅述。
ejs的render函數(shù)有兩個(gè)參數(shù) 第一個(gè)是字符串,第二個(gè)是可選的對(duì)象,和其他javascript模版一樣需要渲染的數(shù)據(jù)也是包含在option對(duì)象中的
ejs.render(str,option);
// 渲染字符串 str 一般是通過(guò)nodejs文件系統(tǒng)的readfile方法讀取
ejs.render(str,{
data : user_data // 需要渲染的數(shù)據(jù)
});
當(dāng)str字符串中沒(méi)有包含 include 標(biāo)簽時(shí),渲染數(shù)據(jù)是沒(méi)有問(wèn)題的,反之,就會(huì)報(bào)錯(cuò)。前面已經(jīng)講過(guò)我的項(xiàng)目文件和nodejs的安裝文件不在同一個(gè)根目錄下。解決這個(gè)問(wèn)題需要配置option參數(shù)的filename屬性。
查看ejs源碼,會(huì)發(fā)現(xiàn),ejs在處理include包含文件的路徑時(shí)會(huì)用到一個(gè)resolveInclude函數(shù):
function resolveInclude(name, filename) {
var path = join(dirname(filename), name);
var ext = extname(name);
if (!ext) path += '.ejs';
return path;
}
filename正是dirname函數(shù)的參數(shù),作為nodejs核心模塊的path.dirname(),返回的path總是相對(duì)nodejs的安裝路徑,如果不指定filename值,就會(huì)找不到文件
在使用dirname時(shí)應(yīng)當(dāng)注意,函數(shù)處理傳入的路徑參數(shù)時(shí)會(huì)截取第一個(gè)
'/' 之前的部分作為路徑名例如:
path.dirname('/foo/bar/baz/asdf/quux')
// returns
'/foo/bar/baz/asdf'
要取得tpl目錄可以這樣寫:
path.dirname('/tpl/..') // return /tpl
完整的render函數(shù)可以這樣:
ejs.render(str,{
filename : path + '/tpl/..', //tpl文件中保存的是模版文件
data: user_data
});