基于JS正則表達(dá)式實(shí)現(xiàn)模板數(shù)據(jù)動(dòng)態(tài)渲染(實(shí)現(xiàn)思路詳解)
最近業(yè)務(wù)上需要?jiǎng)討B(tài)渲染模板數(shù)據(jù),好久沒(méi)寫(xiě)前端代碼了,有點(diǎn)生疏,將思路簡(jiǎn)單寫(xiě)下來(lái),防老:
一、業(yè)務(wù)需求:
1.前端后端定義好模板以及變量名,保存數(shù)據(jù)庫(kù)
2.訂單數(shù)據(jù)是前端根據(jù)支付結(jié)果獲取的,最終渲染完的數(shù)據(jù)模板需要調(diào)用打印機(jī)打印出來(lái)
3.模板相對(duì)商家來(lái)說(shuō)比較固定,但是每個(gè)商家需要的模板都有可能不一樣,所以需要每次登錄后,查詢一次模板緩存前端,后續(xù)每次支付后,動(dòng)態(tài)渲染數(shù)據(jù)即可
二、考點(diǎn):
1.正則表達(dá)式
2.精簡(jiǎn)代碼量,盡量減少前端的工作量
三、實(shí)現(xiàn)思路:
1.需要渲染數(shù)據(jù)的模板,以${變量名}區(qū)分:
var t="銀行:${bankName},商家名稱:${merchantName},訂單號(hào):${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.組裝訂單數(shù)據(jù),注意變量屬性名與模板里的變量名要保持一致
var order={
"bankName": "工行",
"merchantName": "小賣(mài)部",
"orderNum": "123456"
};
4.渲染數(shù)據(jù)
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.有人會(huì)說(shuō),直接拼接字符串不是更快?比如:
var t=`銀行:${order.bankName},商家名稱:${order.merchantName},訂單號(hào):${order.orderNum}`;
這種方式在模板固定且數(shù)據(jù)量少的時(shí)候是挺好用的,但是業(yè)務(wù)上,雖然模板和數(shù)據(jù)對(duì)于商家來(lái)說(shuō)相對(duì)固定,但是系統(tǒng)里面很多商家,每個(gè)商家的小票模板可能都不一樣,需要渲染的變量也挺多,前端不可能根據(jù)每個(gè)商家都改一套模板的,總而言之,適合才是最好的!
到此這篇關(guān)于基于JS正則表達(dá)式實(shí)現(xiàn)模板數(shù)據(jù)動(dòng)態(tài)渲染的文章就介紹到這了,更多相關(guān)js 正則模板數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談javascript的url參數(shù)parse和build函數(shù)
下面小編就為大家?guī)?lái)一篇淺談javascript的url參數(shù)parse和build函數(shù)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03
javascript如何實(shí)現(xiàn)360度全景照片問(wèn)題匯總
這篇文章主要為大家詳細(xì)匯總了javascript如何實(shí)現(xiàn)360度全景照片問(wèn)題,感興趣的朋友可以參考一下2016-04-04
JavaScript的Object.defineProperty詳解
本篇文章給大家詳細(xì)講述了JavaScript的Object.defineProperty的相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友參考學(xué)習(xí)下。2018-07-07
js下拉菜單語(yǔ)言選項(xiàng)簡(jiǎn)單實(shí)現(xiàn)
大家對(duì)下拉菜單并不陌生吧,下面為大家介紹下使用js實(shí)現(xiàn)下拉菜單語(yǔ)言選項(xiàng),具體實(shí)現(xiàn)如下,喜歡的朋友可以看看2013-09-09
JavaScript中使用Spread運(yùn)算符的八種方法總結(jié)
這篇文章主要給大家介紹了JavaScript中使用Spread運(yùn)算符的八種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
JS遍歷JSON數(shù)組及獲取JSON數(shù)組長(zhǎng)度操作示例【測(cè)試可用】
這篇文章主要介紹了JS遍歷JSON數(shù)組及獲取JSON數(shù)組長(zhǎng)度操作,涉及javascript簡(jiǎn)單json數(shù)組遍歷與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2018-12-12
使用Bootstrap美化按鈕實(shí)例代碼(demo)
這篇文章主要介紹了使用Bootstrap美化按鈕實(shí)例代碼(demo),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02

