Node.js项目中调用JavaScript的EJS模板库的方法
作为外部模块,调用的方法和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 });
Node.js的Express框架使用上手指南
Express介绍npm提供了大量的第三方模块,其中不乏许多Web框架,比如我们本章节要讲述的一个轻量级的Web框架———Express。Express是一个简洁、灵活的node.
Node.js编写爬虫的基本思路及抓取百度图片的实例分享
其实写爬虫的思路十分简单:按照一定的规律发送HTTP请求获得页面HTML源码(必要时需要加上一定的HTTP头信息,比如cookie或referer之类)利用正则匹配或
node模块机制与异步处理详解
1.模块机制commonJS模块机制出现的目的是为了构建js在web服务器,桌面程序,浏览器等方面形成生态系统。而nodejs就是这种规范的一种实现,用requird来引