本身用 art-template 有些年头了,最近在培养团队学习 art-template 使用,发现有一个痛点比较难解决。javascript
好比有一个模版,咱们能够直接写在页面中,像这样:html
<script id="appbtnTemp" type="text/html"> <div id="<%=id%>" class="appbtn" title="<%=title%>" appid="<%=appid%>" realappid="<%=realappid%>" type="<%=type%>"> <img src="<%=imgsrc%>" alt="<%=title%>" style="width:<%=appsize%>px;height:<%=appsize%>px;"> <span style="width:<%=appsize+10%>px;"><%=title%></span> </div> </script>
但若是这是个公用的模版,在不少页面须要用到,那就不能直接写在页面中了,否则就得复制不少份了,那就只能写到 js 文件里,作为一个公用函数。java
var appbtn = template.compile( '<div id="<%=id%>" class="appbtn" title="<%=title%>" appid="<%=appid%>" realappid="<%=realappid%>" type="<%=type%>">'+ '<img src="<%=imgsrc%>" alt="<%=title%>" style="width:<%=appsize%>px;height:<%=appsize%>px;">'+ '<span style="width:<%=appsize+10%>px;"><%=title%></span>'+ '</div>' );
这样子虽然解决了公用的问题,但代码就变得难以维护了,毕竟是在 js 文件里写 html 代码,代码高亮提示没了,并且都是字符串拼接,若是模版有修改,将会是一个可怕的问题。jquery
那有没有什么解决办法呢?个人第一个想法是把每一个模版都写到独立的文件里,但在官网文档里看到浏览器版本不支持文件路径读取模版,那就本身改造下吧,让浏览器版本也支持文件加载读取模版。webpack
这里个人大体思路是经过 jquery 的 $.ajax() 去获取模版,读取到模版而后用 template.compile() 把模版编译成函数并储存好,若是再次调用模版,则不用从新去获取模版。git
$(function(){ var cache = {}; var renderFile = function(path, data){ var html; if(cache.hasOwnProperty(path)){ html = cache[path](data); }else{ $.ajax({ type: 'GET', url: path, dataType: 'text', async: false }).done(function(cb){ var render = template.compile(cb); html = render(data); cache[path] = render; }); } return html; } renderFile('test.art', {title: '测试1'}); });
下面是 test.art 文件es6
<div> <h1><%=title%></h1> </div>
代码实现总体仍是很 easy 的,这样修改以后,模版文件也能够统一管理了,既不会和页面混在一块儿,也不会和 js 混在一块儿。github
后续:web
在和 art-template 的做者交流后,做者给出两点解决方案:ajax
一、若是用 webpack 结合 art-template-loader 就解决了这个问题了,它能够根据须要自动打包模板(并且是编译好的代码,不包含模板引擎)
二、我建议你使用 es6,至少模板这里能够用 es6 书写这样能够轻松的写多行字符串