这篇文章给大家分享的是有关Nodejs中怎么使用模板引擎以及使用模板引擎渲染HTML的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
使用readdir获取指定路径下的所有文件名
文件结构
实现代码
const fs = require('fs');
fs.readdir('G:/pink_code/Node_Study/02',(err,list) => {
if (!err) {
console.log(list);
}
})
代码输出
[ '01_http-helloWorld.js', '02_使用readdir获取指定路径下的所有文件名.js', 'www' ]
在浏览器中使用模板引擎
1. 安装art-template
npm install art-template
2. 通过script标签引入art-template
<script src="./node_modules/art-template/lib/template-web.js"></script>
3. 使用模板引擎语法进行调用
<script src="./node_modules/art-template/lib/template-web.js"></script>
<script type='text/template' id = 'tpl'>
这是{{name}}
</script>
<script>
const test = template('tpl',{
name: 'China'
});
console.log(test);
</script>
在Node中使用模板引擎
1. 安装art-template
npm install art-template
2. 在需要使用模板引擎的模块中加载art-template
3. 查文档,使用模板引擎的API
在Node中使用模板引擎的一个小案例
const template = require('art-template');
const test = template.render('hello {{name}}',{
name: 'NodeJs'
})
console.log(test);
输出结果
hello NodeJs
一个使用模板引擎渲染HTML的小案例
HTML结构
<html dir="ltr">
<head>
<meta charset="utf-8">
<meta name="google" value="notranslate">
<style>
h2 {
border-bottom: 1px solid #c0c0c0;
margin-bottom: 10px;
padding-bottom: 10px;
white-space: nowrap;
}
table {
border-collapse: collapse;
}
th {
cursor: pointer;
}
td.detailsColumn {
-webkit-padding-start: 2em;
text-align: end;
white-space: nowrap;
}
a.icon {
-webkit-padding-start: 1.5em;
text-decoration: none;
user-select: auto;
}
a.icon:hover {
text-decoration: underline;
}
a.file {
background: url(" ") left top no-repeat;
}
a.dir {
background: url(" ") left top no-repeat;
}
a.up {
background: url(" ") left top no-repeat;
}
html[dir=rtl] a {
background-position-x: right;
}
#parentDirLinkBox {
margin-bottom: 10px;
padding-bottom: 10px;
}
#listingParsingErrorBox {
border: 1px solid black;
background: #fae691;
padding: 10px;
display: none;
}
</style>
<title id="title">C:\Users\HP\Desktop\共享文件\ 的索引</title>
</head>
<body>
<div id="listingParsingErrorBox">糟糕!Google Chrome无法解读服务器所发送的数据。请<a
href="http://code.google.com/p/chromium/issues/entry">报告错误</a>,并附上<a href="LOCATION">原始列表</a>。</div>
<h2 id="header">C:\Users\HP\Desktop\共享文件\ 的索引</h2>
<div id="parentDirLinkBox" style="display: block;">
<a id="parentDirLink" class="icon up" href="/C:/Users/HP/Desktop/%E5%85%B1%E4%BA%AB%E6%96%87%E4%BB%B6/..">
<span id="parentDirText">[上级目录]</span>
</a>
</div>
<table>
<thead>
<tr id="theader">
<th id="nameColumnHeader" tabindex="0" role="button">名称</th>
<th id="sizeColumnHeader" tabindex="0" role="button">
大小
</th>
<th id="dateColumnHeader" tabindex="0" role="button">
修改日期
</th>
</tr>
</thead>
<tbody id="tbody">
{{each files}}
<tr>
<td data-value="{{$value}}"><a class="icon file" draggable="true" href="{{$value}}">{{$value}}</a>
</td>
<td data-value="193955">189 kB</td>
<td data-value="1627464963">2021/7/28 下午5:36:03</td>
</tr>
{{/each}}
</tbody>
</table>
</body>
</html>
Node代码
const http = require('http');
const template = require('art-template');
const fs = require('fs');
const server = http.createServer();
server.on('request', (req, res) => {
const url = req.url;
// 文件路径
const filePath = 'G:/pink_code/Node_Study/02';
// 获取文件路径下所有的文件名
let listName;
fs.readdir(filePath, (err, list) => {
if (!err) {
listName = list;
}
})
// 读取模板文件内容
fs.readFile('./www/template.html', (err, data) => {
if (!err) {
data = data.toString();
test = template.render(data,{
files: listName
})
res.end(test);
} else {
console.log('读取文件出错', err);
}
});
})
// 监听3000端口
server.listen(3000, (err) => {
if (!err) {
console.log('服务器启动成功!');
}
})
实现效果
感谢各位的阅读!关于“Nodejs中怎么使用模板引擎以及使用模板引擎渲染HTML”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!