最近業務上需要動態渲染模板數據,好久沒寫前端代碼了,有點生疏,將思路簡單寫下來,防老:
一、業務需求:
-
前端后端定義好模板以及變量名,保存數據庫
-
訂單數據是前端根據支付結果獲取的,最終渲染完的數據模板需要調用打印機打印出來
-
模板相對商家來說比較固定,但是每個商家需要的模板都有可能不一樣,所以需要每次登錄后,查詢一次模板緩存前端,后續每次支付后,動態渲染數據即可
二、考點:
-
正則表達式
-
精簡代碼量,盡量減少前端的工作量
三、實現思路:
1.需要渲染數據的模板,以${變量名}區分:
var t="銀行:${bankName},商家名稱:${merchantName},訂單號:${orderNum}";
2.正則匹配獲取所有變量名
var keys=[]; var arr = t.match(/\$\{(.*?)\}/g); for(var key in arr){ var s=arr[key].replace("${","").replace("}",""); keys.push(s); } alert(keys);
3.組裝訂單數據,注意變量屬性名與模板里的變量名要保持一致
var order={ "bankName": "工行", "merchantName": "小賣部", "orderNum": "123456" };
4.渲染數據
for(var i=0;i<keys.length;i++){ var key=keys[i]; var value=order[key]; t= t.replace("${"+key+"}",value); } alert(t);
5.查看效果:
6.有人會說,直接拼接字符串不是更快?比如:
var t=`銀行:${order.bankName},商家名稱:${order.merchantName},訂單號:${order.orderNum}`;
這種方式在模板固定且數據量少的時候是挺好用的,但是業務上,雖然模板和數據對於商家來說相對固定,但是系統里面很多商家,每個商家的小票模板可能都不一樣,需要渲染的變量也挺多,前端不可能根據每個商家都改一套模板的,總而言之,適合才是最好的!