javascript - EJS为什么提示EJS is not a function呢??
巴扎黑
巴扎黑 2017-04-10 16:40:03
[JavaScript讨论组]

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

巴扎黑
巴扎黑

全部回复(3)
ringa_lee

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>
</p>
</body>
</html>
巴扎黑

ejs.js 是这么用的吧:

var html = ejs.compile(template)(data);
ringa_lee

目测是题主访问是通过file://来的,然后就无法读取模板文件导致的。

可以用npm装一个http-server然后再做测试。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号