index.html
<script>
var data = '{"title":"cleaning","supplies":["mop","broom","duster"]}';
var html = new EJS({url: '/header.ejs'}).render(JSON.parse(data));
console.log(tel);
</script>
header.ejs(和上边那个文件在同一个目录下)
<h1><%=title %></h1>
<ul>
<% for(var i=0; i<supplies.length; i++) { %>
<li>
<a href='supplies/<%=supplies[i] %>'>
<%= supplies[i] %>
</a>
</li>
<% } %>
</ul>
我在顶部有引用js/ejs.js的~~~这是为什么呢??
这个是直接打印的ejs
ejs.js 是这么用的吧:
var html = ejs.compile(template)(data);
目测是题主访问是通过file://
来的,然后就无法读取模板文件导致的。
可以用npm
装一个http-server
然后再做测试。
ejs是这个http://www.embeddedjs.com/index.html吧
一般的ejs的指这个 https://github.com/tj/ejs
那你提到的ejs,做了个例子,运行没有问题注意文件的放置的目录位置
样例文件,都在同一个目录下
html文件和pjs.js,header.ejs在同一个目录下
<!DOCTYPE html>
<html>
<head>
<title>width offsetwidth clientWidth</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="ejs.js"></script>
<script>
var data = {"title":"cleaning","supplies":["mop","broom","duster"]};
var html = new EJS({url: 'header.ejs'}).render(data);
console.log(html);
</script>
</head>
<body>
</div>
</body>
</html>