色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

基于JS正則表達(dá)式實現(xiàn)模板數(shù)據(jù)動態(tài)渲染(實現(xiàn)思路詳解)

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

最近業(yè)務(wù)上需要動態(tài)渲染模板數(shù)據(jù),好久沒寫前端代碼了,有點生疏,將思路簡單寫下來,防老:

一、業(yè)務(wù)需求:

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

2.訂單數(shù)據(jù)是前端根據(jù)支付結(jié)果獲取的,最終渲染完的數(shù)據(jù)模板需要調(diào)用打印機打印出來

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

二、考點:

1.正則表達(dá)式

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

三、實現(xiàn)思路:

1.需要渲染數(shù)據(jù)的模板,以${變量名}區(qū)分:

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.組裝訂單數(shù)據(jù),注意變量屬性名與模板里的變量名要保持一致

var order={ 'bankName': '工行', 'merchantName': '小賣部', '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.查看效果:

基于JS正則表達(dá)式實現(xiàn)模板數(shù)據(jù)動態(tài)渲染(實現(xiàn)思路詳解)

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

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

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

到此這篇關(guān)于基于JS正則表達(dá)式實現(xiàn)模板數(shù)據(jù)動態(tài)渲染的文章就介紹到這了,更多相關(guān)js 正則模板數(shù)據(jù)內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产区久久| 黄色日韩网站 | 国产一级一国产一级毛片 | 国产精品成人久久久久久久 | 国产菲菲视频在线观看 | 九色福利 | 国产一级毛片免 | 婷婷丁香花麻豆 | 亚洲国产高清一区二区三区 | 成年女人黄小视频 | 久久巨乳 | 国产精品一区二区免费 | 美女视频黄免费 | 一区二区三区免费在线视频 | 一区二区播放 | 日韩欧美精品一区二区三区 | 国产美女精品三级在线观看 | 在线免费观看日本视频 | 国产精品美女视视频专区 | 国产精品九九 | 国产亚洲欧美日韩在线观看不卡 | 美女福利视频国产 | 国内在线播放 | 国产三级做爰在线观看视频 | 欧美日韩精品一区二区三区视频在线 | 成人一级片在线观看 | 国产精品久久国产三级国电话系列 | 亚洲精品永久一区 | 亚洲精品久久一区二区无卡 | 欧美性群另类交 | 中国一级做a爱片免费 | 中国一级毛片录像 | 久久精品一区二区三区不卡牛牛 | 精品日本久久久久久久久久 | 自拍视频精品 | 欧美黄色一级在线 | 国产第一夜 | 玖玖在线国产精品 | 好看欧美视频高清va | 亚洲欧美卡通动漫丝袜美腿 | 日本一区二区三区高清福利视频 |