update
This commit is contained in:
parent
d744fea2a3
commit
abb387250c
@ -22,12 +22,6 @@
|
|||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<!--
|
|
||||||
<p align="center">
|
|
||||||
<a href="https://saucelabs.com/beta/builds/7e6196205e4f492496203388fc003b65"><img src="https://saucelabs.com/browser-matrix/layui.svg" alt="Browser Matrix"></a>
|
|
||||||
</p>
|
|
||||||
-->
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
layui 是一套开源的 Web UI 组件库,采用自身经典的模块化规范,并遵循原生 HTML/CSS/JS 的开发方式,极易上手,拿来即用。其风格简约轻盈,而组件优雅丰盈,从源代码到使用方法的每一处细节都经过精心雕琢,非常适合网页界面的快速开发。layui 区别于那些基于 MVVM 底层的前端框架,却并非逆道而行,而是信奉返璞归真之道。准确地说,它更多是面向后端开发者,你无需涉足前端的各种工具,只需面对浏览器本身,让一切你所需要的元素与交互,从这里信手拈来。
|
layui 是一套开源的 Web UI 组件库,采用自身经典的模块化规范,并遵循原生 HTML/CSS/JS 的开发方式,极易上手,拿来即用。其风格简约轻盈,而组件优雅丰盈,从源代码到使用方法的每一处细节都经过精心雕琢,非常适合网页界面的快速开发。layui 区别于那些基于 MVVM 底层的前端框架,却并非逆道而行,而是信奉返璞归真之道。准确地说,它更多是面向后端开发者,你无需涉足前端的各种工具,只需面对浏览器本身,让一切你所需要的元素与交互,从这里信手拈来。
|
||||||
@ -66,7 +60,7 @@ layui.use(['layer', 'form'], function(){
|
|||||||
```
|
```
|
||||||
|
|
||||||
## 阅读文档
|
## 阅读文档
|
||||||
[**最新文档**](https://layui.gitee.io/)
|
[**最新文档**](https://layui.github.io/)
|
||||||
|
|
||||||
愿 layui 能成为你得心应手的 Web 界面解决方案,化作你方寸屏幕前的亿万字节!
|
愿 layui 能成为你得心应手的 Web 界面解决方案,化作你方寸屏幕前的亿万字节!
|
||||||
|
|
||||||
|
2
dist/css/layui.css
vendored
2
dist/css/layui.css
vendored
File diff suppressed because one or more lines are too long
2
dist/layui.js
vendored
2
dist/layui.js
vendored
File diff suppressed because one or more lines are too long
@ -199,6 +199,8 @@ layui.use('laydate', function(laydate){
|
|||||||
,type: 'year'
|
,type: 'year'
|
||||||
//,range: true
|
//,range: true
|
||||||
//,trigger: 'click'
|
//,trigger: 'click'
|
||||||
|
//,min:'2021-01-01'
|
||||||
|
//,max:'2022-12-31'
|
||||||
,done: function(value, date, endDate){
|
,done: function(value, date, endDate){
|
||||||
console.log(value, date, endDate);
|
console.log(value, date, endDate);
|
||||||
}
|
}
|
||||||
@ -213,7 +215,8 @@ layui.use('laydate', function(laydate){
|
|||||||
,type: 'month'
|
,type: 'month'
|
||||||
,range: true
|
,range: true
|
||||||
,trigger: 'click'
|
,trigger: 'click'
|
||||||
//,max: -30
|
,min:'2022-03-01'
|
||||||
|
,max:'2022-05-31'
|
||||||
,done: function(value, date, endDate){
|
,done: function(value, date, endDate){
|
||||||
console.log(value, date, endDate);
|
console.log(value, date, endDate);
|
||||||
}
|
}
|
||||||
|
@ -89,8 +89,8 @@ var runTest = function(run, $, layer){
|
|||||||
};
|
};
|
||||||
window.jQuery && runTest(1, window.jQuery, window.layer);
|
window.jQuery && runTest(1, window.jQuery, window.layer);
|
||||||
|
|
||||||
layui.use('layer', function(){
|
layui.use(['layer', 'util'], function(layer, util){
|
||||||
var $ = layui.jquery, layer = layui.layer;
|
var $ = layui.jquery;
|
||||||
//return
|
//return
|
||||||
|
|
||||||
var index = layer.msg('hello');
|
var index = layer.msg('hello');
|
||||||
@ -166,7 +166,7 @@ layui.use('layer', function(){
|
|||||||
layer.close(index);
|
layer.close(index);
|
||||||
layer.prompt({title: '随便写点啥,并确认', formType: 2}, function(text, index){
|
layer.prompt({title: '随便写点啥,并确认', formType: 2}, function(text, index){
|
||||||
layer.close(index);
|
layer.close(index);
|
||||||
layer.msg('演示完毕!您的口令:'+ pass +'<br>您最后写下了:'+text);
|
layer.msg('演示完毕!您的口令:'+ util.escape(pass) +'<br>您最后写下了:'+ util.escape(text));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,9 @@
|
|||||||
<div>模板</div>
|
<div>模板</div>
|
||||||
<textarea id="demoTPL1"><h1>{{ d.title }}</h1>
|
<textarea id="demoTPL1"><h1>{{ d.title }}</h1>
|
||||||
|
|
||||||
<p>转义 html:{{= d.desc }}</p>
|
<p>转义输出(HTML):{{ d.desc }}</p>
|
||||||
|
<p>转义输出(HTML):{{= d.desc }}</p>
|
||||||
|
<p>原始输出(HTML):{{- d.desc }}</p>
|
||||||
{{#}}
|
{{#}}
|
||||||
|
|
||||||
<div class="layui-section">
|
<div class="layui-section">
|
||||||
@ -69,7 +71,7 @@
|
|||||||
<textarea id="demoData1">
|
<textarea id="demoData1">
|
||||||
{
|
{
|
||||||
"title": "标题",
|
"title": "标题",
|
||||||
"desc": "<a href=\"\">一段描述</a>",
|
"desc": "<a href=\"\" style=\"color:blue;\">一段描述</a>",
|
||||||
"items": [
|
"items": [
|
||||||
{
|
{
|
||||||
"title": "list 1",
|
"title": "list 1",
|
||||||
@ -121,7 +123,7 @@
|
|||||||
|
|
||||||
<script type="type/html" template id="laytplTestTpl">
|
<script type="type/html" template id="laytplTestTpl">
|
||||||
{{# for(var i = 0; i < d.items.length; i++){ }}
|
{{# for(var i = 0; i < d.items.length; i++){ }}
|
||||||
第{{d.items[i].index}}个,Name: {{d.items[i].name}} Number: {{d.items[i].number}}
|
第{{= d.items[i].index }}个,Name: {{- d.items[i].name }} Number: {{= d.items[i].number }}
|
||||||
{{# } }}
|
{{# } }}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -111,12 +111,22 @@ layui.use(['table', 'dropdown'], function(){
|
|||||||
,layEvent: 'LAYTABLE_TIPS'
|
,layEvent: 'LAYTABLE_TIPS'
|
||||||
,icon: 'layui-icon-tips'
|
,icon: 'layui-icon-tips'
|
||||||
}]
|
}]
|
||||||
,cols: [[
|
,cols: !1 ? [[ //仅用于测试
|
||||||
|
{type: 'checkbox', fixed: 'left'}
|
||||||
|
,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true, totalRowText: '合计:'}
|
||||||
|
,{field:'username', title:'用户名', width:120, edit: 'text'}
|
||||||
|
,{field:'email', title:'邮箱', hide: 0, width:150, edit: 'text'}
|
||||||
|
,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
|
||||||
|
,{field:'city', title:'城市', width:120}
|
||||||
|
,{field:'sign', title:'签名'}
|
||||||
|
,{field: 'experience', title: '积分', width:80, sort: true, align:'center', totalRow: '{{ d.TOTAL_NUMS }} 😊'}
|
||||||
|
,{fixed: 'right', title:'操作', toolbar: '#barDemo', width:150}
|
||||||
|
]] : [[
|
||||||
{type: 'checkbox', fixed: 'left'}
|
{type: 'checkbox', fixed: 'left'}
|
||||||
,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true, totalRowText: '合计:'}
|
,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true, totalRowText: '合计:'}
|
||||||
,{field:'username', title:'用户名', width:120, edit: 'text', templet: '#usernameTpl'}
|
,{field:'username', title:'用户名', width:120, edit: 'text', templet: '#usernameTpl'}
|
||||||
,{field:'email', title:'邮箱', hide: 0, width:150, edit: 'text', templet: function(d){
|
,{field:'email', title:'邮箱', hide: 0, width:150, edit: 'text', templet: function(d){
|
||||||
return '<em>'+ d.email +'</em>'
|
return '<em>'+ layui.util.escape(d.email) +'</em>'
|
||||||
}}
|
}}
|
||||||
,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
|
,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
|
||||||
,{field:'city', title:'城市', width:120, templet: '#cityTpl', exportTemplet: function(d, obj){
|
,{field:'city', title:'城市', width:120, templet: '#cityTpl', exportTemplet: function(d, obj){
|
||||||
@ -212,7 +222,7 @@ layui.use(['table', 'dropdown'], function(){
|
|||||||
break;
|
break;
|
||||||
case 'getCheckData':
|
case 'getCheckData':
|
||||||
var data = checkStatus.data;
|
var data = checkStatus.data;
|
||||||
layer.alert(JSON.stringify(data));
|
layer.alert(layui.util.escape(JSON.stringify(data)));
|
||||||
break;
|
break;
|
||||||
case 'getCheckLength':
|
case 'getCheckLength':
|
||||||
var data = checkStatus.data;
|
var data = checkStatus.data;
|
||||||
|
@ -21,35 +21,15 @@
|
|||||||
<a href="table-static.html" class="layui-btn">静态表格</a>
|
<a href="table-static.html" class="layui-btn">静态表格</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script type="text/html" id="toolbarDemo">
|
<table class="layui-table" lay-data="{url:'json/table/demo2.json', page: true, limit: 6}" lay-filter="appendtest">
|
||||||
<div class="layui-btn-container">
|
<thead>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="getCheckData">获取选中行数据</button>
|
<tr>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="getCheckLength">获取选中数目</button>
|
<th lay-data="{checkbox:true, fixed:'left'}" rowspan="2"></th>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="getData">获取当前页所有数据</button>
|
<th lay-data="{field:'username', width:80}" rowspan="2">联系人</th>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="isAll">验证是否全选</button>
|
<th lay-data="{field:'amount', width:120}" rowspan="2">金额</th>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="reload">重载(保留初始参数)</button>
|
</tr>
|
||||||
<button class="layui-btn layui-btn-sm" lay-event="reload2">重载(不保留初始参数)</button>
|
</thead>
|
||||||
<button class="layui-btn layui-btn-sm" id="dropdown">
|
</table>
|
||||||
更多菜单
|
|
||||||
<i class="layui-icon layui-icon-down layui-font-12"></i>
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<table id="test" lay-filter="test"></table>
|
|
||||||
|
|
||||||
<div id="appendtest"></div>
|
|
||||||
<script type="text/html" id="TPL_appendtest">
|
|
||||||
<table class="layui-table" lay-data="{url:'json/table/demo2.json', page: true, limit: 6}" lay-filter="appendtest">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th lay-data="{checkbox:true, fixed:'left'}" rowspan="2"></th>
|
|
||||||
<th lay-data="{field:'username', width:80}" rowspan="2">联系人</th>
|
|
||||||
<th lay-data="{field:'amount', width:120}" rowspan="2">金额</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
</table>
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script type="text/html" id="barDemo">
|
<script type="text/html" id="barDemo">
|
||||||
<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
|
<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
|
||||||
@ -222,189 +202,6 @@ layui.use(['table', 'dropdown'], function(){
|
|||||||
//,height: 300
|
//,height: 300
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#appendtest').append($('#TPL_appendtest').html())
|
|
||||||
table.init('appendtest');
|
|
||||||
|
|
||||||
//渲染
|
|
||||||
window.ins1 = table.render({
|
|
||||||
elem: '#test'
|
|
||||||
,height: 400
|
|
||||||
//,width: 600
|
|
||||||
,title: '用户数据表'
|
|
||||||
,url: 'json/table/demo1.json'
|
|
||||||
//,size: 'lg'
|
|
||||||
,page: {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//,autoSort: false //是否自动排序。如果否,则由服务端排序
|
|
||||||
//,loading: false
|
|
||||||
,totalRow: true
|
|
||||||
,limit: 30
|
|
||||||
,toolbar: '#toolbarDemo'
|
|
||||||
,defaultToolbar: ['filter', 'exports', 'print', {
|
|
||||||
title: '帮助'
|
|
||||||
,layEvent: 'LAYTABLE_TIPS'
|
|
||||||
,icon: 'layui-icon-tips'
|
|
||||||
}]
|
|
||||||
,escape: true
|
|
||||||
,cols: [[
|
|
||||||
{type: 'checkbox', fixed: 'left'}
|
|
||||||
,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true, totalRowText: '合计:'}
|
|
||||||
,{field:'username', title:'用户名', width:120, edit: 'text', templet: '#usernameTpl'}
|
|
||||||
,{field:'email', title:'邮箱', hide: 0, width:150, edit: 'text', templet: function(d){
|
|
||||||
return '<em>'+ d.email +'</em>'
|
|
||||||
}}
|
|
||||||
,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
|
|
||||||
,{field:'city', title:'城市', width:120}
|
|
||||||
,{field:'sign', title:'签名'}
|
|
||||||
,{field:'experience', title:'积分', width:80, sort: true, totalRow: '{{ d.TOTAL_NUMS }} 分', templet: '<div>{{ d.experience }} 分</div>'}
|
|
||||||
,{field:'ip', title:'IP', width:120}
|
|
||||||
,{field:'logins', title:'登入次数', width:100, sort: true, totalRow: true}
|
|
||||||
,{field:'joinTime', title:'加入时间', width:120}
|
|
||||||
,{fixed: 'right', title:'操作', toolbar: '#barDemo', width:150}
|
|
||||||
]]
|
|
||||||
|
|
||||||
,initSort1: {
|
|
||||||
field: 'experience' //排序字段,对应 cols 设定的各字段名
|
|
||||||
,type: 'desc' //排序方式 asc: 升序、desc: 降序、null: 默认排序
|
|
||||||
}
|
|
||||||
|
|
||||||
,headers: {headers_token: 'sasasas'}
|
|
||||||
,where: $.extend({}, table.config.where, {
|
|
||||||
test: '渲染的 test'
|
|
||||||
,token: '渲染的 token'
|
|
||||||
,key: 'experience'
|
|
||||||
,order: 'asc'
|
|
||||||
})
|
|
||||||
|
|
||||||
,done: function(){
|
|
||||||
//下拉菜单
|
|
||||||
dropdown.render({
|
|
||||||
elem: '#dropdown' //可绑定在任意元素中,此处以上述按钮为例
|
|
||||||
,data: [{
|
|
||||||
id: 0,
|
|
||||||
title: '刷新'
|
|
||||||
}]
|
|
||||||
//菜单被点击的事件
|
|
||||||
,click: function(obj){
|
|
||||||
table.reload('test');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
,error: function(res, msg){
|
|
||||||
console.log(res, msg)
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
,response: {
|
|
||||||
statusName: 'status'
|
|
||||||
,statusCode: 200
|
|
||||||
}
|
|
||||||
,parseData: function(res){
|
|
||||||
return {
|
|
||||||
"status": res.status
|
|
||||||
,"msg": res.message
|
|
||||||
,"count": res.total
|
|
||||||
,"data": res.data.list
|
|
||||||
};
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
});
|
|
||||||
|
|
||||||
//排序事件
|
|
||||||
table.on('sort(test)', function(obj){
|
|
||||||
console.log(obj);
|
|
||||||
|
|
||||||
return;
|
|
||||||
layer.msg('服务端排序。order by '+ obj.field + ' ' + obj.type);
|
|
||||||
//服务端排序
|
|
||||||
table.reload('test', {
|
|
||||||
initSort: obj
|
|
||||||
//,page: {curr: 1} //重新从第一页开始
|
|
||||||
,where: { //重新请求服务端
|
|
||||||
key: obj.field //排序字段
|
|
||||||
,order: obj.type //排序方式
|
|
||||||
}
|
|
||||||
}, true);
|
|
||||||
});
|
|
||||||
|
|
||||||
//工具栏事件
|
|
||||||
table.on('toolbar(test)', function(obj){
|
|
||||||
var config = obj.config;
|
|
||||||
var checkStatus = table.checkStatus(config.id);
|
|
||||||
switch(obj.event){
|
|
||||||
case 'add':
|
|
||||||
layer.msg('添加');
|
|
||||||
break;
|
|
||||||
case 'update':
|
|
||||||
layer.msg('编辑');
|
|
||||||
break;
|
|
||||||
case 'delete':
|
|
||||||
layer.msg('删除');
|
|
||||||
break;
|
|
||||||
case 'getCheckData':
|
|
||||||
var data = checkStatus.data;
|
|
||||||
layer.alert(JSON.stringify(data));
|
|
||||||
break;
|
|
||||||
case 'getCheckLength':
|
|
||||||
var data = checkStatus.data;
|
|
||||||
layer.msg('选中了:'+ data.length + ' 个');
|
|
||||||
break;
|
|
||||||
case 'getData':
|
|
||||||
var getData = table.getData(obj.config.id);
|
|
||||||
console.log(getData);
|
|
||||||
layer.alert(JSON.stringify(getData));
|
|
||||||
break;
|
|
||||||
case 'isAll':
|
|
||||||
layer.msg(checkStatus.isAll ? '全选': '未全选')
|
|
||||||
break;
|
|
||||||
case 'LAYTABLE_TIPS':
|
|
||||||
layer.alert(config.title || 'Table for layui-v'+ layui.v);
|
|
||||||
break;
|
|
||||||
case 'reload':
|
|
||||||
//深度重载
|
|
||||||
var instReload = table.reload('test', {
|
|
||||||
|
|
||||||
where: {
|
|
||||||
abc: 123
|
|
||||||
,test: '重载的 test'
|
|
||||||
}
|
|
||||||
,page: {curr: 5, limit: 20}
|
|
||||||
,cols: ins1.config.cols
|
|
||||||
//,height: 300
|
|
||||||
//,url: 'x'
|
|
||||||
}, true);
|
|
||||||
break;
|
|
||||||
case 'reload2':
|
|
||||||
//浅重载
|
|
||||||
table.reload('test', {
|
|
||||||
where: {
|
|
||||||
efg: 'sasasas'
|
|
||||||
//,test: '新的 test2'
|
|
||||||
//,token: '新的 token2'
|
|
||||||
}
|
|
||||||
,cols: [[
|
|
||||||
{type: 'checkbox', fixed: 'left'}
|
|
||||||
,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true, totalRowText: '合计:'}
|
|
||||||
,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
|
|
||||||
,{field:'experience', title:'积分', width:80, sort: true, totalRow: true, templet: '<div>{{ d.experience }} 分</div>'}
|
|
||||||
,{field:'logins', title:'登入次数', width:100, sort: true, totalRow: true}
|
|
||||||
,{field:'joinTime', title:'加入时间', width:120}
|
|
||||||
]]
|
|
||||||
//,height: 500
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
table.on('row(test)', function(obj){
|
|
||||||
console.log(obj);
|
|
||||||
//layer.closeAll('tips');
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
table.render({
|
table.render({
|
||||||
elem: '#test2'
|
elem: '#test2'
|
||||||
|
@ -98,7 +98,7 @@ layui.use(['upload', 'element'], function(){
|
|||||||
|
|
||||||
var uploadInst = upload.render({
|
var uploadInst = upload.render({
|
||||||
elem: '#test1'
|
elem: '#test1'
|
||||||
,url: 'http://httpbin.org/post'
|
,url: 'https://httpbin.org/post'
|
||||||
//,size: 2000 //限制文件大小,单位 KB
|
//,size: 2000 //限制文件大小,单位 KB
|
||||||
//,accept: 'file'
|
//,accept: 'file'
|
||||||
,method: 'get'
|
,method: 'get'
|
||||||
@ -110,8 +110,8 @@ layui.use(['upload', 'element'], function(){
|
|||||||
return 2
|
return 2
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
,choose: function(){
|
,choose: function(obj){
|
||||||
|
console.log('choose', obj);
|
||||||
}
|
}
|
||||||
,before: function(obj){
|
,before: function(obj){
|
||||||
//预读本地文件示例,不支持ie8
|
//预读本地文件示例,不支持ie8
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "layui",
|
"name": "layui",
|
||||||
"realname": "layui",
|
"realname": "layui",
|
||||||
"version": "2.6.10",
|
"version": "2.6.11",
|
||||||
"description": "Classic modular Front-End UI library",
|
"description": "Classic modular Front-End UI library",
|
||||||
"main": "dist/layui.js",
|
"main": "dist/layui.js",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
@ -243,7 +243,7 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
.layui-icon-music:before{content:"\e690"}
|
.layui-icon-music:before{content:"\e690"}
|
||||||
|
|
||||||
/* 基本布局 */
|
/* 基本布局 */
|
||||||
.layui-main{position: relative; width: 1140px; margin: 0 auto;}
|
.layui-main{position: relative; width: 1160px; margin: 0 auto;}
|
||||||
.layui-header{position: relative; z-index: 1000; height: 60px;}
|
.layui-header{position: relative; z-index: 1000; height: 60px;}
|
||||||
.layui-header a:hover{transition: all .5s; -webkit-transition: all .5s;}
|
.layui-header a:hover{transition: all .5s; -webkit-transition: all .5s;}
|
||||||
.layui-side{position: fixed; left: 0; top: 0; bottom: 0; z-index: 999; width: 200px; overflow-x: hidden;}
|
.layui-side{position: fixed; left: 0; top: 0; bottom: 0; z-index: 999; width: 200px; overflow-x: hidden;}
|
||||||
@ -264,7 +264,7 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
|
|
||||||
|
|
||||||
/* 栅格布局 */
|
/* 栅格布局 */
|
||||||
.layui-container{position: relative; margin: 0 auto; padding: 0 15px; box-sizing: border-box;}
|
.layui-container{position: relative; margin: 0 auto; box-sizing: border-box;}
|
||||||
.layui-fluid{position: relative; margin: 0 auto; padding: 0 15px;}
|
.layui-fluid{position: relative; margin: 0 auto; padding: 0 15px;}
|
||||||
|
|
||||||
.layui-row:before, .layui-row:after{content: ""; display: block; clear: both;}
|
.layui-row:before, .layui-row:after{content: ""; display: block; clear: both;}
|
||||||
@ -302,7 +302,8 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
.layui-col-xs-offset12{margin-left: 100%;}
|
.layui-col-xs-offset12{margin-left: 100%;}
|
||||||
|
|
||||||
/* 超小屏幕(手机) */
|
/* 超小屏幕(手机) */
|
||||||
@media screen and (max-width: 768px) {
|
@media screen and (max-width: 767.98px) {
|
||||||
|
.layui-container{padding: 0 15px;}
|
||||||
.layui-hide-xs{display: none!important;}
|
.layui-hide-xs{display: none!important;}
|
||||||
.layui-show-xs-block{display: block!important;}
|
.layui-show-xs-block{display: block!important;}
|
||||||
.layui-show-xs-inline{display: inline!important;}
|
.layui-show-xs-inline{display: inline!important;}
|
||||||
@ -311,7 +312,7 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
|
|
||||||
/* 小型屏幕(平板) */
|
/* 小型屏幕(平板) */
|
||||||
@media screen and (min-width: 768px) {
|
@media screen and (min-width: 768px) {
|
||||||
.layui-container{width: 750px;}
|
.layui-container{width: 720px;}
|
||||||
.layui-hide-sm{display: none!important;}
|
.layui-hide-sm{display: none!important;}
|
||||||
.layui-show-sm-block{display: block!important;}
|
.layui-show-sm-block{display: block!important;}
|
||||||
.layui-show-sm-inline{display: inline!important;}
|
.layui-show-sm-inline{display: inline!important;}
|
||||||
@ -346,7 +347,7 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
}
|
}
|
||||||
/* 中型屏幕(桌面) */
|
/* 中型屏幕(桌面) */
|
||||||
@media screen and (min-width: 992px) {
|
@media screen and (min-width: 992px) {
|
||||||
.layui-container{width: 970px;}
|
.layui-container{width: 960px;}
|
||||||
.layui-hide-md{display: none!important;}
|
.layui-hide-md{display: none!important;}
|
||||||
.layui-show-md-block{display: block!important;}
|
.layui-show-md-block{display: block!important;}
|
||||||
.layui-show-md-inline{display: inline!important;}
|
.layui-show-md-inline{display: inline!important;}
|
||||||
@ -381,7 +382,7 @@ a cite{font-style: normal; *cursor:pointer;}
|
|||||||
}
|
}
|
||||||
/* 大型屏幕(桌面) */
|
/* 大型屏幕(桌面) */
|
||||||
@media screen and (min-width: 1200px) {
|
@media screen and (min-width: 1200px) {
|
||||||
.layui-container{width: 1170px;}
|
.layui-container{width: 1150px;}
|
||||||
.layui-hide-lg{display: none!important;}
|
.layui-hide-lg{display: none!important;}
|
||||||
.layui-show-lg-block{display: block!important;}
|
.layui-show-lg-block{display: block!important;}
|
||||||
.layui-show-lg-inline{display: inline!important;}
|
.layui-show-lg-inline{display: inline!important;}
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
,Layui = function(){
|
,Layui = function(){
|
||||||
this.v = '2.6.10'; // layui 版本号
|
this.v = '2.6.11'; // layui 版本号
|
||||||
}
|
}
|
||||||
|
|
||||||
//识别预先可能定义的指定全局对象
|
//识别预先可能定义的指定全局对象
|
||||||
|
@ -917,7 +917,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//通过检测当前有效日期,来设定确定按钮是否可点
|
//通过检测当前有效日期,来设定确定按钮是否可点
|
||||||
if(!options.range) that.limit(lay(that.footer).find(ELEM_CONFIRM), null, 0, ['hours', 'minutes', 'seconds']);
|
if(!options.range){
|
||||||
|
that.limit(lay(that.footer).find(ELEM_CONFIRM), null, 0, ['hours', 'minutes', 'seconds']);
|
||||||
|
}
|
||||||
|
|
||||||
//同步按钮可点状态
|
//同步按钮可点状态
|
||||||
that.setBtnStatus();
|
that.setBtnStatus();
|
||||||
@ -960,10 +962,18 @@
|
|||||||
lay.each(new Array(15), function(i){
|
lay.each(new Array(15), function(i){
|
||||||
var li = lay.elem('li', {
|
var li = lay.elem('li', {
|
||||||
'lay-ym': yearNum
|
'lay-ym': yearNum
|
||||||
}), ymd = {year: yearNum};
|
})
|
||||||
|
,ymd = {
|
||||||
|
year: yearNum
|
||||||
|
,month: 0
|
||||||
|
,date: 1
|
||||||
|
};
|
||||||
|
|
||||||
yearNum == listYM[0] && lay(li).addClass(THIS);
|
yearNum == listYM[0] && lay(li).addClass(THIS);
|
||||||
li.innerHTML = yearNum + text;
|
li.innerHTML = yearNum + text;
|
||||||
ul.appendChild(li);
|
ul.appendChild(li);
|
||||||
|
|
||||||
|
/*
|
||||||
if(yearNum < that.firstDate.year){
|
if(yearNum < that.firstDate.year){
|
||||||
ymd.month = options.min.month;
|
ymd.month = options.min.month;
|
||||||
ymd.date = options.min.date;
|
ymd.date = options.min.date;
|
||||||
@ -971,9 +981,12 @@
|
|||||||
ymd.month = options.max.month;
|
ymd.month = options.max.month;
|
||||||
ymd.date = options.max.date;
|
ymd.date = options.max.date;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
that.limit(lay(li), ymd, index);
|
that.limit(lay(li), ymd, index);
|
||||||
yearNum++;
|
yearNum++;
|
||||||
});
|
});
|
||||||
|
|
||||||
lay(elemYM[isCN ? 0 : 1]).attr('lay-ym', (yearNum - 8) + '-' + listYM[1])
|
lay(elemYM[isCN ? 0 : 1]).attr('lay-ym', (yearNum - 8) + '-' + listYM[1])
|
||||||
.html((startY + text) + ' - ' + (yearNum - 1 + text));
|
.html((startY + text) + ' - ' + (yearNum - 1 + text));
|
||||||
}
|
}
|
||||||
@ -983,17 +996,28 @@
|
|||||||
lay.each(new Array(12), function(i){
|
lay.each(new Array(12), function(i){
|
||||||
var li = lay.elem('li', {
|
var li = lay.elem('li', {
|
||||||
'lay-ym': i
|
'lay-ym': i
|
||||||
}), ymd = {year: listYM[0], month: i};
|
})
|
||||||
|
,ymd = {
|
||||||
|
year: listYM[0]
|
||||||
|
,month: i
|
||||||
|
,date: 1
|
||||||
|
};
|
||||||
|
|
||||||
i + 1 == listYM[1] && lay(li).addClass(THIS);
|
i + 1 == listYM[1] && lay(li).addClass(THIS);
|
||||||
li.innerHTML = lang.month[i] + (isCN ? '月' : '');
|
li.innerHTML = lang.month[i] + (isCN ? '月' : '');
|
||||||
ul.appendChild(li);
|
ul.appendChild(li);
|
||||||
|
|
||||||
|
/*
|
||||||
if(listYM[0] < that.firstDate.year){
|
if(listYM[0] < that.firstDate.year){
|
||||||
ymd.date = options.min.date;
|
ymd.date = options.min.date;
|
||||||
} else if(listYM[0] >= that.firstDate.year){
|
} else if(listYM[0] >= that.firstDate.year){
|
||||||
ymd.date = options.max.date;
|
ymd.date = options.max.date;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
that.limit(lay(li), ymd, index);
|
that.limit(lay(li), ymd, index);
|
||||||
});
|
});
|
||||||
|
|
||||||
lay(elemYM[isCN ? 0 : 1]).attr('lay-ym', listYM[0] + '-' + listYM[1])
|
lay(elemYM[isCN ? 0 : 1]).attr('lay-ym', listYM[0] + '-' + listYM[1])
|
||||||
.html(listYM[0] + text);
|
.html(listYM[0] + text);
|
||||||
}
|
}
|
||||||
@ -1016,7 +1040,9 @@
|
|||||||
}][i], index, [['hours'], ['hours', 'minutes'], ['hours', 'minutes', 'seconds']][i]);
|
}][i], index, [['hours'], ['hours', 'minutes'], ['hours', 'minutes', 'seconds']][i]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
if(!options.range) that.limit(lay(that.footer).find(ELEM_CONFIRM), that[startEnd], 0, ['hours', 'minutes', 'seconds']);
|
if(!options.range){
|
||||||
|
that.limit(lay(that.footer).find(ELEM_CONFIRM), that[startEnd], 0, ['hours', 'minutes', 'seconds']);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
//初始化时间对象
|
//初始化时间对象
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
layui.define(function(exports){
|
layui.define(function(exports){
|
||||||
|
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
@ -24,8 +23,15 @@ layui.define(function(exports){
|
|||||||
return exp((_||'') + config.open + types + config.close + (__||''));
|
return exp((_||'') + config.open + types + config.close + (__||''));
|
||||||
},
|
},
|
||||||
escape: function(html){
|
escape: function(html){
|
||||||
return String(html||'').replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&')
|
var exp = /[<"'>]|&(?=#[a-zA-Z0-9]+)/g;
|
||||||
.replace(/</g, '<').replace(/>/g, '>').replace(/'/g, ''').replace(/"/g, '"');
|
if(html === undefined || html === null) return '';
|
||||||
|
|
||||||
|
html += '';
|
||||||
|
if(!exp.test(html)) return html;
|
||||||
|
|
||||||
|
return html.replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&')
|
||||||
|
.replace(/</g, '<').replace(/>/g, '>')
|
||||||
|
.replace(/'/g, ''').replace(/"/g, '"');
|
||||||
},
|
},
|
||||||
error: function(e, tplog){
|
error: function(e, tplog){
|
||||||
var error = 'Laytpl Error: ';
|
var error = 'Laytpl Error: ';
|
||||||
@ -61,22 +67,24 @@ layui.define(function(exports){
|
|||||||
return str
|
return str
|
||||||
})
|
})
|
||||||
|
|
||||||
//匹配JS规则内容
|
//匹配 JS 语法
|
||||||
.replace(/(?="|')/g, '\\').replace(tool.query(), function(str){
|
.replace(/(?="|')/g, '\\').replace(tool.query(), function(str){
|
||||||
str = str.replace(jss, '').replace(jsse, '');
|
str = str.replace(jss, '').replace(jsse, '');
|
||||||
return '";' + str.replace(/\\(.)/g, '$1') + ';view+="';
|
return '";' + str.replace(/\\(.)/g, '$1') + ';view+="';
|
||||||
})
|
})
|
||||||
|
|
||||||
//匹配普通字段
|
//匹配普通输出语句
|
||||||
.replace(tool.query(1), function(str){
|
.replace(tool.query(1), function(str){
|
||||||
var start = '"+(';
|
var start = '"+laytpl.escape(';
|
||||||
if(str.replace(/\s/g, '') === config.open+config.close){
|
if(str.replace(/\s/g, '') === config.open+config.close){
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
str = str.replace(exp(config.open+'|'+config.close), '');
|
str = str.replace(exp(config.open+'|'+config.close), '');
|
||||||
if(/^=/.test(str)){
|
if(/^=/.test(str)){
|
||||||
str = str.replace(/^=/, '');
|
str = str.replace(/^=/, '');
|
||||||
start = '"+laytpl.escape(';
|
} else if(/^-/.test(str)){
|
||||||
|
str = str.replace(/^-/, '');
|
||||||
|
start = '"+(';
|
||||||
}
|
}
|
||||||
return start + str.replace(/\\(.)/g, '$1') + ')+"';
|
return start + str.replace(/\\(.)/g, '$1') + ')+"';
|
||||||
});
|
});
|
||||||
|
@ -77,7 +77,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
|
|||||||
,item3 = obj.item3 //表头数据
|
,item3 = obj.item3 //表头数据
|
||||||
,content = obj.content; //原始内容
|
,content = obj.content; //原始内容
|
||||||
|
|
||||||
//是否防 xss
|
//是否编码 HTML
|
||||||
if(options.escape) content = util.escape(content);
|
if(options.escape) content = util.escape(content);
|
||||||
|
|
||||||
//获取模板
|
//获取模板
|
||||||
@ -249,6 +249,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
|
|||||||
Class.prototype.config = {
|
Class.prototype.config = {
|
||||||
limit: 10 //每页显示的数量
|
limit: 10 //每页显示的数量
|
||||||
,loading: true //请求数据时,是否显示 loading
|
,loading: true //请求数据时,是否显示 loading
|
||||||
|
,escape: true // 是否开启 HTML 编码功能,即转义 html 原文
|
||||||
,cellMinWidth: 60 //所有单元格默认最小宽度
|
,cellMinWidth: 60 //所有单元格默认最小宽度
|
||||||
,defaultToolbar: ['filter', 'exports', 'print'] //工具栏右侧图标
|
,defaultToolbar: ['filter', 'exports', 'print'] //工具栏右侧图标
|
||||||
,autoSort: true //是否前端自动排序。如果否,则需自主排序(通常为服务端处理好排序)
|
,autoSort: true //是否前端自动排序。如果否,则需自主排序(通常为服务端处理好排序)
|
||||||
@ -1546,21 +1547,19 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
|
|||||||
if(key in data) data[key] = value;
|
if(key in data) data[key] = value;
|
||||||
|
|
||||||
that.eachCols(function(i, item3){
|
that.eachCols(function(i, item3){
|
||||||
var templet = item3.templet || item3.toolbar;
|
|
||||||
|
|
||||||
//更新相应列视图
|
//更新相应列视图
|
||||||
if(item3.field == key && item3.templet){
|
if(item3.field == key){
|
||||||
cell.html(parseTempData.call(that, {
|
cell.html(parseTempData.call(that, {
|
||||||
item3: {templet: item3.templet}
|
item3: item3
|
||||||
,content: value
|
,content: value
|
||||||
,tplData: data
|
,tplData: data
|
||||||
}));
|
}));
|
||||||
td.data('content', value);
|
td.data('content', value);
|
||||||
} else if(templet){ //更新所有其他列的模板
|
} else if(item3.templet || item3.toolbar){ //更新所有其他列的模板
|
||||||
var thisTd = tr.children('td[data-field="'+ (item3.field || i) +'"]')
|
var thisTd = tr.children('td[data-field="'+ (item3.field || i) +'"]')
|
||||||
,content = data[item3.field];
|
,content = data[item3.field];
|
||||||
thisTd.children(ELEM_CELL).html(parseTempData.call(that, {
|
thisTd.children(ELEM_CELL).html(parseTempData.call(that, {
|
||||||
item3: {templet: templet}
|
item3: item3
|
||||||
,content: content
|
,content: content
|
||||||
,tplData: data
|
,tplData: data
|
||||||
}));
|
}));
|
||||||
@ -1663,7 +1662,7 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
|
|||||||
,field: field
|
,field: field
|
||||||
}));
|
}));
|
||||||
}).on('blur', '.'+ELEM_EDIT, function(){
|
}).on('blur', '.'+ELEM_EDIT, function(){
|
||||||
var templet
|
var item3
|
||||||
,othis = $(this)
|
,othis = $(this)
|
||||||
,thisElem = this
|
,thisElem = this
|
||||||
,field = othis.parent().data('field')
|
,field = othis.parent().data('field')
|
||||||
@ -1671,12 +1670,12 @@ layui.define(['laytpl', 'laypage', 'layer', 'form', 'util'], function(exports){
|
|||||||
,data = table.cache[that.key][index];
|
,data = table.cache[that.key][index];
|
||||||
that.eachCols(function(i, item){
|
that.eachCols(function(i, item){
|
||||||
if(item.field == field && item.templet){
|
if(item.field == field && item.templet){
|
||||||
templet = item.templet;
|
item3 = item;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
othis.siblings(ELEM_CELL).html(function(value){
|
othis.siblings(ELEM_CELL).html(function(value){
|
||||||
return parseTempData.call(that, {
|
return parseTempData.call(that, {
|
||||||
item3: {templet: templet}
|
item3: item3 || {}
|
||||||
,content: value
|
,content: value
|
||||||
,tplData: data
|
,tplData: data
|
||||||
});
|
});
|
||||||
|
@ -169,10 +169,14 @@ layui.define('jquery', function(exports){
|
|||||||
.replace(/ss/g, hms[2]);
|
.replace(/ss/g, hms[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
//转义 html,防 xss 攻击
|
//转义 html
|
||||||
,escape: function(html){
|
,escape: function(html){
|
||||||
if(html === undefined || html === null) html = '';
|
var exp = /[<"'>]|&(?=#[a-zA-Z0-9]+)/g;
|
||||||
|
if(html === undefined || html === null) return '';
|
||||||
|
|
||||||
html += '';
|
html += '';
|
||||||
|
if(!exp.test(html)) return html;
|
||||||
|
|
||||||
return html.replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&')
|
return html.replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&')
|
||||||
.replace(/</g, '<').replace(/>/g, '>')
|
.replace(/</g, '<').replace(/>/g, '>')
|
||||||
.replace(/'/g, ''').replace(/"/g, '"');
|
.replace(/'/g, ''').replace(/"/g, '"');
|
||||||
@ -182,6 +186,7 @@ layui.define('jquery', function(exports){
|
|||||||
,unescape: function(html){
|
,unescape: function(html){
|
||||||
if(html === undefined || html === null) html = '';
|
if(html === undefined || html === null) html = '';
|
||||||
html += '';
|
html += '';
|
||||||
|
|
||||||
return html.replace(/\&/g, '&')
|
return html.replace(/\&/g, '&')
|
||||||
.replace(/\</g, '<').replace(/\>/g, '>')
|
.replace(/\</g, '<').replace(/\>/g, '>')
|
||||||
.replace(/\'/, '\'').replace(/\"/, '"');
|
.replace(/\'/, '\'').replace(/\"/, '"');
|
||||||
@ -248,6 +253,6 @@ layui.define('jquery', function(exports){
|
|||||||
!function(a,b,c){"$:nomunge";function l(){f=b[g](function(){d.each(function(){var b=a(this),c=b.width(),d=b.height(),e=a.data(this,i);(c!==e.w||d!==e.h)&&b.trigger(h,[e.w=c,e.h=d])}),l()},e[j])}var f,d=a([]),e=a.resize=a.extend(a.resize,{}),g="setTimeout",h="resize",i=h+"-special-event",j="delay",k="throttleWindow";e[j]=250,e[k]=!0,a.event.special[h]={setup:function(){if(!e[k]&&this[g])return!1;var b=a(this);d=d.add(b),a.data(this,i,{w:b.width(),h:b.height()}),1===d.length&&l()},teardown:function(){if(!e[k]&&this[g])return!1;var b=a(this);d=d.not(b),b.removeData(i),d.length||clearTimeout(f)},add:function(b){function f(b,e,f){var g=a(this),h=a.data(this,i)||{};h.w=e!==c?e:g.width(),h.h=f!==c?f:g.height(),d.apply(this,arguments)}if(!e[k]&&this[g])return!1;var d;return a.isFunction(b)?(d=b,f):(d=b.handler,b.handler=f,void 0)}}}($,window);
|
!function(a,b,c){"$:nomunge";function l(){f=b[g](function(){d.each(function(){var b=a(this),c=b.width(),d=b.height(),e=a.data(this,i);(c!==e.w||d!==e.h)&&b.trigger(h,[e.w=c,e.h=d])}),l()},e[j])}var f,d=a([]),e=a.resize=a.extend(a.resize,{}),g="setTimeout",h="resize",i=h+"-special-event",j="delay",k="throttleWindow";e[j]=250,e[k]=!0,a.event.special[h]={setup:function(){if(!e[k]&&this[g])return!1;var b=a(this);d=d.add(b),a.data(this,i,{w:b.width(),h:b.height()}),1===d.length&&l()},teardown:function(){if(!e[k]&&this[g])return!1;var b=a(this);d=d.not(b),b.removeData(i),d.length||clearTimeout(f)},add:function(b){function f(b,e,f){var g=a(this),h=a.data(this,i)||{};h.w=e!==c?e:g.width(),h.h=f!==c?f:g.height(),d.apply(this,arguments)}if(!e[k]&&this[g])return!1;var d;return a.isFunction(b)?(d=b,f):(d=b.handler,b.handler=f,void 0)}}}($,window);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//暴露接口
|
// 输出接口
|
||||||
exports('util', util);
|
exports('util', util);
|
||||||
});
|
});
|
Loading…
Reference in New Issue
Block a user