layui后台添加数据给php,layui怎么实现数据绑定

layui实现数据绑定的方法:首先引入layui的css文件和js文件;然后建立视图,用于呈现渲染结果;接着编写模版,使用一个script标签存放模板;最后渲染模版即可。

2166e457a211aa223561eec51356d568.png

本教程操作环境:Windows7系统、layui2.5.6版,本文适用于所有品牌的电脑。

基于layui的laytpl实现数据绑定

想了半天才想起自己园子的登录密码。可想而知,多长时间没登录了

正文

一开始用layui做了几个管理系统,所以用起来觉得确实很容易上手,管理后台最常用的就是form和table以及弹窗类。layui提供的form table layer已经是很简洁好用了,抛开底层的封装不说,给我们展现出来的使用方法我觉得是非常简化了。管理用到的除了form table layer之外,经常会有一些统计数据展示或者详情页这种内容展示。那么一些用到的统计数据(除图表),如文字统计型数据展示。这个时候,用layui的基于laytpl展现这种功能其实是极好的。

先写一个简单的数据绑定

第一步:引入layui的css文件和js文件(自行引入)

第二步:建立视图,用于呈现渲染结果,代码如下:

第三步:编写模版,使用一个script标签存放模板,代码如下:

订单概况
  • 营业额

    {{d.turnover}}

  • 订单数

    {{d.orderNum}}

  • 已发货

    {{d.delivered}}

  • 未发货

    {{d.unDelivered}}

  • 已取消

    {{d.cancelled}}

  • 已收货

    {{d.received }}

  • 已评价

    {{d.evaluated}}

  • 好评率

    {{d.favorableRate}}%

第四步:渲染模版,代码如下:

layui.use(['laytpl'], function () {

var laytpl = layui.laytpl;

//订单统计(正常情况下,此处应是ajax返回后的数据,这里是模拟数据。)

//渲染模板所用的数据

var data = { turnover: "23,251", orderNum: "256", delivered: "16", unDelivered: "130", cancelled: "10", received: "100", evaluated: "80", favorableRate: "80" }

var orderInfoTpl = orderInfo.innerHTML //获取模板,即上面所定义的

, orderInfoDiv = document.getElementById('orderInfoDiv'); //视图 即上面的

laytpl(orderInfoTpl).render(data, function (html) { //渲染视图

orderInfoDiv.innerHTML = html;

});

})

第五步:效果显示如下

b5eb2cdca07f174c5da795874915445f.png

是不是非常的简单呢。因为大量的后台系统都是基于layui开发的,遇到一些数据展示型的不想用传统的jquery绑定方式的话,用这个其实非常实用呢。

详情数据展示

如果是一个table,点击查看详情的话,也可以用这种方式展示数据

第一步:引入layui的css文件和js文件(自行引入),页面中用到的css样式自行编写。

第二步:table数据展示,此处是赋值已知数据,开发当中换成自己的数据,并给table定义一个点击事件

用来渲染的数据

姓名:

{{d.username}}

邮箱:

{{d.email}}

签名:

{{d.sign}}

性别:

{{d.sex}}

城市:

{{d.city}}

积分:

{{d.experience}}

以下是table的赋值table.render({

elem: '#demoTable'

, cols: [[ //标题栏

{ 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页面效果展示

4807a61a3a147705bc17f736d567ae77.png

第三步,建立一个用来渲染详情数据的弹出框

第四步,点击表格的“查看详情”,通过laytpl实现数据绑定 代码如下: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;

});

}

});

显示效果如下:

954cdcdfda4b7a91130947b664b2f271.png

总结:

以上是记录一点最简单的用laytpl渲染数据的方式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值