亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

基于JS正則表達式實現模板數據動態渲染(實現思路詳解)

瀏覽:80日期:2024-05-20 17:29:18

最近業務上需要動態渲染模板數據,好久沒寫前端代碼了,有點生疏,將思路簡單寫下來,防老:

一、業務需求:

1.前端后端定義好模板以及變量名,保存數據庫

2.訂單數據是前端根據支付結果獲取的,最終渲染完的數據模板需要調用打印機打印出來

3.模板相對商家來說比較固定,但是每個商家需要的模板都有可能不一樣,所以需要每次登錄后,查詢一次模板緩存前端,后續每次支付后,動態渲染數據即可

二、考點:

1.正則表達式

2.精簡代碼量,盡量減少前端的工作量​

三、實現思路:

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.查看效果:

基于JS正則表達式實現模板數據動態渲染(實現思路詳解)

6.有人會說,直接拼接字符串不是更快?比如:

var t=`銀行:${order.bankName},商家名稱:${order.merchantName},訂單號:${order.orderNum}`;

這種方式在模板固定且數據量少的時候是挺好用的,但是業務上,雖然模板和數據對于商家來說相對固定,但是系統里面很多商家,每個商家的小票模板可能都不一樣,需要渲染的變量也挺多,前端不可能根據每個商家都改一套模板的,總而言之,適合才是最好的!

到此這篇關于基于JS正則表達式實現模板數據動態渲染的文章就介紹到這了,更多相關js 正則模板數據內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产三级全黄 | 久久精品国产欧美 | riav久久中文一区二区 | 久久91精品综合国产首页 | 91精品全国免费观看含羞草 | 日韩欧美在线第一页 | 在线成人a毛片免费播放 | 亚洲欧美日本综合一区二区三区 | 亚洲狠狠狠一区二区三区 | 欧美成人三级一区二区在线观看 | 综合色区 | 中文字幕日韩一区二区三区不卡 | 特级淫片aaaa毛片aa视频 | 奇米色88欧美一区二区 | 亚洲免费观看在线视频 | 国产福利免费在线观看 | 久久久这里有精品 | 中文国产成人精品久久一区 | 精品国产高清a毛片无毒不卡 | 伊人久久久综在合线久久在播 | 女同视频一区二区在线观看 | 亚欧成人一区二区 | 性网站视频| 亚洲99久久无色码中文字幕 | 亚洲精选 | 亚洲国产精品成人综合久久久 | 中文在线日韩 | 免费影院在线 | 亚洲色图男人天堂 | 国产一区二区三区在线观看精品 | 婷婷黄色片 | 国产日韩欧美中文字幕 | 91精品国产爱久久久久 | 婷婷久久综合九色综合九七 | 国产欧美在线观看精品一区二区 | 99精品视频在线观看免费播放 | 成年女人免费看片 | 日本免费观看95视频网站 | 日本一区毛片免费观看 | 国产欧美成人xxx视频 | 日本欧美成人免费观看 |