本文最后更新于 2022年6月29日 中午
事件和选择器
1 2 3 4 5 6 7
| $("p")
$("#test")
$(".test")
|
1 2 3 4 5 6 7 8
| $("p").click(function(){ });
$("p").on("click",function(){ alert("段落被点击了。"); });
|
$(selector).on(event,childSelector,data,function)
参数 |
描述 |
event |
必需。规定要从被选元素添加的一个或多个事件或命名空间。 由空格分隔多个事件值,也可以是数组。必须是有效的事件。 |
childSelector |
可选。规定只能添加到指定的子元素上的事件处理程序(且不是选择器本身,比如已废弃的 delegate() 方法)。 |
data |
可选。规定传递到函数的额外数据。 |
function |
可选。规定当事件发生时运行的函数。 |
Ajax 执行异步的 HTTP 请求方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| $.ajax({ type: "get", async: true, url: '', dataType: "json", data: {}, contentType: "application/json;charset=UTF-8", success: function(res) { }, error: function(err) { console.log(err) }, complete: function(res) { reload(); } })
|
下面的表格中列出了可能的名称/值:
名称 |
值/描述 |
async |
布尔值,表示请求是否异步处理。默认是 true。 |
beforeSend(xhr) |
发送请求前运行的函数。 |
cache |
布尔值,表示浏览器是否缓存被请求页面。默认是 true。 |
complete(xhr,status) |
请求完成时运行的函数(在请求成功或失败之后均调用,即在 success 和 error 函数之后)。 |
contentType |
发送数据到服务器时所使用的内容类型。默认是:”application/x-www-form-urlencoded”。 |
context |
为所有 AJAX 相关的回调函数规定 “this” 值。 |
data |
规定要发送到服务器的数据。 |
dataFilter(data,type) |
用于处理 XMLHttpRequest 原始响应数据的函数。 |
dataType |
预期的服务器响应的数据类型。 |
error(xhr,status,error) |
如果请求失败要运行的函数。 |
global |
布尔值,规定是否为请求触发全局 AJAX 事件处理程序。默认是 true。 |
ifModified |
布尔值,规定是否仅在最后一次请求以来响应发生改变时才请求成功。默认是 false。 |
jsonp |
在一个 jsonp 中重写回调函数的字符串。 |
jsonpCallback |
在一个 jsonp 中规定回调函数的名称。 |
password |
规定在 HTTP 访问认证请求中使用的密码。 |
processData |
布尔值,规定通过请求发送的数据是否转换为查询字符串。默认是 true。 |
scriptCharset |
规定请求的字符集。 |
success(result,status,xhr) |
当请求成功时运行的函数。 |
timeout |
设置本地的请求超时时间(以毫秒计)。 |
traditional |
布尔值,规定是否使用参数序列化的传统样式。 |
type |
规定请求的类型(GET 或 POST)。 |
url |
规定发送请求的 URL。默认是当前页面。 |
username |
规定在 HTTP 访问认证请求中使用的用户名。 |
xhr |
用于创建 XMLHttpRequest 对象的函数。 |
Layer 弹出层组件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
| 特别说明: 事件需自己绑定,以下只展现调用代码。
layer.alert('内容')
layer.confirm('您是如何看待前端开发?', { btn: ['重要','奇葩'] }, function(){ layer.msg('的确很重要', {icon: 1}); }, function(){ layer.msg('也可以这样', { time: 20000, btn: ['明白了', '知道了'] }); });
layer.msg('一段提示信息');
layer.alert('墨绿风格,点击确认看深蓝', { skin: 'layui-layer-molv' ,closeBtn: 0 }, function(){ layer.alert('偶吧深蓝style', { skin: 'layui-layer-lan' ,closeBtn: 0 ,anim: 4 }); });
layer.open({ type: 1, shade: false, title: false, content: $('.layer_notice'), cancel: function(){ layer.msg('捕获就是从页面已经存在的元素上,包裹layer的结构', {time: 5000, icon:6}); } });
layer.open({ type: 1, skin: 'layui-layer-rim', area: ['420px', '240px'], content: 'html内容' });
layer.open({ type: 1, skin: 'layui-layer-demo', closeBtn: 0, anim: 2, shadeClose: true, content: '内容' });
layer.tips('Hi,我是tips', '吸附元素选择器,如#id');
layer.open({ type: 2, title: 'layer mobile页', shadeClose: true, shade: 0.8, area: ['380px', '90%'], content: 'mobile/' });
layer.open({ type: 2, title: '很多时候,我们想最大化看,比如像这个页面。', shadeClose: true, shade: false, maxmin: true, area: ['893px', '600px'], content: 'https://layui.jianwoo.cn' });
var index = layer.load(0, {shade: false});
var index = layer.load(1, { shade: [0.1,'#fff'] });
layer.tips('我是另外一个tips,只不过我长得跟之前那位稍有些不一样。', '吸附元素选择器', { tips: [1, '#3595CC'], time: 4000 });
layer.prompt({title: '输入任何口令,并确认', formType: 1}, function(pass, index){ layer.close(index); layer.prompt({title: '随便写点啥,并确认', formType: 2}, function(text, index){ layer.close(index); layer.msg('演示完毕!您的口令:'+ pass +'<br>您最后写下了:'+text); }); });
layer.tab({ area: ['600px', '300px'], tab: [{ title: 'TAB1', content: '内容1' }, { title: 'TAB2', content: '内容2' }, { title: 'TAB3', content: '内容3' }] });
$.getJSON('test/photos.json?v='+new Date, function(json){ layer.photos({ photos: json ,anim: 5 }); });
layer.alert('在标题栏显示自动关闭倒计秒数', { time: 5*1000 ,success: function(layero, index){ var timeNum = this.time/1000, setText = function(start){ layer.title((start ? timeNum : --timeNum) + ' 秒后关闭', index); }; setText(!0); this.timer = setInterval(setText, 1000); if(timeNum <= 0) clearInterval(this.timer); } ,end: function(){ clearInterval(this.timer); } });
|
Layui 表格
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
| <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>table模块快速使用</title> <link rel="stylesheet" href="/layui/css/layui.css" media="all"> </head> <body> <table id="demo" lay-filter="test"></table> <script src="/layui/layui.js"></script> <script> layui.use('table', function(){ var table = layui.table; table.render({ elem: '#demo' ,height: 312 ,url: '../../demo/table/user/-page=1&limit=30.js' ,page: true ,cols: [[ {field: 'id', title: 'ID', width:80, sort: true, fixed: 'left'} ,{field: 'username', title: '用户名', width:80} ,{field: 'sex', title: '性别', width:80, sort: true} ,{field: 'city', title: '城市', width:80} ,{field: 'sign', title: '签名', width: 177} ,{field: 'experience', title: '积分', width: 80, sort: true} ,{field: 'score', title: '评分', width: 80, sort: true} ,{field: 'classify', title: '职业', width: 80} ,{field: 'wealth', title: '财富', width: 135, sort: true} ]] }); }); </script> </body> </html>
|
下面是目前 table 模块所支持的全部参数一览表,我们对重点参数进行了的详细说明,你可以点击下述表格最右侧的“示例”去查看
参数 |
类型 |
说明 |
示例值 |
elem |
String/DOM |
指定原始 table 容器的选择器或 DOM,方法渲染方式必填 |
“#demo” |
cols |
Array |
设置表头。值是一个二维数组。方法渲染方式必填 |
详见表头参数 |
url(等) |
- |
异步数据接口相关参数。其中 url 参数为必填项 |
详见异步参数 |
toolbar |
String/DOM/Boolean |
开启表格头部工具栏区域,该参数支持四种类型值:toolbar: ‘#toolbarDemo’ //指向自定义工具栏模板选择器toolbar: ‘ xxx ‘ //直接传入工具栏模板字符toolbar: true //仅开启工具栏,不显示左侧模板toolbar: ‘default’ //让工具栏左侧显示默认的内置模板注意: 1. 该参数为 layui 2.4.0 开始新增。 2. 若需要“列显示隐藏”、“导出”、“打印”等功能,则必须开启该参数 |
false |
defaultToolbar |
Array |
该参数可自由配置头部工具栏右侧的图标按钮 |
详见头工具栏图标 |
width |
Number |
设定容器宽度。table容器的默认宽度是跟随它的父元素铺满,你也可以设定一个固定值,当容器中的内容超出了该宽度时,会自动出现横向滚动条。 |
1000 |
height |
Number/String |
设定容器高度 |
详见height |
cellMinWidth |
Number |
(layui 2.2.1 新增)全局定义所有常规单元格的最小宽度(默认:60),一般用于列宽自动分配的情况。其优先级低于表头参数中的 minWidth |
100 |
done |
Function |
数据渲染完的回调。你可以借此做一些其它的操作 |
详见 done 回调 |
error |
Function |
数据请求失败的回调,返回两个参数:错误对象、内容 layui 2.6.0 新增 |
- |
data |
Array |
直接赋值数据。既适用于只展示一页数据,也非常适用于对一段已知数据进行多页展示。 |
[{}, {}, {}, {}, …] |
escape |
Boolean |
是否开启 xss 字符过滤(默认 false)layui 2.6.8 新增 |
true |
totalRow |
Boolean/String |
是否开启合计行区域 |
false |
page |
Boolean/Object |
开启分页(默认:false)。支持传入一个对象,里面可包含 laypage 组件所有支持的参数(jump、elem除外) |
{theme: ‘#c00’} |
limit |
Number |
每页显示的条数(默认 10)。值需对应 limits 参数的选项。 注意:优先级低于 page 参数中的 limit 参数 |
30 |
limits |
Array |
每页条数的选择项,默认:[10,20,30,40,50,60,70,80,90]。 注意:优先级低于 page 参数中的 limits 参数 |
[30,60,90] |
loading |
Boolean |
是否显示加载条(默认 true)。若为 false,则在切换分页时,不会出现加载条。该参数只适用于 url 参数开启的方式 |
false |
title |
String |
定义 table 的大标题(在文件导出等地方会用到) |
“用户表” |
text |
Object |
自定义文本,如空数据时的异常提示等。 |
详见自定义文本 |
autoSort |
Boolean |
默认 true,即直接由 table 组件在前端自动处理排序。 若为 false,则需自主排序,即由服务端返回排序好的数据 |
详见事件排序 |
initSort |
Object |
初始排序状态。 用于在数据表格渲染完毕时,默认按某个字段排序。 |
详见初始排序 |
id |
String |
设定容器唯一 id。id 是对表格的数据操作方法上是必要的传递条件,它是表格容器的索引,你在下文诸多地方都将会见识它的存在。 另外,若该参数未设置,则默认从 中的 id 属性值中获取。 |
test |
skin(等) |
- |
设定表格各种外观、尺寸等 |
详见表格风格 |
cols - 表头参数一览表
相信我,在你还尚无法驾驭 layui table 的时候,你的所有焦点都应放在这里,它带引领你完成许多可见和不可见甚至你无法想象的工作。如果你采用的是方法渲染,cols 是一个二维数组,表头参数设定在数组内;如果你采用的自动渲染,表头参数的设定应放在 标签上
参数 |
类型 |
说明 |
示例值 |
field |
String |
设定字段名。非常重要,且是表格数据列的唯一标识 |
username |
title |
String |
设定标题名称 |
用户名 |
width |
Number/String |
设定列宽,若不填写,则自动分配;若填写,则支持值为:数字、百分比。 请结合实际情况,对不同列做不同设定。 |
200 30% |
minWidth |
Number |
局部定义当前常规单元格的最小宽度(默认:60),一般用于列宽自动分配的情况。其优先级高于基础参数中的 cellMinWidth |
100 |
type |
String |
设定列类型。可选值有:normal(常规列,无需设定)checkbox(复选框列)radio(单选框列,layui 2.4.0 新增)numbers(序号列)space(空列) |
任意一个可选值 |
LAY_CHECKED |
Boolean |
是否全选状态(默认:false)。必须复选框列开启后才有效,如果设置 true,则表示复选框默认全部选中。 |
true |
fixed |
String |
固定列。可选值有:left(固定在左)、right(固定在右)。一旦设定,对应的列将会被固定在左或右,不随滚动条而滚动。 注意:如果是固定在左,该列必须放在表头最前面;如果是固定在右,该列必须放在表头最后面。 |
left(同 true) right |
hide |
Boolean |
是否初始隐藏列,默认:false。layui 2.4.0 新增 |
true |
|
|
|
|
totalRow |
Boolean/String |
是否开启该列的自动合计功能,默认:false。当开启时,则默认由前端自动合计当前行数据。从 layui 2.5.6 开始: 若接口直接返回了合计行数据,则优先读取接口合计行数据,格式如下:</>code{ "code": 0, "totalRow": { "score": "666" ,"experience": "999" }, "data": [{}, {}], "msg": "", "count": 1000} 如上,在 totalRow 中返回所需统计的列字段名和值即可。 另外,totalRow 字段同样可以通过 parseData 回调来解析成为 table 组件所规定的数据格式。从 layui 2.6.3 开始,如果 totalRow 为一个 string 类型,则可解析为合计行的动态模板,如:</>codetotalRow: '{{ d.TOTAL_NUMS }} 单位'//还比如只取整:'{{ parseInt(d.TOTAL_NUMS) }}' |
true |
totalRowText |
String |
用于显示自定义的合计文本。layui 2.4.0 新增 |
“合计:” |
|
|
|
|
sort |
Boolean |
是否允许排序(默认:false)。如果设置 true,则在对应的表头显示排序icon,从而对列开启排序功能。注意:不推荐对值同时存在“数字和普通字符”的列开启排序,因为会进入字典序比对。比如:*’贤心’ > ‘2’ > ‘100’*,这可能并不是你想要的结果,但字典序排列算法(ASCII码比对)就是如此。 |
true |
unresize |
Boolean |
是否禁用拖拽列宽(默认:false)。默认情况下会根据列类型(type)来决定是否禁用,如复选框列,会自动禁用。而其它普通列,默认允许拖拽列宽,当然你也可以设置 true 来禁用该功能。 |
false |
edit |
String |
单元格编辑类型(默认不开启)目前只支持:text(输入框) |
text |
event |
String |
自定义单元格点击事件名,以便在 tool 事件中完成对该单元格的业务处理 |
任意字符 |
style |
String |
自定义单元格样式。即传入 CSS 样式 |
background-color: #5FB878; color: #fff; |
align |
String |
单元格排列方式。可选值有:left(默认)、center(居中)、right(居右) |
center |
colspan |
Number |
单元格所占列数(默认:1)。一般用于多级表头 |
3 |
rowspan |
Number |
单元格所占行数(默认:1)。一般用于多级表头 |
2 |
templet |
String |
自定义列模板,模板遵循 laytpl 语法。这是一个非常实用的功能,你可借助它实现逻辑处理,以及将原始数据转化成其它格式,如时间戳转化为日期字符等 |
详见自定义模板 |
toolbar |
String |
绑定工具条模板。可在每行对应的列中出现一些自定义的操作性按钮 |
详见行工具事件 |
Layui 表单
在一个容器中设定 class=”layui-form” 来标识一个表单元素块,通过规范好的HTML结构及CSS类,来组装成各式各样的表单元素,并通过内置的 form模块 来完成各种交互。
依赖加载模块:form (请注意:如果不加载form模块,select、checkbox、radio等将无法显示,并且无法使用form相关功能)
UI的最终呈现得益于 Form模块 的全自动渲染,她将原本普通的诸如select、checkbox、radio等元素重置为你所看到的模样。
渲染尽管 form 会对表单进行自动渲染,但当元素动态插入时,需通过核心方法 form.render(type, filter) 来进行渲染。 其中参数 type 为表单的元素类型,可选。默认对全部类型的表单进行一次渲染。也可指向 type 进行渲染:
type |
描述 |
select |
渲染 select 选择框 |
checkbox |
渲染 checkbox 复选框(含开关) |
radio |
渲染 radio 单选框框 |
1 2 3 4 5 6
| var form = layui.form;
form.render(); form.render('select');
|
第二个参数 filter 为 class=”layui-form” 所在元素的 lay-filter=”” 的值。你可以借助该参数,对表单完成区域渲染。
1 2 3 4 5 6 7 8 9 10 11 12 13
| <div class="layui-form" lay-filter="test1"> … </div> <script> layui.use('form', function(){ var form = layui.form; form.render(null, 'test1'); form.render('select', 'test1'); }); </script>
|
定向渲染 - 注:v2.7.0 新增1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| <div class="layui-form"> <select id="select-id"> <option value="a">A</option> </select> </div> <script> layui.use('form', function(){ var $ = layui.$; var form = layui.form; form.render($('#select-id')); }); </script>
|
属性事实上在使用表单时,你的一半精力可能会在元素本身上。所以我们把一些基础属性的配置恰恰安放在了标签本身上。如:
1 2 3
| <input type="text" lay-verify="email"> <input type="checkbox" checked lay-skin="switch" lay-filter="encrypt" title="是否加密"> <button lay-submit>提交</button>
|
上述 lay- 前缀的属性即是表单所能识别的元素属性,他们可以使得一些交互操作交由 form 模块内部处理,或者借助 form 提供的 api 精确操作。目前我们可支持的属性如下表所示:
属性名 |
属性值 |
说明 |
title |
任意字符 |
设定元素名称,一般用于 checkbox、radio 框 |
lay-filter |
任意字符 |
过滤器,主要用于事件匹配 |
lay-search |
default (等同空字符) cs (区分字母大小写) |
用于给 select 开启搜索功能。默认不区分字母大小写(注:v2.7.0 新增) |
lay-skin |
switch(开关风格) primary(原始风格) |
定义元素的风格,目前只对 checkbox 元素有效,可将其转变为开关样式 |
lay-ignore |
任意字符或不设值 |
是否忽略元素美化处理。设置后,将不会对该元素进行初始化渲染,即保留系统风格 |
lay-verify |
required(必填项) phone(手机号) email(邮箱) url(网址) number(数字) date(日期) identity(身份证) 自定义值 |
同时支持多条规则的验证,格式:`lay-verify=”验证A |
lay-verType |
tips(吸附层) alert(对话框) msg(默认) |
用于定义异常提示层模式。 |
lay-reqText |
任意字符 |
用于自定义必填项(即设定了 lay-verify=”required” 的表单)的提示文本 |
lay-submit |
无需填写值 |
绑定触发提交的元素,如button |
API1 2 3 4 5 6 7 8 9 10
| var form = layui.form; form.render(type, filter); form.validate(elem); form.verify(obj); form.on('event(filter)', callback); form.val(filter, object); form.submit(filter, callback); form.config; form.set(options);
|
事件语法:form.on('event(filter)', callback);
event |
描述 |
select |
触发select下拉选择事件 |
checkbox |
触发checkbox复选框勾选事件 |
switch |
触发checkbox复选框开关事件 |
radio |
触发radio单选框事件 |
submit |
触发表单提交事件 |
默认情况下,事件所触发的是全部的 form 模块元素,但如果你只想触发某一个元素,使用事件过滤器即可。 如:<select lay-filter="test"></select>
1 2 3
| form.on('select(test)', function(data){ console.log(data); });
|
select 事件下拉选择框被选中时触发,回调函数返回一个object参数,携带两个成员:
1 2 3 4 5
| form.on('select(filter)', function(data){ console.log(data.elem); console.log(data.value); console.log(data.othis); });
|
请注意:如果你想触发所有的select,去掉过滤器*(filter)*即可。下面将不再对此进行备注。
checkbox 事件复选框点击勾选时触发,回调函数返回一个object参数,携带两个成员:
1 2 3 4 5 6
| form.on('checkbox(filter)', function(data){ console.log(data.elem); console.log(data.elem.checked); console.log(data.value); console.log(data.othis); });
|
switch 事件开关被点击时触发,回调函数返回一个object参数,携带两个成员:
1 2 3 4 5 6
| form.on('switch(filter)', function(data){ console.log(data.elem); console.log(data.elem.checked); console.log(data.value); console.log(data.othis); });
|
radio 事件radio单选框被点击时触发,回调函数返回一个object参数,携带两个成员:
1 2 3 4
| form.on('radio(filter)', function(data){ console.log(data.elem); console.log(data.value); });
|
submit 事件按钮点击或者表单被执行提交时触发,其中回调函数只有在验证全部通过后才会进入,回调返回三个成员:
1 2 3 4 5 6
| form.on('submit(*)', function(data){ console.log(data.elem) console.log(data.form) console.log(data.field) return false; });
|
再次温馨提示:上述的*submit(*)*中的 *** 号为事件过滤器的值,是在你绑定执行提交的元素时设定的,如:
1
| <button lay-submit lay-filter="*">提交</button>
|
你可以把号换成任意的值,如:lay-filter=”go”*,但触发事件时也要改成 form.on(‘submit(go)’, callback);
执行提交方法:有时我们未必要通过点击表单内的按钮来进行提交,这时需要用到提交方法:form.submit(filter, callback);
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| <div class="layui-form" lay-filter="test1"> <!-- 表单内部 --> </div> <button id="testSubmitBtn">任意位置按钮</button> <script> layui.use('form', function(){ var form = layui.form; $('#testSubmitBtn').on('click', function(data){ form.submit('test1', function(data){ var field = data.field; }); return false; }); }); </script>
|
表单赋值 / 取值语法:form.val(‘filter’, object);
用于给指定表单集合的元素赋值和取值。如果 object 参数存在,则为赋值;如果 object 参数不存在,则为取值。 注:其中「取值」功能为 layui 2.5.5 开始新增
1 2 3 4 5 6 7 8 9 10 11 12
| form.val("formTest", { "username": "贤心" ,"sex": "女" ,"auth": 3 ,"check[write]": true ,"open": false ,"desc": "我爱layui" });
var data1 = form.val("formTest");
|
第二个参数中的键值是表单元素对应的 name 和 value。
表单验证我们对表单的验证进行了非常巧妙的支持,大多数时候你只需要在表单元素上加上 lay-verify=”” 属性值即可。如:
1 2 3 4
| <input type="text" lay-verify="email"> 还同时支持多条规则的验证,如下: <input type="text" lay-verify="required|phone|number">
|
上述对输入框定义了一个邮箱规则的校验,它会在 form 模块内部完成。目前我们内置的校验支持见上文的:预设元素属性
定义验证规则除了内置的校验规则外,你还可以自定义验证规则,通常对于比较复杂的校验,这是非常有必要的。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
| form.verify({ username: function(value, item){ if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){ return '用户名不能有特殊字符'; } if(/(^\_)|(\__)|(\_+$)/.test(value)){ return '用户名首尾不能出现下划线\'_\''; } if(/^\d+\d+\d$/.test(value)){ return '用户名不能全为数字'; } if(value === 'xxx'){ alert('用户名不能为敏感词'); return true; } } ,pass: [ /^[\S]{6,12}$/ ,'密码必须6到12位,且不能出现空格' ] });
|
当你自定义了类似上面的验证规则后,你只需要把 key 赋值给输入框的 lay-verify 属性即可:
1 2 3
| </>code<input type="text" name="username" lay-verify="username"><input type="password" name="pass" lay-verify="pass"><input type="ch<input type="text" name="username" lay-verify="username"> <input type="password" name="pass" lay-verify="pass"> <input type="checkbox" name="agreement" lay-verify="required" title="同意">eckbox" name="agreement" lay-verify="required" title="同意">
|
当表单提交时,自动触发验证
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| var layer = layui.layer; var form = layui.form;
form.on('submit(*)', function(data){ var field = data.field; if(!field.agreement){ layer.msg('请同意'); return false; } return false; });
|
主动触发验证方法:form.validate(elem); 若验证通过返回 true,否则 false
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
| <div class="layui-form"> <div class="layui-form-item"> <label class="layui-form-label">手机</label> <div class="layui-input-block"> <input type="tel" name="phone" lay-verify="required|phone" class="layui-input demo-phone"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">验证码</label> <div class="layui-input-inline"> <input type="text" name="vercode" lay-verify="required" class="layui-input"> </div> <div class="layui-inline"> <button type="button" class="layui-btn layui-btn-primary" lay-on="get-vercode">获取验证码</button> </div> </div> </div> <script> layui.use(['form', 'util'], function(){ var form = layui.form; var layer = layui.layer; var util = layui.util; util.on('lay-on', { "get-vercode": function(othis){ var isValid = form.validate('.demo-phone'); if(isValid){ layer.msg('手机号验证通过,执行发送验证码的操作'); } } }); }); </script>
|
Layui 日期与时间选择1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272
| <script> layui.use('laydate', function(){ var laydate = layui.laydate; laydate.render({ elem: '#test1' }); laydate.render({ elem: '#test1-1' ,lang: 'en' }); laydate.render({ elem: '#test2' ,type: 'year' }); laydate.render({ elem: '#test3' ,type: 'month' }); laydate.render({ elem: '#test4' ,type: 'time' }); laydate.render({ elem: '#test5' ,type: 'datetime' }); laydate.render({ elem: '#test6' ,range: ['#test-startDate-1', '#test-endDate-1'] }); laydate.render({ elem: '#test7' ,type: 'year' ,range: true }); laydate.render({ elem: '#test8' ,type: 'month' ,range: true }); laydate.render({ elem: '#test9' ,type: 'time' ,range: true }); laydate.render({ elem: '#test10' ,type: 'datetime' ,range: true }); laydate.render({ elem: '#test11' ,format: 'yyyy年MM月dd日' }); laydate.render({ elem: '#test12' ,format: 'dd/MM/yyyy' }); laydate.render({ elem: '#test13' ,format: 'yyyyMMdd' }); laydate.render({ elem: '#test14' ,type: 'time' ,format: 'H点m分' }); laydate.render({ elem: '#test15' ,type: 'month' ,range: '~' ,format: 'yyyy-MM' }); laydate.render({ elem: '#test16' ,type: 'datetime' ,range: '到' ,format: 'yyyy年M月d日H时m分s秒' }); laydate.render({ elem: '#test17' ,calendar: true }); laydate.render({ elem: '#test18' ,mark: { '0-10-14': '生日' ,'0-12-31': '跨年' ,'0-0-10': '工资' ,'0-0-15': '月中' ,'2017-8-15': '' ,'2099-10-14': '呵呵' } ,done: function(value, date){ if(date.year === 2017 && date.month === 8 && date.date === 15){ layer.msg('这一天是:中国人民抗日战争胜利72周年'); } } }); var ins22 = laydate.render({ elem: '#test-limit1' ,min: '2016-10-14' ,max: '2080-10-14' ,ready: function(){ ins22.hint('日期可选值设定在 <br> 2016-10-14 到 2080-10-14'); } }); laydate.render({ elem: '#test-limit2' ,min: -7 ,max: 7 }); laydate.render({ elem: '#test-limit3' ,type: 'time' ,min: '09:30:00' ,max: '17:30:00' ,btns: ['clear', 'confirm'] }); lay('.test-item').each(function(){ laydate.render({ elem: this ,trigger: 'click' }); }); laydate.render({ elem: '#test19' ,value: '2016-10-14' ,isInitValue: true }); laydate.render({ elem: '#test20' ,done: function(value, date){ layer.alert('你选择的日期是:' + value + '<br>获得的对象是' + JSON.stringify(date)); } }); laydate.render({ elem: '#test21' ,change: function(value, date){ layer.msg('你选择的日期是:' + value + '<br><br>获得的对象是' + JSON.stringify(date)); } }); laydate.render({ elem: '#test22' ,showBottom: false }); laydate.render({ elem: '#test23' ,btns: ['confirm'] }); laydate.render({ elem: '#test24' ,trigger: 'mousedown' }); laydate.render({ elem: '#test25' ,eventElem: '#test25-1' ,trigger: 'click' }); lay('#test26-1').on('dblclick', function(){ laydate.render({ elem: '#test26' ,show: true ,closeStop: '#test26-1' }); }); laydate.render({ elem: '#test27' ,trigger: 'click' }); laydate.render({ elem: '#test28' }); laydate.render({ elem: '#test29' ,theme: 'molv' }); laydate.render({ elem: '#test30' ,theme: '#393D49' }); laydate.render({ elem: '#test31' ,theme: 'grid' }); laydate.render({ elem: '#test-n1' ,position: 'static' }); laydate.render({ elem: '#test-n2' ,position: 'static' ,lang: 'en' }); laydate.render({ elem: '#test-n3' ,type: 'month' ,position: 'static' }); laydate.render({ elem: '#test-n4' ,type: 'time' ,position: 'static' }); }); </script>
|
Layui 上传文件1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227
| <script> layui.use(['upload', 'element', 'layer'], function(){ var $ = layui.jquery ,upload = layui.upload ,element = layui.element ,layer = layui.layer; var uploadInst = upload.render({ elem: '#test1' ,url: 'https://httpbin.org/post' ,before: function(obj){ obj.preview(function(index, file, result){ $('#demo1').attr('src', result); }); element.progress('demo', '0%'); layer.msg('上传中', {icon: 16, time: 0}); } ,done: function(res){ if(res.code > 0){ return layer.msg('上传失败'); } $('#demoText').html(''); } ,error: function(){ var demoText = $('#demoText'); demoText.html('<span style="color: #FF5722;">上传失败</span> <a class="layui-btn layui-btn-xs demo-reload">重试</a>'); demoText.find('.demo-reload').on('click', function(){ uploadInst.upload(); }); } ,progress: function(n, elem, e){ element.progress('demo', n + '%'); if(n == 100){ layer.msg('上传完毕', {icon: 1}); } } }); var uploadListIns = upload.render({ elem: '#testList' ,elemList: $('#demoList') ,url: 'https://httpbin.org/post' ,accept: 'file' ,multiple: true ,number: 3 ,auto: false ,bindAction: '#testListAction' ,choose: function(obj){ var that = this; var files = this.files = obj.pushFile(); obj.preview(function(index, file, result){ var tr = $(['<tr id="upload-'+ index +'">' ,'<td>'+ file.name +'</td>' ,'<td>'+ (file.size/1014).toFixed(1) +'kb</td>' ,'<td><div class="layui-progress" lay-filter="progress-demo-'+ index +'"><div class="layui-progress-bar" lay-percent=""></div></div></td>' ,'<td>' ,'<button class="layui-btn layui-btn-xs demo-reload layui-hide">重传</button>' ,'<button class="layui-btn layui-btn-xs layui-btn-danger demo-delete">删除</button>' ,'</td>' ,'</tr>'].join('')); tr.find('.demo-reload').on('click', function(){ obj.upload(index, file); }); tr.find('.demo-delete').on('click', function(){ delete files[index]; tr.remove(); uploadListIns.config.elem.next()[0].value = ''; }); that.elemList.append(tr); element.render('progress'); }); } ,done: function(res, index, upload){ var that = this; var tr = that.elemList.find('tr#upload-'+ index) ,tds = tr.children(); tds.eq(3).html(''); delete this.files[index]; return; this.error(index, upload); } ,allDone: function(obj){ console.log(obj) } ,error: function(index, upload){ var that = this; var tr = that.elemList.find('tr#upload-'+ index) ,tds = tr.children(); tds.eq(3).find('.demo-reload').removeClass('layui-hide'); } ,progress: function(n, elem, e, index){ element.progress('progress-demo-'+ index, n + '%'); } }); upload.render({ elem: '#test2' ,url: '' ,multiple: true ,before: function(obj){ obj.preview(function(index, file, result){ $('#demo2').append('<img src="'+ result +'" alt="'+ file.name +'" class="layui-upload-img">') }); } ,done: function(res){ } }); upload.render({ elem: '#test3' ,url: '' ,accept: 'file' ,done: function(res){ layer.msg('上传成功'); console.log(res); } }); upload.render({ elem: '#test4' ,url: '' ,accept: 'file' ,exts: 'zip|rar|7z' ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); upload.render({ elem: '#test5' ,url: '' ,accept: 'video' ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); upload.render({ elem: '#test6' ,url: '' ,accept: 'audio' ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); upload.render({ elem: '#test7' ,url: '' ,size: 60 ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); upload.render({ elem: '.demoMore' ,before: function(){ layer.tips('接口地址:'+ this.url, this.item, {tips: 1}); } ,done: function(res, index, upload){ var item = this.item; console.log(item); } }) upload.render({ elem: '#test8' ,url: '' ,auto: false ,bindAction: '#test9' ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); upload.render({ elem: '#test10' ,url: 'https://httpbin.org/post' ,done: function(res){ layer.msg('上传成功'); layui.$('#uploadDemoView').removeClass('layui-hide').find('img').attr('src', res.files.file); console.log(res) } }); upload.render({ elem: '#test20' ,url: '' ,done: function(res){ layer.msg('上传成功'); console.log(res) } }); }); </script>
|
更多支持的参数详见下表,合理的配置它们,应对各式各样的业务需求。
参数选项 |
说明 |
类型 |
默认值 |
elem |
指向容器选择器,如:elem: ‘#id’。也可以是DOM对象 |
string/object |
- |
url |
服务端上传接口,返回的数据规范请详见下文 |
string |
- |
data |
请求上传接口的额外参数。如:data: {id: ‘xxx’} 从 layui 2.2.6 开始,支持动态值,如:</>codedata: { id: function(){ return $('#id').val(); }} |
object |
- |
headers |
接口的请求头。如:*headers: {token: ‘sasasas’}*。注:该参数为 layui 2.2.6 开始新增 |
|
|
accept |
指定允许上传时校验的文件类型,可选值有:images(图片)、file(所有文件)、video(视频)、audio(音频) |
string |
images |
acceptMime |
规定打开文件选择框时,筛选出的文件类型,值为用逗号隔开的 MIME 类型列表。如: *acceptMime: ‘image/*‘*(只显示图片文件) *acceptMime: ‘image/jpg, image/png’*(只显示 jpg 和 png 文件) 注:layui 2.2.6 新增 |
string |
images |
exts |
允许上传的文件后缀。一般结合 accept 参数类设定。假设 accept 为 file 类型时,那么你设置 exts: ‘zip|rar|7z’ 即代表只允许上传压缩格式的文件。如果 accept 未设定,那么限制的就是图片的文件格式 |
string |
jpg|png|gif|bmp|jpeg |
auto |
是否选完文件后自动上传。如果设定 false,那么需要设置 bindAction 参数来指向一个其它按钮提交上传 |
boolean |
true |
bindAction |
指向一个按钮触发上传,一般配合 auto: false 来使用。值为选择器或DOM对象,如:bindAction: ‘#btn’ |
string/object |
- |
force |
规定强制返回的数据格式,默认不强制。 若值为 ‘json’,则强制为 JSON 数据格式 注:layui 2.6.9 新增 |
string |
null |
field |
设定文件域的字段名 |
string |
file |
size |
设置文件最大可允许上传的大小,单位 KB。不支持ie8/9 |
number |
0(即不限制) |
multiple |
是否允许多文件上传。设置 true即可开启。不支持ie8/9 |
boolean |
false |
number |
设置同时可上传的文件数量,一般配合 multiple 参数出现。 注意:该参数为 layui 2.2.3 开始新增 |
number |
0(即不限制) |
drag |
是否接受拖拽的文件上传,设置 false 可禁用。不支持ie8/9 |
boolean |
true |
回调 |
|
|
|
choose |
选择文件后的回调函数。返回一个object参数,详见下文 |
function |
- |
before |
文件提交上传前的回调。返回一个object参数(同上),详见下文 |
function |
- |
done |
执行上传请求后的回调。返回三个参数,分别为:res(服务端响应信息)、index(当前文件的索引)、upload(重新上传的方法,一般在文件上传失败后使用)。详见下文 |
function |
- |
error |
执行上传请求出现异常的回调(一般为网络异常、URL 404等)。返回两个参数,分别为:index(当前文件的索引)、upload(重新上传的方法)。详见下文 |
function |
- |
如何判断 JavaScript 对象是否为空Object.keys()1 2 3
| function isEmpty(obj) { return Object.keys(obj).length === 0; }
|
for…in…1 2 3 4
| for (var i in obj) { return true } return false
|
JSON.stringify()1 2 3 4
| if (JSON.stringify(data) === '{}') { return false } return true
|
Json 数据解析JSON.parse()JSON 通常用于与服务端交换数据。
在接收服务器数据时一般是字符串。
我们可以使用 JSON.parse() 方法将数据转换为 JavaScript 对象。
语法1
| JSON.parse(text[, reviver])
|
参数说明:
- text: 必需, 一个有效的 JSON 字符串。
- reviver: 可选,一个转换结果的函数, 将为对象的每个成员调用此函数。
JSON 解析实例例如我们从服务器接收了以下数据:
1
| { "name":"runoob", "alexa":10000, "site":"www.runoob.com" }
|
我们使用 JSON.parse() 方法处理以上数据,将其转换为 JavaScript 对象:
1
| var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');
|
JSON.stringify()JSON 通常用于与服务端交换数据。
在向服务器发送数据时一般是字符串。
我们可以使用 JSON.stringify() 方法将 JavaScript 对象转换为字符串。
语法1
| JSON.stringify(value[, replacer[, space]])
|
参数说明:
value:
必需, 要转换的 JavaScript 值(通常为对象或数组)。
replacer:
可选。用于转换结果的函数或数组。
如果 replacer 为函数,则 JSON.stringify 将调用该函数,并传入每个成员的键和值。使用返回值而不是原始值。如果此函数返回 undefined,则排除成员。根对象的键是一个空字符串:””。
如果 replacer 是一个数组,则仅转换该数组中具有键值的成员。成员的转换顺序与键在数组中的顺序一样。当 value 参数也为数组时,将忽略 replacer 数组。
space:
可选,文本添加缩进、空格和换行符,如果 space 是一个数字,则返回值文本在每个级别缩进指定数目的空格,如果 space 大于 10,则文本缩进 10 个空格。space 也可以使用非数字,如:\t。
JavaScript 对象转换例如我们向服务器发送以下数据:
1
| var obj = { "name":"runoob", "alexa":10000, "site":"www.runoob.com"};
|
我们使用 JSON.stringify() 方法处理以上数据,将其转换为字符串:
1
| var myJSON = JSON.stringify(obj);
|
JavaScript 删除数组元素splice() 方法1 2 3 4 5 6 7 8 9 10 11
| const array = [2, 5, 9];
console.log(array);
const index = array.indexOf(5); if (index > -1) { array.splice(index, 1); }
console.log(array);
|
delete 关键字1 2 3 4 5
| var colors = ["red", "blue", "grey", "green"];
delete colors[0];
console.log(colors);
|
JavaScript 常用业务代码总结
http://www.loquy.cn/posts/9296f96c.html
|