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