如何基于layui的laytpl實(shí)現(xiàn)數(shù)據(jù)綁定的示例代碼
想了半天才想起自己園子的登錄密碼??上攵嚅L(zhǎng)時(shí)間沒(méi)登錄了
正文
一開(kāi)始用layui做了幾個(gè)管理系統(tǒng),所以用起來(lái)覺(jué)得確實(shí)很容易上手,管理后臺(tái)最常用的就是form和table以及彈窗類。layui提供的form table layer已經(jīng)是很簡(jiǎn)潔好用了,拋開(kāi)底層的封裝不說(shuō),給我們展現(xiàn)出來(lái)的使用方法我覺(jué)得是非常簡(jiǎn)化了。管理用到的除了form table layer之外,經(jīng)常會(huì)有一些統(tǒng)計(jì)數(shù)據(jù)展示或者詳情頁(yè)這種內(nèi)容展示。那么一些用到的統(tǒng)計(jì)數(shù)據(jù)(除圖表),如文字統(tǒng)計(jì)型數(shù)據(jù)展示。這個(gè)時(shí)候,用layui的基于laytpl展現(xiàn)這種功能其實(shí)是極好的。
先寫(xiě)一個(gè)簡(jiǎn)單的數(shù)據(jù)綁定
第一步:引入layui的css文件和js文件(自行引入)
第二步:建立視圖,用于呈現(xiàn)渲染結(jié)果,代碼如下:
<div class="layui-row">
<div class="layui-col-md6" id="orderInfoDiv"></div>
</div>
第三步:編寫(xiě)模版,使用一個(gè)script標(biāo)簽存放模板,代碼如下:
<script type="text/html" id="orderInfo">
<div class="layui-card">
<div class="layui-card-header">訂單概況</div>
<div class="layui-card-body">
<ul class="layui-row layui-col-space10 layadmin-backlog">
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>營(yíng)業(yè)額</h3>
<p><cite style="font-size:24px;">{{d.turnover}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>訂單數(shù)</h3>
<p><cite style="font-size:24px;">{{d.orderNum}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>已發(fā)貨</h3>
<p><cite style="font-size:24px;">{{d.delivered}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>未發(fā)貨</h3>
<p><cite style="font-size:24px;">{{d.unDelivered}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>已取消</h3>
<p><cite style="font-size:24px;">{{d.cancelled}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>已收貨</h3>
<p><cite style="font-size:24px;">{{d.received }}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>已評(píng)價(jià)</h3>
<p><cite style="font-size:24px;">{{d.evaluated}}</cite></p>
</a>
</li>
<li class="layui-col-xs6 layui-col-sm3">
<a class="layadmin-backlog-body">
<h3>好評(píng)率</h3>
<p><cite style="font-size:24px;">{{d.favorableRate}}%</cite></p>
</a>
</li>
</ul>
</div>
</div>
</script>
第四步:渲染模版,代碼如下:
<script>
layui.use(['laytpl'], function () {
var laytpl = layui.laytpl;
//訂單統(tǒng)計(jì)(正常情況下,此處應(yīng)是ajax返回后的數(shù)據(jù),這里是模擬數(shù)據(jù)。)
//渲染模板所用的數(shù)據(jù)
var data = { turnover: "23,251", orderNum: "256", delivered: "16", unDelivered: "130", cancelled: "10", received: "100", evaluated: "80", favorableRate: "80" }
var orderInfoTpl = orderInfo.innerHTML //獲取模板,即上面所定義的 <script id="orderInfo">
, orderInfoDiv = document.getElementById('orderInfoDiv'); //視圖 即上面的 <div id="orderInfoDiv">
laytpl(orderInfoTpl).render(data, function (html) { //渲染視圖
orderInfoDiv.innerHTML = html;
});
})
</script>
第五步:效果顯示如下

是不是非常的簡(jiǎn)單呢。因?yàn)榇罅康暮笈_(tái)系統(tǒng)都是基于layui開(kāi)發(fā)的,遇到一些數(shù)據(jù)展示型的不想用傳統(tǒng)的jquery綁定方式的話,用這個(gè)其實(shí)非常實(shí)用呢。
詳情數(shù)據(jù)展示
如果是一個(gè)table,點(diǎn)擊查看詳情的話,也可以用這種方式展示數(shù)據(jù)
第一步:引入layui的css文件和js文件(自行引入),頁(yè)面中用到的css樣式自行編寫(xiě)。
第二步:table數(shù)據(jù)展示,此處是賦值已知數(shù)據(jù),開(kāi)發(fā)當(dāng)中換成自己的數(shù)據(jù),并給table定義一個(gè)點(diǎn)擊事件
<table class="layui-hide" lay-filter="demoTableFilter" id="demoTable"></table>
<script type="text/html" id="barDemo">
<a class="layui-btn layui-btn-xs" lay-event="detail">查看詳情</a>
</script>
以下是table的賦值
table.render({
elem: '#demoTable'
, cols: [[ //標(biāo)題欄
{ field: 'id', title: 'ID', width: 100 }
, { field: 'username', title: '用戶名', width: 80 }
, { field: 'email', title: '郵箱', width: 180 }
, { field: 'sign', title: '簽名', width: 180 }
, { field: 'sex', title: '性別', width: 80 }
, { field: 'city', title: '城市', width: 100 }
, { field: 'experience', title: '積分', minWidth: 80 }
, { width: 100, align: 'center', toolbar: '#barDemo' }
]]
, data: [{
"id": "10001"
, "username": "杜甫"
, "email": "xianxin@layui.com"
, "sex": "男"
, "city": "浙江杭州"
, "sign": "人生恰似一場(chǎng)修行"
, "experience": "116"
, "ip": "192.168.0.8"
, "logins": "108"
, "joinTime": "2016-10-14"
},{
"id": "10002"
, "username": "李白"
, "email": "xianxin@layui.com"
, "sex": "男"
, "city": "浙江杭州"
, "sign": "人生恰似一場(chǎng)修行"
, "experience": "12"
, "ip": "192.168.0.8"
, "logins": "106"
, "joinTime": "2016-10-14"
, "LAY_CHECKED": true
}]
});
table頁(yè)面效果展示

第三步,建立一個(gè)用來(lái)渲染詳情數(shù)據(jù)的彈出框
<div class="demoDetailDiv" style="display:none;padding:10px;">
<div id="detailDiv"></div>
</div>
第四步,點(diǎn)擊表格的“查看詳情”,通過(guò)laytpl實(shí)現(xiàn)數(shù)據(jù)綁定代碼如下:
table.on('tool(demoTableFilter)', function (obj) {
var data = obj.data;
if (obj.event === 'detail') {
index = layer.open({
title: '查看詳情',
type: 1,
move: false,
content: $('.demoDetailDiv'),
area: ['750px', '300px'],
resize: false,
scrollbar: false
});
var demoDetailTpl = demoDetail.innerHTML //獲取模板,
, detailDiv = document.getElementById('detailDiv'); //視圖
laytpl(demoDetailTpl).render(obj.data, function (html) { //渲染視圖
detailDiv.innerHTML = html;
});
}
});
顯示效果如下:

總結(jié):
以上是記錄一點(diǎn)最簡(jiǎn)單的用laytpl渲染數(shù)據(jù)的方式。到此這篇關(guān)于如何基于layui的laytpl實(shí)現(xiàn)數(shù)據(jù)綁定的示例代碼的文章就介紹到這了,更多相關(guān)layui laytpl 數(shù)據(jù)綁定內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實(shí)現(xiàn)小球沿正弦曲線運(yùn)動(dòng)
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)小球沿正弦曲線運(yùn)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
js實(shí)現(xiàn)AI五子棋人機(jī)大戰(zhàn)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)AI五子棋人機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
利用JS實(shí)現(xiàn)一個(gè)同Excel表現(xiàn)的智能填充算法
這篇文章主要給大家介紹了關(guān)于利用JS實(shí)現(xiàn)一個(gè)同Excel表現(xiàn)的智能填充算法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08
JavaScript數(shù)組的定義及數(shù)字操作技巧
這篇文章主要介紹了JavaScript數(shù)組的定義及數(shù)字操作技巧的相關(guān)資料,需要的朋友可以參考下2016-06-06
js實(shí)現(xiàn)懸浮窗效果(支持拖動(dòng))
本文主要介紹了js實(shí)現(xiàn)懸浮窗效果(支持拖動(dòng))的實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03
基于javascript實(shí)現(xiàn)的搜索時(shí)自動(dòng)提示功能
這篇文章主要介紹了基于javascript實(shí)現(xiàn)的搜索時(shí)自動(dòng)提示功能,非常實(shí)用,推薦給需要的小伙伴參考下。2014-12-12
Javascript客戶端將指定區(qū)域?qū)С龅絎ord、Excel的代碼
Javascript 瀏覽器客戶端導(dǎo)出指定區(qū)域到Word、Excel,非常不錯(cuò)的應(yīng)用實(shí)例2008-10-10

