template.js / artTemplate 模板引擎问题

发布于 2022-08-31 09:18:57 字数 1470 浏览 18 评论 0

html<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<title>basic-demo</title>
<script src="template-debug.js"></script>
</head>

<body>


<div id="content"></div>




<script id="test" type="text/html">
<ul>
    {{each }}
        <li>{{pinId }}</li>
    {{/each}}
</ul>
</script>





<script>
var data = [{"pinId":1,"userId":1}, {"pinId":2,"userId":2}, {"pinId":3,"userId":3}, {"pinId":4,"userId":4}];
var html = template('test', data);
document.getElementById('content').innerHTML = html;
</script>


</body>
</html>

这样的json数据怎么用,必须要下面这样吗?

html<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<title>basic-demo</title>
<script src="template-debug.js"></script>
</head>

<body>


<div id="content"></div>




<script id="test" type="text/html">
<ul>
    {{each list as val}}
        <li>{{val.pinId}}</li>
    {{/each}}
</ul>
</script>





<script>
var data = [{"pinId":1,"userId":1}, {"pinId":2,"userId":2}, {"pinId":3,"userId":3}, {"pinId":4,"userId":4}];
var dataList = {"list":data }
var html = template('test', dataList );
document.getElementById('content').innerHTML = html;
</script>


</body>
</html>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

夜夜流光相皎洁 2022-09-07 09:18:57

你说的这个 template.js 不清楚具体是哪一个模板引擎,有文档没?

不过绝大多数的模板引擎都支持 this 来指向输入的对象,比如 {{each this}}{{/each}},这种方式就适合你举例中的直接返回数组的情况。不过由于我不知道你说的到底是哪个模板引擎,所以不确定是否支持这样引用。

但是,更加推荐的做法是修改一下你的数据格式,你上面的例子可以变成:

javascriptvar html = template('test', { items: data });

如此一来模板里可以这么写了:

html{{each items as item}}
    <li>{{item.pinId}}</li>
{{/each}}
和我恋爱吧 2022-09-07 09:18:57

我现在就在使用art-template这个模板引擎,我使用的是原生的语法,看你用的好像是简化的语法。
我觉得是你没理解透数据的引用,建议你多看看这个
https://github.com/aui/arttemplate

ヅ她的身影、若隐若现 2022-09-07 09:18:57

这个问题我遇到过,可以直接使用{{each as item index}},如果list不传的话,底层会使用$data来代替

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文