如何基于layui的laytpl實現(xiàn)數(shù)據(jù)綁定的示例代碼
想了半天才想起自己園子的登錄密碼??上攵嚅L時間沒登錄了
正文
一開始用layui做了幾個管理系統(tǒng),所以用起來覺得確實很容易上手,管理后臺最常用的就是form和table以及彈窗類。layui提供的form table layer已經(jīng)是很簡潔好用了,拋開底層的封裝不說,給我們展現(xiàn)出來的使用方法我覺得是非常簡化了。管理用到的除了form table layer之外,經(jīng)常會有一些統(tǒng)計數(shù)據(jù)展示或者詳情頁這種內(nèi)容展示。那么一些用到的統(tǒng)計數(shù)據(jù)(除圖表),如文字統(tǒng)計型數(shù)據(jù)展示。這個時候,用layui的基于laytpl展現(xiàn)這種功能其實是極好的。
先寫一個簡單的數(shù)據(jù)綁定
第一步:引入layui的css文件和js文件(自行引入)
第二步:建立視圖,用于呈現(xiàn)渲染結(jié)果,代碼如下:
<div class="layui-row"> <div class="layui-col-md6" id="orderInfoDiv"></div> </div>
第三步:編寫模版,使用一個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è)額</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>已評價</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>好評率</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)計(正常情況下,此處應(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>
第五步:效果顯示如下
是不是非常的簡單呢。因為大量的后臺系統(tǒng)都是基于layui開發(fā)的,遇到一些數(shù)據(jù)展示型的不想用傳統(tǒng)的jquery綁定方式的話,用這個其實非常實用呢。
詳情數(shù)據(jù)展示
如果是一個table,點擊查看詳情的話,也可以用這種方式展示數(shù)據(jù)
第一步:引入layui的css文件和js文件(自行引入),頁面中用到的css樣式自行編寫。
第二步:table數(shù)據(jù)展示,此處是賦值已知數(shù)據(jù),開發(fā)當(dāng)中換成自己的數(shù)據(jù),并給table定義一個點擊事件
<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": "人生恰似一場修行" , "experience": "116" , "ip": "192.168.0.8" , "logins": "108" , "joinTime": "2016-10-14" },{ "id": "10002" , "username": "李白" , "email": "xianxin@layui.com" , "sex": "男" , "city": "浙江杭州" , "sign": "人生恰似一場修行" , "experience": "12" , "ip": "192.168.0.8" , "logins": "106" , "joinTime": "2016-10-14" , "LAY_CHECKED": true }] });
table頁面效果展示
第三步,建立一個用來渲染詳情數(shù)據(jù)的彈出框
<div class="demoDetailDiv" style="display:none;padding:10px;"> <div id="detailDiv"></div> </div>
第四步,點擊表格的“查看詳情”,通過laytpl實現(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é):
以上是記錄一點最簡單的用laytpl渲染數(shù)據(jù)的方式。到此這篇關(guān)于如何基于layui的laytpl實現(xiàn)數(shù)據(jù)綁定的示例代碼的文章就介紹到這了,更多相關(guān)layui laytpl 數(shù)據(jù)綁定內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺析JavaScript中l(wèi)et與const命令的區(qū)別
這篇文章主要為大家詳細(xì)介紹了JavaScript中l(wèi)et命令與const命令的用法及區(qū)別,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,需要的可以參考下2023-09-09js動態(tài)添加onclick事件可傳參數(shù)與不傳參數(shù)
本節(jié)主要介紹了js動態(tài)添加onclick事件可傳參數(shù)與不傳參數(shù),需要的朋友可以參考下2014-07-07JS如何判斷瀏覽器類型和詳細(xì)區(qū)分IE各版本瀏覽器
本篇文章主要介紹了JS判斷瀏覽器類型和詳細(xì)區(qū)分IE各版本瀏覽器的代碼,非常具有實用價值,有興趣的可以了解一下。2017-03-03IE6-8中Date不支持toISOString的修復(fù)方法
這篇文章主要介紹了IE6-8中Date不支持toISOString的修復(fù)方法,需要的朋友可以參考下2014-05-05javascript的tab切換原理與效果實現(xiàn)方法
這篇文章主要介紹了javascript的tab切換原理與效果實現(xiàn)方法,實例分析了簡單的tab切換實現(xiàn)技巧,非常具有實用價值,需要的朋友可以參考下2015-01-01