express中使用ejs怎么实现前后台共用同一套模板啊?
发布于 10 年前 作者 fancyboynet 6960 次浏览 最后一次编辑是 8 年前

我有一个单独的模板文件test.ejs 后台直接<% include test.ejs %>没问题 前台我想把test.ejs的内容放在script标签中让js调用渲染,咋整? 类似

<div>
<% include test %>
</div>
<script type="text/template" id="tpl">
    <% include test %> <!-- 这边不想被解析,由客户端渲染 -->
</script>
9 回复

用 swig 可以。ejs 不清楚。

直接css display掉不知道能不能达到你想要的结果

前后端使用不同的分隔符<% %> {{ }}

ejs.open = '{{';
ejs.close = '}}';

@taufik 显然不行。。。

@nihgwu 那不搞两套了,我现换了种思路,把ejs的目录暴露出来,前台ajax获取文件后用ejs.render()渲染

@fancyboynet 这样效率突然就低了好多吧?

@alsotang 效率不好说,应该没啥差别,文件不大的。模板没办法存在页面中,也只能另外获取了

@fancyboynet 我指的效率是网络传输效率,多了个 ajax 好蛋疼啊。 你可以写个 express 的 helper,比如叫 template,然后把

<script type="text/template" id="tpl">
    <% include test %> <!-- 这边不想被解析,由客户端渲染 -->
</script>

换成

<script type="text/template" id="tpl">
    <%- template('./test') %> <!-- 这边不想被解析,由客户端渲染 -->
</script>

在 template 中, 实现读取本地文件 ./test.ejs,就好了啊。

@alsotang 嗯,确实可行,我用fs.readFileSync把文件读过来填进去就好了,谢谢提供思路

回到顶部