layer.open(常用)
layer.open(常用) 迷迭绿 于 2022-04-08 13:38:49 发布 12797 收藏 15 分类专栏: 前端 UI 框架--layui 文章标签: layui 前端 前端框架 版权 华为云开发者联盟 该内容已被华为云开发者联盟社区收录,社区免费抽大奖🎉,赢华为平板、Switch等好礼! 加入社区 前端 UI 框架--layui 专栏收录该内容 2 篇文章0 订阅 订阅专栏 实例: 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(iframe层)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皮肤制作说明 推荐自己来定义:(如下) //单个使用 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调试工具,定义更多样式控制层更多的区域。 content - 内容 类型: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 }); area - 宽高 类型:String/Array,默认:'auto' 在默认状态下,layer是宽高都自适应的 若要定义宽度:area: '500px',高度仍然是自适应的 若要定义宽高:area: ['500px', '300px'] btn - 按钮 类型: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 开启该代码可禁止点击该按钮关闭 } }); offset - 坐标 类型: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' 快捷设置右下角 icon - 图标 信息框和加载层的私有参数 类型:Number,默认:-1(信息框)/0(加载层) 信息框默认不显示图标 若需显示图标时,默认皮肤可以传入0-6 若是加载层,可以传入0-2 //eg1 layer.alert('酷毙了', {icon: 1}); //eg2 layer.msg('不开心。。', {icon: 5}); //eg3 layer.load(1); //风格1的加载 btnAlign - 按钮排列 类型:String,默认:r 该参数可支持的赋值: 值 备注 btnAlign: 'l' 按钮左对齐 btnAlign: 'c' 按钮居中对齐 btnAlign: 'r' 按钮右对齐。默认值,不用设置 closeBtn - 关闭按钮 类型:String/Boolean,默认:1 layer提供了两种风格的关闭按钮,可通过配置1和2来展示 若需不显示,则closeBtn: 0 shade - 遮罩 类型:String/Array/Boolean,默认:0.3 即弹层外区域 默认是0.3透明度的黑色背景('#000') 若需定义别的颜色,shade: [0.8, '#393D49']; 若需不显示遮罩,可以shade: 0 shadeClose - 是否点击遮罩关闭 类型:Boolean,默认:false 如果你的shade是存在的,那么你可以设定shadeClose来控制点击弹层外区域关闭。 time - 自动关闭所需毫秒 类型:Number,默认:0 默认不会自动关闭。 若需自动关闭时,可以time: 5000,即代表5秒后自动关闭,注意单位是毫秒(1秒=1000毫秒) success - 层弹出后的成功回调方法 类型:Function,默认:null 若需在层创建完毕时即执行一些语句,可以通过该回调。 success会携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero) layer.open({ content: '测试回调', success: function(layero, index){ console.log(layero, index); } }); yes - 确定按钮回调方法 类型:Function,默认:null 该回调携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero) layer.open({ content: '测试回调', yes: function(index, layero){ //do something layer.close(index); //如果设定了yes回调,需进行手工关闭 } }); cancel - 右上角关闭按钮触发的回调 类型:Function,默认:null 该回调携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero) 默认会自动触发关闭 如果不想关闭,return false即可 cancel: function(index, layero){ if(confirm('确定要关闭么')){ //只有当点击confirm框的确定时,该层才会关闭 layer.close(index) } return false; } end - 层销毁后触发的回调 类型:Function,默认:null 无论是确认还是取消,只要层被销毁了,end都会执行,不携带任何参数。 full/min/restore -分别代表最大化、最小化、还原 后触发的回调 类型:Function,默认:null 携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero) min: function(layero, index){ //index 参数为 layui 2.6.6 或独立版 layer 3.5.0 开始新增 //当层最小化时触发 //自定义操作,并阻止默认最小化 //layer.min(index); //单独执行最小化 //return false; //阻止默认最小化 } id - 用于控制弹层唯一标识 类型:String,默认:空字符 设置该值后,不管是什么类型的层,都只允许同时弹出一个。一般用于页面层和iframe层模式 查看更多:layer弹层组件开发文档 - Layui ———————————————— 版权声明:本文为CSDN博主「迷迭绿」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_42832151/article/details/124037469
let _data = obj.data; //这一行的所有数据 layer.open({ type: 2 ,title: '查看详情' ,content: '/index/abnor/look' ,area: ['95%', '95%'], success:function (layero, index){ //弹出层加载成功后执行 let iframeWindow = window['layui-layer-iframe'+ index]; let doc = $(iframeWindow.document); doc.find('.layui-textarea').text(_data.content); } })
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2021-12-30 vue 批量导入 + 过滤excel文件(用了el-upload),处理上传的excel
2021-12-30 element 密码显示 隐藏
2021-12-30 find(), findIndex(),indexof使用方法和区别
2021-12-30 Element UI系列:Select下拉框实现默认选择
2021-12-30 vue2的v-model响应数组index的变化
2021-12-30 vue element UI el-select选择框触发事件(每选择一次则触发一次该事件)
2021-12-30 this.$alert 方法