实例:
layer.open({
type: 1,
title: '标题',
skin: 'layui-layer-rim', //加上边框
area: ['1070px', '550px'], //设置宽高
content:$("#lookinfo"),
btn: ['按钮1','按钮2'],
btn1:function(index, layero){
// 按钮1的逻辑
},
btn2:function(index, layero){
// 按钮2的逻辑
},
cancel: function(){
// 开发公司右上角关闭事件的逻辑
}
});
------------------------------------------------常用情景------------------------------------------------------
1.点击“按钮”开发公司仅关闭弹窗,不刷新 ,可使用layer.close(index);
layer.open({
type: 1,
title: '查看',
closeBtn: 1,
anim: 2,
shadeClose: true,
area: ['540px', '750px'],
content: $("#lookinfo"),
btn: ["确定","取消"],
yes: function(index, layero){
layer.close(index);
},
cancel: function(index, layero){
layer.close(index);
},
});
------------------------------------------------详细说明------------------------------------------------------
type -- 开发公司基本层类型
类型:Number,默认:0
0(信息框,默认)1(页面层)2(层)3(加载层)4(tips层)
title -- 标题
类型:String/Array/Boolean,默认:'信息'
title开发公司支持三种类型的值:
1、开发公司若你传入的是普通的字符串,如title :'我是标题',开发公司那么只会改变标题文本;
2、开发公司若你还需要自定义标题区域样式,开发公司那么你可以title: ['文本', 'font-size:18px;'],开发公司数组第二项可以写任意css样式;
3、开发公司如果你不想显示标题栏,你可以title: false
skin -- 样式类名
类型:String,默认:''
skin允许传入layer开发公司内置的样式class名
skin开发公司允许传入自定义的class名,可以借助skin开发公司轻松完成不同的风格定制
目前layer内置的skin有:layui-layer-lanlayui-layer-molv,
开发公司推荐自己来定义:(如下)
- //单个使用
- layer.open({
- skin: 'demo-class'
- });
- //全局使用。开发公司即所有弹出层都默认采用,开发公司但是单个配置skin开发公司的优先级更高
- layer.config({
- skin: 'demo-class'
- })
- //CSS
- body .demo-class .layui-layer-title{background:#c00; color:#fff; border: none;}
- body .demo-class .layui-layer-btn{border-top:1px solid #E9E7E7}
- body .demo-class .layui-layer-btn a{background:#333;}
- body .demo-class .layui-layer-btn .layui-layer-btn1{background:#999;}
- …
- 加上body开发公司是为了保证优先级。开发公司你可以借助Chrome调试工具,定义更多样式控制层更多的区域。
- 内容
类型:String/DOM/Array,默认:''
content可传入的值是灵活多变的
可以是普通的html内容
可以指定DOM
可以随着type的不同而不同(如下)
- /!*
- 如果是页面层
- */
- layer.open({
- type: 1,
- content: '传入任意的文本或html' //这里content是一个普通的String
- });
- layer.open({
- type: 1,
- content: $('#id') //这里content是一个DOM,注意:最好该元素要存放在body最外层,否则可能被其它的相对元素所影响
- });
- //Ajax获取
- $.post('url', {}, function(str){
- layer.open({
- type: 1,
- content: str //注意,如果str是object,那么需要字符拼接。
- });
- });
- /!*
- 如果是iframe层
- */
- layer.open({
- type: 2,
- content: 'http://sentsin.com' //这里content是一个URL,如果你不想让iframe出现滚动条,你还可以content: ['http://sentsin.com', 'no']
- });
- /!*
- 如果是用layer.open执行tips层
- */
- layer.open({
- type: 4,
- content: ['内容', '#id'] //数组第二项即吸附元素选择器或者DOM
- });
- 宽高
类型:String/Array,默认:'auto'
在默认状态下,layer是宽高都自适应的
若要定义宽度:area: '500px',高度仍然是自适应的
若要定义宽高:area: ['500px', '300px']
- 按钮
类型:String/Array,默认:'确认'
信息框模式时,btn默认是一个确认按钮,其它层类型则默认不显示,加载层和tips层则无效。
若需自定义一个按钮时,btn: "我知道了'"
若需自定义两个按钮时,btn: ['yes', 'no']
若需自定义更多按钮,btn: ['按钮1', '按钮2', '按钮3', …],按钮1的回调是yes,而从按钮2开始,则回调为btn2: function(){},以此类推。(如下)
- //eg1
- layer.confirm('纳尼?', {
- btn: ['按钮一', '按钮二', '按钮三'] //可以无限个按钮
- ,btn3: function(index, layero){
- //按钮【按钮三】的回调
- }
- }, function(index, layero){
- //按钮【按钮一】的回调
- }, function(index){
- //按钮【按钮二】的回调
- });
-
- //eg2
- layer.open({
- content: 'test'
- ,btn: ['按钮一', '按钮二', '按钮三']
- ,yes: function(index, layero){
- //按钮【按钮一】的回调
- }
- ,btn2: function(index, layero){
- //按钮【按钮二】的回调
-
- //return false 开启该代码可禁止点击该按钮关闭
- }
- ,btn3: function(index, layero){
- //按钮【按钮三】的回调
-
- //return false 开启该代码可禁止点击该按钮关闭
- }
- ,cancel: function(){
- //右上角关闭回调
-
- //return false 开启该代码可禁止点击该按钮关闭
- }
- });
- 坐标
类型:String/Array,默认:
offset默认情况下不用设置。但如果你不想垂直水平居中,你还可以进行以下赋值:
值 | 备注 |
---|---|
offset: 'auto' | 默认坐标,即垂直水平居中 |
offset: '100px' | 只定义top坐标,水平保持居中 |
offset: ['100px', '50px'] | 同时定义top、left坐标 |
offset: 't' | 快捷设置顶部坐标 |
offset: 'r' | 快捷设置右边缘坐标 |
offset: 'b' | 快捷设置底部坐标 |
offset: 'l' | 快捷设置左边缘坐标 |
offset: 'lt' | 快捷设置左上角 |
offset: 'lb' | 快捷设置左下角 |
offset: 'rt' | 快捷设置右上角 |
offset: 'rb' | 快捷设置右下角 |
- 图标
信息框和加载层的私有参数
类型:Number,默认:-1(信息框)/0(加载层)
信息框默认不显示图标
若需显示图标时,默认皮肤可以传入0-6
若是加载层,可以传入0-2
- //eg1
- layer.alert('酷毙了', {icon: 1});
- //eg2
- layer.msg('不开心。。', {icon: 5});
- //eg3
- layer.load(1); //风格1的加载
- 按钮排列
类型:String,默认:r
该参数可支持的赋值:
值 | 备注 |
---|---|
btnAlign: 'l' | 按钮左对齐 |
btnAlign: 'c' | 按钮居中对齐 |
btnAlign: 'r' | 按钮右对齐。默认值,不用设置 |
- 关闭按钮
类型:String/Boolean,默认:1
layer提供了两种风格的关闭按钮,可通过配置1和2来展示
若需不显示,则closeBtn: 0
- 遮罩
类型:String/Array/Boolean,默认:0.3
即弹层外区域
默认是0.3透明度的黑色背景('#000')
若需定义别的颜色,shade: [0.8, '#393D49'];
若需不显示遮罩,可以shade: 0
- 是否点击遮罩关闭
类型:Boolean,默认:false
如果你的shade是存在的,那么你可以设定shadeClose来控制点击弹层外区域关闭。
- 自动关闭所需毫秒
类型:Number,默认:0
默认不会自动关闭。
若需自动关闭时,可以time: 5000,即代表5秒后自动关闭,注意单位是毫秒(1秒=1000毫秒)
- 层弹出后的成功回调方法
类型:Function,默认:null
若需在层创建完毕时即执行一些语句,可以通过该回调。
success会携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero)
- layer.open({
- content: '测试回调',
- success: function(layero, index){
- console.log(layero, index);
- }
- });
- 确定按钮回调方法
类型:Function,默认:null
该回调携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero)
- layer.open({
- content: '测试回调',
- yes: function(index, layero){
- //do something
- layer.close(index); //如果设定了yes回调,需进行手工关闭
- }
- });
- 右上角关闭按钮触发的回调
类型:Function,默认:null
该回调携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero)
默认会自动触发关闭
如果不想关闭,return false即可
- cancel: function(index, layero){
- if(confirm('确定要关闭么')){ //只有当点击confirm框的确定时,该层才会关闭
- layer.close(index)
- }
- return false;
- }
- 层销毁后触发的回调
类型:Function,默认:null
无论是确认还是取消,只要层被销毁了,end都会执行,不携带任何参数。
-分别代表最大化、最小化、还原 后触发的回调
类型:Function,默认:null
携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero)
- min: function(layero, index){
- //index 参数为 layui 2.6.6 或独立版 layer 3.5.0 开始新增
- //当层最小化时触发
-
- //自定义操作,并阻止默认最小化
- //layer.min(index); //单独执行最小化
- //return false; //阻止默认最小化
- }
- 用于控制弹层唯一标识
类型:String,默认:空字符
设置该值后,不管是什么类型的层,都只允许同时弹出一个。一般用于页面层和iframe层模式
查看更多: