国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

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

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

最近業(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ún)一次模板緩存前端,后續(xù)每次支付后,動(dòng)態(tài)渲染數(shù)據(jù)即可

二、考點(diǎn):

1.正則表達(dá)式

2.精簡(jiǎn)代碼量,盡量減少前端的工作量​

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

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

var t='銀行:${bankName},商家名稱(chēng):${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.查看效果:

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

6.有人會(huì)說(shuō),直接拼接字符串不是更快?比如:

var t=`銀行:${order.bankName},商家名稱(chēng):${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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 乐东| 噶尔县| 来宾市| 丰顺县| 信阳市| 诸城市| 竹北市| 隆德县| 鹿泉市| 绥宁县| 贵定县| 鄢陵县| 余干县| 垦利县| 沈阳市| 桦南县| 隆德县| 鹤庆县| 黔江区| 三门峡市| 万年县| 称多县| 张家口市| 合作市| 安庆市| 赤城县| 商都县| 永新县| 玉田县| 汝阳县| 雷波县| 社会| 虞城县| 迁安市| 沙雅县| 错那县| 阿拉尔市| 泗洪县| 滕州市| 五寨县| 新平|