zoukankan      html  css  js  c++  java
  • 从 art-template 模版维护到动态加载的思考

      自己用 art-template 有些年头了,最近在培养团队学习 art-template 使用,发现有一个痛点比较难解决。

      比如有一个模版,我们可以直接写在页面中,像这样:

    <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="<%=appsize%>px;height:<%=appsize%>px;">
            <span style="<%=appsize+10%>px;"><%=title%></span>
        </div>
    </script>
    

      但如果这是个公用的模版,在很多页面需要用到,那就不能直接写在页面中了,不然就得复制很多份了,那就只能写到 js 文件里,做为一个公用函数。

    var appbtn = template.compile(
        '<div id="<%=id%>" class="appbtn" title="<%=title%>" appid="<%=appid%>" realappid="<%=realappid%>" type="<%=type%>">'+
            '<img src="<%=imgsrc%>" alt="<%=title%>" style="<%=appsize%>px;height:<%=appsize%>px;">'+
            '<span style="<%=appsize+10%>px;"><%=title%></span>'+
        '</div>'
    );
    

      这样子虽然解决了公用的问题,但代码就变得难以维护了,毕竟是在 js 文件里写 html 代码,代码高亮提示没了,而且都是字符串拼接,如果模版有修改,将会是一个可怕的问题。

      那有没有什么解决办法呢?我的第一个想法是把每个模版都写到独立的文件里,但在官网文档里看到浏览器版本不支持文件路径读取模版,那就自己改造下吧,让浏览器版本也支持文件加载读取模版。

      这里我的大致思路是通过 jquery 的 $.ajax() 去获取模版,读取到模版然后用 template.compile() 把模版编译成函数并储存好,如果再次调用模版,则不用重新去获取模版。

    $(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 文件

    <div>
        <h1><%=title%></h1>
    </div>
    

      代码实现整体还是很 easy 的,这样修改之后,模版文件也可以统一管理了,既不会和页面混在一起,也不会和 js 混在一起。

      后续:

      在和 art-template 的作者交流后,作者给出两点解决方案:

    1、如果用 webpack 结合 art-template-loader 就解决了这个问题了,它可以根据需要自动打包模板(而且是编译好的代码,不包含模板引擎)

    2、我建议你使用 es6,至少模板这里可以用 es6 书写这样可以轻松的写多行字符串

  • 相关阅读:
    Group Normalization
    Resnet小记
    Mxnet 查看模型params的网络结构
    ResNets和Inception的理解
    基础 | batchnorm原理及代码详解
    交叉熵代价函数原理
    深度学习笔记:优化方法总结(BGD,SGD,Momentum,AdaGrad,RMSProp,Adam)
    机器学习 logistic分类
    ubuntu16.04 安装搜狗输入法
    工作5年半了,最近准备做一些工作的小结了
  • 原文地址:https://www.cnblogs.com/hooray/p/6895343.html
Copyright © 2011-2022 走看看