Node.js项目中调用JavaScript的EJS模板库的方法
作者:bea
作为外部模块,调用的方法和mysql模块是相同的,不再赘述。 ejs的render函数有两个参数 第一个是字符串,第二个是可选的对象,和其他javascript模版一样需要渲染的数据也是包含在option对象中的 ejs.render(str,option); // 渲染字符串 str 一般是通过nodejs文件系统的readfile方法读取 ejs.render(str,{ data : user_data // 需要渲染的数据 }); 当str字符串中没有包含
作为外部模块,调用的方法和mysql模块是相同的,不再赘述。
ejs的render函数有两个参数 第一个是字符串,第二个是可选的对象,和其他javascript模版一样需要渲染的数据也是包含在option对象中的
ejs.render(str,option);
// 渲染字符串 str 一般是通过nodejs文件系统的readfile方法读取
ejs.render(str,{
data : user_data // 需要渲染的数据
});
当str字符串中没有包含 include 标签时,渲染数据是没有问题的,反之,就会报错。前面已经讲过我的项目文件和nodejs的安装文件不在同一个根目录下。解决这个问题需要配置option参数的filename属性。
查看ejs源码,会发现,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
});
有用 | 无用
ejs的render函数有两个参数 第一个是字符串,第二个是可选的对象,和其他javascript模版一样需要渲染的数据也是包含在option对象中的
ejs.render(str,option);
// 渲染字符串 str 一般是通过nodejs文件系统的readfile方法读取
ejs.render(str,{
data : user_data // 需要渲染的数据
});
当str字符串中没有包含 include 标签时,渲染数据是没有问题的,反之,就会报错。前面已经讲过我的项目文件和nodejs的安装文件不在同一个根目录下。解决这个问题需要配置option参数的filename属性。
查看ejs源码,会发现,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
});
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 基于javascript html5实现3D翻书特效
- php基于redis处理session的方法
- 使用javascript插入样式
- jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
- javascript实现数组去重的多种方法
- javascript实现PC网页里的拖拽效果
- Jquery实现简单的轮播效果(代码管用)
- node模块机制与异步处理详解
- JS中创建函数的三种方式及区别
- 使用jQuery操作HTML的table表格的实例解析
- Javascript数组Array方法解读
- GitHub上一些实用的JavaScript的文件压缩解压缩库推荐
- Javascript数组Array基础介绍
- 深入探究JavaScript中for循环的效率问题及相关优化
- 简单谈谈json跨域
- 详解JavaScript中数组和字符串的lastIndexOf()方法使用
- Node.js编写爬虫的基本思路及抓取百度图片的实例分享
- JavaScript中循环遍历Array与Map的方法小结
- Node.js的Express框架使用上手指南