Dũn*_*yễn 3 ejs node.js express
我尝试用这样的ejs渲染html
const ejs = require('ejs'),
fs = require('fs'),
str = fs.readFileSync(`${__dirname}/../mail_templates/test.ejs`, 'utf8');
console.log(ejs.render(str, {name: 'abc'});
Run Code Online (Sandbox Code Playgroud)
test.ejs
<%- include(`header.ejs`)%>
...
Run Code Online (Sandbox Code Playgroud)
但是得到了这个错误:
Error: ejs:1
>> 1| <%- include(`header.ejs`)%>
Could not find the include file "header.ejs"
...
Run Code Online (Sandbox Code Playgroud)
文件夹结构如下所示:
你能告诉我为什么吗?我也尝试过这些情况,但没有希望:
<% include header.ejs %>
<% include header %>
<%- include('header.ejs'); -%>
<%- include('../mail_templates/header.ejs'); -%>
<%- include('mail_templates/header.ejs'); -%>
<%- include('./mail_templates/header.ejs'); -%>
Run Code Online (Sandbox Code Playgroud)
唯一可行的情况是使用绝对路径:
<%- include("/Users/admin/Work/engine/mail_templates/header.ejs")%>
Run Code Online (Sandbox Code Playgroud)
但是我当然不想使用它。
包括相对于当前模板。为了使引擎知道当前的模板路径,应使用filename选项将其指定,例如:
const templatePath = `${__dirname}/../mail_templates/test.ejs`;
str = fs.readFileSync(templatePath, 'utf8');
ejs.render(str, {filename: templatePath, name: 'abc'});
Run Code Online (Sandbox Code Playgroud)
然后,预期其中任何一个都将起作用:
<% include header.ejs %>
<% include header %>
<%- include('header.ejs'); -%>
<%- include('./header.ejs'); -%>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
669 次 |
| 最近记录: |