前端模板选择

http://nuysoft.com/bak/templating.html

define(function(require,exports,module){
	
	var box = require("../../weixin/box.js");

        var html_cn_text  =   ["<div>.....</div>"];
        var html_en_text  =   ["<div>.....</div>"];
        var html_en_text  =   ["<div>.....</div>"];


        var checkDomExist = function(){


            var lang = box.getLang();
    
            switch(lang){
              case 'zh_cn' : 
                  html_text = html_cn_text;
                  break;
              case 'zh_tw' :
                  html_text = html_cn_text;
                  break;
              case 'zh_hk' : 
                  html_text = html_cn_text;
                  break;
              default :
                  html_text = html_en_text;
                  break; 
            }

        }

 checkDomExist();

 module.exports = $.extend({"checkDomExist" : checkDomExist},box);

})
define(function(require, exports, module) {
  var source = [ '<div class="container" id="js-index">',
     '<!--餘額頁[[-->',
     '<div class="main">',
         '<div class="ico-wrap">',
             '<span class="ico-money"><!--图标--></span>',
         '</div>',
         '<p class="tips-txt">_{indexTitle}</p>',
         '<p class="tips-cnt" id="balance"></p>',
         '<div class="form-line-btn">',
             '<a class="btn-opt btn-green js-draw-index" >_{withdraw}</a>',
         '</div>',
         '<p class="tips-redpacket">',
             '<img src="" class="ico-img">',
             '<a href="#" id="go-luckymoney">_{go-luckymoney}</a>',
         '</p>',
     '</div>',
     '<!--餘額頁]]-->',
     '<div class="tips-link">_{tips-link}',
     '</div>',
 '</div>',
 '<!--弹窗:参考公共模块\inc\html\mod_pop_tips.shtml-->',
 '<div class="pop-tips balance-pop-tips" id="balance_tips_container">',
     '<div class="pop-tips-main">',
         '<a class="pop-btn-close" id="balance_tips_close"><!--关闭按钮--></a>',
         '<div class="pop-tips-cnt">',
             '<p>_{pop-tips-cnt}</p>',
         '</div>',
     '</div>',
 '</div>'].join("");
  return source;
})
//app.js
//引入
$.myspeed = require("../../../../g/js/mobile/global/hkwallet/myspeed.js");
//配置
$.myspeed.init({demainId_1 : "21370",demainId_2 : "1"},{basePerfId:"3"});


//其它页面
 var Detail = {
        title: '零錢详情',
    	body : tpl,
    	bodyClass:'rec-record-detail',
    	pageId : 4,//测速 
        init : function(){//增加测速点
            $.myspeed.addSpeed(this);
        },
        afterinit:function(){//上报
            $.SPA.emit("sendSpeed",this);
        }

};
//初始化&发送

$.mystat.init('hkwallet.balance.view.');

//发送
$.mystat.send('hkwallet.balance.init.charge');


Title Text

{
    "retcode": "0",
    "retmsg": "OK",
    "current_page": "1",
    "transactions": [
        {
            "amount_in_cent": "10",
            "bank_name": "0",
            "create_time": "1471348514",
            "currency_code": "HK\x24",
            "datetime": "0",
            "description": "",
            "instrument": "BALANCE",
            "merchant": "lowinwu2",
            "merchant_id": "o5PXlshcsO",
            "pay_state": "2",
            "payrecord_id": "1010013000000501201608160020585494",
            "product_desc": "",
            "transfer_type": "pay",
            "type": "transfer"
        },
        {
            "amount_in_cent": "1",
            "bank_name": "",
            "create_time": "1470815513",
            "currency_code": "HK\x24",
            "datetime": "1470815513",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "\x25E6\x2588\x2591\x25E4\x25BB\x25AC\x25E9\x2583\x25BD\x25E6\x2598\x25AF\x25E8\x2587\x25AA\x25E5\x25B7\x25B1\x25E6\x2583\x25B3\x25E6\x25B3\x2595\x25E7\x259A\x2584\x25E5\x25A3\x25AB\x25E5\x258A\x259B\x25E9\x2587\x258F\x25E5\x2592\x258C\x25E8\x25B0\x2590\x25E7\x25A4\x25BE\x25E4\x25BC\x259A",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201608101038824047",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "10",
            "bank_name": "0",
            "create_time": "1470297633",
            "currency_code": "HK\x24",
            "datetime": "1470387002",
            "description": "luckymoney",
            "instrument": "BALANCE",
            "merchant": "WeChat\x25E5\x2588\x25A9\x25E6\x2598\x25AF",
            "merchant_id": "3000000101",
            "pay_state": "7",
            "payrecord_id": "1010013000000101201608040020511762",
            "product_desc": "luckymoney",
            "transfer_type": "",
            "type": "Payment"
        },
        {
            "amount_in_cent": "17",
            "bank_name": "",
            "create_time": "1469763685",
            "currency_code": "HK\x24",
            "datetime": "1469763685",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "\x25E5\x25A7\x259A\x25E5\x2585\x25B5",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201607291038291214",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "5",
            "bank_name": "",
            "create_time": "1469618248",
            "currency_code": "HK\x24",
            "datetime": "1469618248",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "\x25E6\x259D\x258E\x25E5\x25B8\x2585",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201607271038221415",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "1",
            "bank_name": "",
            "create_time": "1469616578",
            "currency_code": "HK\x24",
            "datetime": "1469616578",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "\x25E5\x25A7\x259A\x25E5\x2585\x25B5",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201607271038217535",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "10",
            "bank_name": "",
            "create_time": "1469611166",
            "currency_code": "HK\x24",
            "datetime": "1469611166",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "lowinwu2",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201607271038214353",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "600",
            "bank_name": "0",
            "create_time": "1469609207",
            "currency_code": "HK\x24",
            "datetime": "0",
            "description": "",
            "instrument": "BALANCE",
            "merchant": "lowinwu2",
            "merchant_id": "o5PXlshcsO",
            "pay_state": "5",
            "payrecord_id": "1010013000000501201607270020471404",
            "product_desc": "",
            "transfer_type": "pay",
            "type": "transfer"
        },
        {
            "amount_in_cent": "8",
            "bank_name": "",
            "create_time": "1469418838",
            "currency_code": "HK\x24",
            "datetime": "1469418838",
            "description": "",
            "instrument": "CREDITCARD",
            "merchant": "Jing\x25E9\x259D\x2593",
            "merchant_id": "3000000101",
            "pay_state": "0",
            "payrecord_id": "3000000101201607251038102362",
            "product_desc": "",
            "transfer_type": "",
            "type": "luckymoney"
        },
        {
            "amount_in_cent": "10",
            "bank_name": "0",
            "create_time": "1469152352",
            "currency_code": "HK\x24",
            "datetime": "1469242202",
            "description": "luckymoney",
            "instrument": "BALANCE",
            "merchant": "WeChat\x25E5\x2588\x25A9\x25E6\x2598\x25AF",
            "merchant_id": "3000000101",
            "pay_state": "7",
            "payrecord_id": "1010013000000101201607220020450530",
            "product_desc": "luckymoney",
            "transfer_type": "",
            "type": "Payment"
        }
    ]
}

前端模板选择

1、Embedded JavaScript Templates (micro template)

      基于原生 JS 语法,解析简单、渲         染性       能接近极限;书写略烦,容易导         致模板中出现过多的业务代码而失控。---开发接入方便

 

2、Logic-less Templates (mustache)

     基于自定义语法,解析复杂、渲染性能不一---开发接入不利

语法,定义模板书写方式

前端模板选择

Mustache

独有语法结构:{{}}

{{#keyName}} {{/keyName}}

以#开始、以/结束表示区块,它会根据当前上下文中的键值来对区块进行一次或多次渲染,例如改写下 Demo 中的 tpl:


var tpl = '{{#address}} <p>{{street}},{{city}},{{state}}</p> {{/address}}';
var html = Mustache.render(tpl, data);

//输出:
<p>1 Infinite Loop Cupertino</br>,California,CA</p>

前端模板选择

Micro-Templating

实现方式

new Function()  执行数组中存放的每个变量
with()
--低性能
Introduce the data as local variables using with(){}
reg new RegExp(s + "=(.+?)" + e , "g"), // /<%=(.+?)%>/g
str.replace .replace(reg, "',$1,'")
p p.push("","","")
(function(obj
/**/) {
var p=[],print=function(){p.push.apply(p,arguments);};with(obj){p.push('     
            <li class="amt">                     <!--交互说明:当金额为收入时,绿色标识,在.text后加入income-->                     <span class="tit">',sincoming,'</span><span class="text ',paynumClass,'">',cur_type,' ',paynum,'</span>                 </li>                 <li>                     <span class="tit">',stype,'</span><span class="text">',type,'</span>                 </li>                 <li>                     <span class="tit">',stime,'</span><span class="text">',trade_time,'</span>                 </li>                 <li>                     <span class="tit">',stransaction,'</span><span class="text">',listid,'</span>                 </li>                 <li>                     <span class="tit">',snote,'</span><span class="text">',memo,'</span>                 </li>             ');}return p.join('');
})

? print有什么用-todo

前端模板选择

Underscore Templating

源自 Micro-Templating

实    现 :new Function() + with()

不同点 :加入自己循环函数

前端模板选择

EJS

方式一:

new EJS({ text: "Hello, <%= name %>" }).render({ name: "Jack" });  


方式二:

// in template.ejs  
  Hello, <%= name %>  
  
// in JS file  
  new EJS({ url: "template.ejs" }).render({ name: "Jack" });  
// 返回: Hello, Jack  

源自 Micro-Templating

new Function() + with()

前端模板选择

artTemplate

方式一:

new EJS({ text: "Hello, <%= name %>" }).render({ name: "Jack" });  


方式二:

// in template.ejs  
  Hello, <%= name %>  
  
// in JS file  
  new EJS({ url: "template.ejs" }).render({ name: "Jack" });  
// 返回: Hello, Jack  

源自 Micro-Templating

new Function() + with()

前端模板选择

aceTemplate

方式一:

new EJS({ text: "Hello, <%= name %>" }).render({ name: "Jack" });  


方式二:

// in template.ejs  
  Hello, <%= name %>  
  
// in JS file  
  new EJS({ url: "template.ejs" }).render({ name: "Jack" });  
// 返回: Hello, Jack  

源自 Micro-Templating

new Function() + with()

前端模板选择

By lowinwu

前端模板选择

前端模板选择

  • 1,431