整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

如何在vue中继续使用layer.js,亲测好用

如何在vue中继续使用layer.js,亲测好用



ayer.js是一个方便的弹出层插件,切图网专注于PSD2HTML等前端切图多年,后转向Vue开发。在vue开发过程中引入layer.js的时候遇到了麻烦。原因是layer.js不支持import导入,这时就需要修改一下它的源码。在看过它的源码后,发现需要修改的地方只有两处,

源码中已经暴露了一个全局变量layer,故只需在脚本末尾处添加

export default layer;

这表示将这个全局变量导出。

然后在文件中找到下面的代码注释掉,这段代码是为layer添加样式的,但使用的路径不对,故没有太大帮助。

document.head.appendChild(function() {
    var link=doc.createElement('link');
    link.href=path + 'need/layer.css?2.0';
    link.type='text/css';
    link.rel='styleSheet'link.id='layermcss';
    return link;
} ());

接下来把layer.js和layer.css分别放入static/js和static/css中,在需要的地方,比如组件内部或者全局注册,因为项目多处都会用到,所以采用全局注册,在main.js中

import layer from '../static/js/layer.js'

layer.css也使用全局注册,它可以放在index.html中通过link引入,也可以放在App.vue中

<!--index.html-->
<link rel="stylesheet" href="./static/css/layer.css" />
<!--或者-->
<!--App.vue-->
<style>
@import "../static/css/layer.css";
</style>

接下来就能在各个组件中使用layer.open等方法了。

这种方式应该可以适用于各种不支持import导入的脚本,即非npm提供的module。

天给大家分享的是Vue3系列之自定义桌面端对话框组件v3layer

V3Layer 基于vue3.0构建的多功能PC网页端弹窗组件。拥有超过10+种弹窗类型、30+种参数配置,支持拖拽(自定义拖拽区域)、缩放、最大化、全屏及自定义置顶层叠等功能。

快速引入

在main.js中引入v3layer组件。

import { createApp } from 'vue'
import App from './App.vue'

// 引入Element-Plus组件库
import ElementPlus from 'element-plus'
import 'element-plus/lib/theme-chalk/index.css'

// 引入弹窗组件v3layer
import V3Layer from './components/v3layer'

createApp(App).use(ElementPlus).use(V3Layer).mount('#app')

v3layer支持组件式+函数式两种调用方式。

  • 组件式
<v3-layer 
    v-model="showDialog"
    title="标题内容"
    content="<div style='color:#f57b16;padding:30px;'>这里是内容信息!</div>"
    z-index="2021"
    lockScroll="false"
    xclose
    resize
    dragOut
    :btns="[
        {text: '取消', click: ()=> showDialog=false},
        {text: '确认', style: 'color:#f90;', click: handleSure},
    ]"
/>
    <template v-slot:content>这里是自定义插槽内容信息!</template>
</v3-layer>
  • 函数式
let $el=v3layer({
    title: '标题内容',
    content: '<div style='color:#f57b16;padding:30px;'>这里是内容信息!</div>', 
    shadeClose: false,
    zIndex: 2021,
    lockScroll: false,
    xclose: true,
    resize: true,
    dragOut: true,
    btns: [
        {text: '取消', click: ()=> { $el.close() }},
        {text: '确认', click: ()=> handleSure},
    ]
});

当弹窗类型为 message | notify | popover,调用方法如下:

v3layer.message({...})
v3layer.notify({...})
v3layer.popover({...})

vue3.0中提供了app.config.globalPropertiesapp.provide 两种方式挂载全局函数。

  • 如果是 app.config.globalProperties 方式创建:
// vue2中调用
methods: {
    showDialog() {
        this.$v3layer({...})
    }
}

// vue3中调用
setup() {
    // 获取上下文
    const { ctx }=getCurrentInstance()
    ctx.$v3layer({...})
}
  • 如果是 app.provide 方式创建:
// vue2中调用
methods: {
    showDialog() {
        this.v3layer({...})
    }
}

// vue3中调用
setup() {
    const v3layer=inject('v3layer')
    
    const showDialog=()=> {
        v3layer({...})
    }

    return {
        v3layer,
        showDialog
    }
}

参数配置

v3layer支持如下30+参数灵活配置,实现各种弹窗场景。

|props参数|
v-model         是否显示弹框
id              弹窗唯一标识
title           标题
content         内容(支持String、带标签内容、自定义插槽内容)***如果content内容比较复杂,推荐使用标签式写法
type            弹框类型(toast|footer|actionsheet|actionsheetPicker|android|ios|contextmenu|drawer|iframe)
layerStyle      自定义弹窗样式
icon            toast图标(loading | success | fail)
shade           是否显示遮罩层
shadeClose      是否点击遮罩时关闭弹窗
lockScroll      是否弹窗出现时将body滚动锁定
opacity         遮罩层透明度
xclose          是否显示关闭图标
xposition       关闭图标位置(left | right | top | bottom)
xcolor          关闭图标颜色
anim            弹窗动画(scaleIn | fadeIn | footer | fadeInUp | fadeInDown | fadeInLeft | fadeInRight)
position        弹出位置(auto | ['100px','50px'] | t | r | b | l | lt | rt | lb | rb)
drawer          抽屉弹窗(top | right | bottom | left)
follow          跟随元素定位弹窗(支持元素.kk #kk 或 [e.clientX, e.clientY])
time            弹窗自动关闭秒数(1、2、3)
zIndex          弹窗层叠(默认8080)
teleport        指定挂载节点(默认是挂载组件标签位置,可通过teleport自定义挂载位置) teleport="body | #xxx | .xxx"
topmost         置顶当前窗口(默认false)
area            弹窗宽高(默认auto)设置宽度area: '300px' 设置高度area:['', '200px'] 设置宽高area:['350px', '150px']
maxWidth        弹窗最大宽度(只有当area:'auto'时,maxWidth的设定才有效)
maximize        是否显示最大化按钮(默认false)
fullscreen      全屏弹窗(默认false)
fixed           弹窗是否固定
drag            拖拽元素(可定义选择器drag:'.xxx' | 禁止拖拽drag:false)
dragOut         是否允许拖拽到窗口外(默认false)
lockAxis        限制拖拽方向可选: v 垂直、h 水平,默认不限制
resize          是否允许拉伸尺寸(默认false)
btns            弹窗按钮(参数:text|style|disabled|click)
++++++++++++++++++++++++++++++++++++++++++++++
|emit事件触发|
success         层弹出后回调(@success="xxx")
end             层销毁后回调(@end="xxx")
++++++++++++++++++++++++++++++++++++++++++++++
|event事件|
onSuccess       层打开回调事件
onEnd           层关闭回调事件

v3layer弹窗模板

<template>
    <div ref="elRef" v-show="opened" class="vui__layer" :class="{'vui__layer-closed': closeCls}" :id="id">
        <!-- //蒙版 -->
        <div v-if="JSON.parse(shade)" class="vlayer__overlay" @click="shadeClicked" :style="{opacity}"></div>
        <div class="vlayer__wrap" :class="['anim-'+anim, type&&'popui__'+type, tipArrow]" :style="[layerStyle]">
            <div v-if="title" class="vlayer__wrap-tit" v-html="title"></div>
            <div v-if="type=='toast'&&icon" class="vlayer__toast-icon" :class="['vlayer__toast-'+icon]" v-html="toastIcon[icon]"></div>
            <div class="vlayer__wrap-cntbox">
                <!-- 判断插槽是否存在 -->
                <template v-if="$slots.content">
                    <div class="vlayer__wrap-cnt"><slot name="content" /></div>
                </template>
                <template v-else>
                    <template v-if="content">
                        <iframe v-if="type=='iframe'" scrolling="auto" allowtransparency="true" frameborder="0" :src="content"></iframe>
                        <!-- message|notify|popover -->
                        <div v-else-if="type=='message' || type=='notify' || type=='popover'" class="vlayer__wrap-cnt">
                            <i v-if="icon" class="vlayer-msg__icon" :class="icon" v-html="messageIcon[icon]"></i>
                            <div class="vlayer-msg__group"><div v-if="title" class="vlayer-msg__title" v-html="title"></div><div v-html="content"></div></div>
                        </div>
                        <div v-else class="vlayer__wrap-cnt" v-html="content"></div>
                    </template>
                </template>
                <slot />
            </div>
            <div v-if="btns" class="vlayer__wrap-btns">
                <span v-for="(btn,index) in btns" :key="index" class="btn" :style="btn.style" @click="btnClicked($event,index)" v-html="btn.text"></span>
            </div>
            <span v-if="xclose" class="vlayer__xclose" :class="!maximize&&xposition" :style="{'color': xcolor}" @click="close"></span>
            <span v-if="maximize" class="vlayer__maximize" @click="maximizeClicked($event)"></span>
            <span v-if="resize" class="vlayer__resize"></span>
        </div>
        <!-- 优化拖拽卡顿 -->
        <div class="vlayer__dragfix"></div>
    </div>
</template>
<script>
    import { onMounted, onUnmounted, ref, reactive, watch, toRefs, nextTick } from 'vue'
    import domUtils from './utils/dom.js'
    // 索引,蒙层控制,定时器
    let $index=0, $locknum=0, $timer={}, $closeTimer=null
    export default {
        props: {
            // ...
        },
        emits: [
            'update:modelValue'
        ],
        setup(props, context) {
            const elRef=ref(null);

            const data=reactive({
                opened: false,
                closeCls: '',
                toastIcon: {
                    // ...
                },
                messageIcon: {
                    // ...
                },
                vlayerOpts: {},
                tipArrow: null,
            })

            onMounted(()=> {
                if(props.modelValue) {
                    open();
                }
                window.addEventListener('resize', autopos, false);
            })

            onUnmounted(()=> {
                window.removeEventListener('resize', autopos, false);
                clearTimeout($closeTimer);
            })

            // 监听弹层v-model
            watch(()=> props.modelValue, (val)=> {
                // console.log('V3Layer is now [%s]', val ? 'show' : 'hide')
                if(val) {
                    open();
                }else {
                    close();
                }
            })

            // 打开弹窗
            const open=()=> {
                if(data.opened) return;
                data.opened=true;
                typeof props.onSuccess==='function' && props.onSuccess();

                const dom=elRef.value;
                // 弹层挂载位置
                if(props.teleport) {
                    nextTick(()=> {
                        let teleportNode=document.querySelector(props.teleport);
                        teleportNode.appendChild(dom);

                        auto();
                    })
                }

                callback();
            }

            // 关闭弹窗
            const close=()=> {
                if(!data.opened) return;

                let dom=elRef.value;
                let vlayero=dom.querySelector('.vlayer__wrap');
                let ocnt=dom.querySelector('.vlayer__wrap-cntbox');
                let omax=dom.querySelector('.vlayer__maximize');

                data.closeCls=true;
                clearTimeout($closeTimer);
                $closeTimer=setTimeout(()=> {
                    data.opened=false;
                    data.closeCls=false;
                    if(data.vlayerOpts.lockScroll) {
                        $locknum--;
                        if(!$locknum) {
                            document.body.style.paddingRight='';
                            document.body.classList.remove('vui__body-hidden');
                        }
                    }
                    if(props.time) {
                        $index--;
                    }
                    // 清除弹窗样式
                    vlayero.style.width=vlayero.style.height=vlayero.style.top=vlayero.style.left='';
                    ocnt.style.height='';
                    omax && omax.classList.contains('maximized') && omax.classList.remove('maximized');
                    
                    data.vlayerOpts.isBodyOverflow && (document.body.style.overflow='');

                    context.emit('update:modelValue', false);
                    typeof props.onEnd==='function' && props.onEnd();
                }, 200)
            }

            // 弹窗位置
            const auto=()=> {
                // ...

                autopos();

                // 全屏弹窗
                if(props.fullscreen) {
                    full();
                }

                // 弹窗拖动|缩放
                move();
            }

            const autopos=()=> {
                if(!data.opened) return;
                let oL, oT
                let pos=props.position;
                let isFixed=JSON.parse(props.fixed);
                let dom=elRef.value;
                let vlayero=dom.querySelector('.vlayer__wrap');

                if(!isFixed || props.follow) {
                    vlayero.style.position='absolute';
                }
                
                let area=[domUtils.client('width'), domUtils.client('height'), vlayero.offsetWidth, vlayero.offsetHeight]
                
                oL=(area[0] - area[2]) / 2;
                oT=(area[1] - area[3]) / 2;

                if(props.follow) {
                    offset();
                }else {
                    typeof pos==='object' ? (
                        oL=parseFloat(pos[0]) || 0, oT=parseFloat(pos[1]) || 0
                    ) : (
                        pos=='t' ? oT=0 : 
                        pos=='r' ? oL=area[0] - area[2] : 
                        pos=='b' ? oT=area[1] - area[3] : 
                        pos=='l' ? oL=0 : 
                        pos=='lt' ? (oL=0, oT=0) : 
                        pos=='rt' ? (oL=area[0] - area[2], oT=0) : 
                        pos=='lb' ? (oL=0, oT=area[1] - area[3]) :
                        pos=='rb' ? (oL=area[0] - area[2], oT=area[1] - area[3]) : 
                        null
                    )

                    vlayero.style.left=parseFloat(isFixed ? oL : domUtils.scroll('left') + oL) + 'px';
                    vlayero.style.top=parseFloat(isFixed ? oT : domUtils.scroll('top') + oT) + 'px';
                }
            }

            // 元素跟随定位
            const offset=()=> {
                let oW, oH, pS
                let dom=elRef.value
                let vlayero=dom.querySelector('.vlayer__wrap');

                oW=vlayero.offsetWidth;
                oH=vlayero.offsetHeight;
                pS=domUtils.getFollowRect(props.follow, oW, oH);
                data.tipArrow=pS[2];
                
                vlayero.style.left=pS[0] + 'px';
                vlayero.style.top=pS[1] + 'px';
            }

            // 最大化弹窗
            const full=()=> {
                // ...
            }

            // 恢复弹窗
            const restore=()=> {
                let dom=elRef.value;
                let vlayero=dom.querySelector('.vlayer__wrap');
                let otit=dom.querySelector('.vlayer__wrap-tit');
                let ocnt=dom.querySelector('.vlayer__wrap-cntbox');
                let obtn=dom.querySelector('.vlayer__wrap-btns');
                let omax=dom.querySelector('.vlayer__maximize');

                let t=otit ? otit.offsetHeight : 0
                let b=obtn ? obtn.offsetHeight : 0

                if(!data.vlayerOpts.lockScroll) {
                    data.vlayerOpts.isBodyOverflow=false;
                    document.body.style.overflow='';
                }
                
                props.maximize && omax.classList.remove('maximized')
                
                vlayero.style.left=parseFloat(data.vlayerOpts.rect[0]) + 'px';
                vlayero.style.top=parseFloat(data.vlayerOpts.rect[1]) + 'px';
                vlayero.style.width=parseFloat(data.vlayerOpts.rect[2]) + 'px';
                vlayero.style.height=parseFloat(data.vlayerOpts.rect[3]) + 'px';
            }

            // 拖动|缩放弹窗
            const move=()=> {
                // ...
            }

            // 事件处理
            const callback=()=> {
                // 倒计时关闭
                if(props.time) {
                    $index++
                    // 防止重复点击
                    if($timer[$index] !==null) clearTimeout($timer[$index])
                    $timer[$index]=setTimeout(()=> {
                        close();
                    }, parseInt(props.time) * 1000)
                }
            }

            // 点击最大化按钮
            const maximizeClicked=(e)=> {
                let o=e.target
                if(o.classList.contains('maximized')) {
                    // 恢复
                    restore();
                } else {
                    // 最大化
                    full();
                }
            }
            // 点击遮罩层
            const shadeClicked=()=> {
                if(JSON.parse(props.shadeClose)) {
                    close();
                }
            }
            // 按钮事件
            const btnClicked=(e, index)=> {
                let btn=props.btns[index]
                if(!btn.disabled) {
                    typeof btn.click==='function' && btn.click(e)
                }
            }
            
            return {
                ...toRefs(data),
                elRef,
                close,
                maximizeClicked,
                shadeClicked,
                btnClicked,
            }
        }
    }
</script>

v3layer支持自定义拖拽区域 (drag:'#aaa'),拖动到窗口外 (dragOut:true)。支持iframe弹窗类型 (type:'iframe')。

配置 topmost:true 当前窗口会保持置顶。

ok,基于vue3.0开发pc端对话框组件就分享到这里。希望对大家有所帮助哈!

起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第1天,点击查看活动详情。 layui是大家众所周知的一款ui框架 下面组要给大家讲一讲layui的弹层组件layer 基础参数

我们提到的基础参数主要指调用方法时用到的配置项,如:layer.open({content: ''}) layer.msg('', {time: 3}) 等,其中的content和time即是基础参数,以键值形式存在,基础参数可合理应用于任何层类型中,您不需要所有都去配置,大多数都是可选的。而其中的layer.open、layer.msg就是内置方法。注意,从2.3开始,无需通过layer.config来加载拓展模块

    • type

    • 基本层类型
    • 类型:Number,默认:0
    • layer提供了5种层类型。可传入的值有:0(信息框,默认)1(页面层)2(iframe层)3(加载层)4(tips层)。 若你采用layer.open({type: 1}) 方式调用,则type为必填项(信息框除外)
    • title

    • 标题
    • 类型:String/Array/Boolean,默认:'信息'
    • title支持三种类型的值,若你传入的是普通的字符串,如title :'我是标题' ,那么只会改变标题文本;若你还需要自定义标题区域样式,那么你可以title: ['文本', 'font-size:18px;'] ,数组第二项可以写任意css样式;如果你不想显示标题栏,你可以title: false
    • content

    • 内容
    • 类型:String/DOM/Array,默认:''
    • content可传入的值是灵活多变的,不仅可以传入普通的html内容,还可以指定DOM,更可以随着type的不同而不同。譬如:
    • </>code /!* 如果是页面层 */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}); 复制代码
    • skin

    • 样式类名
    • 类型:String,默认:''
    • skin不仅允许你传入layer内置的样式class名,还可以传入您自定义的class名。这是一个很好的切入点,意味着你可以借助skin轻松完成不同的风格定制。目前layer内置的skin有:layui-layer-lan layui-layer-molv,未来我们还会选择性地内置更多,但更推荐您自己来定义。以下是一个自定义风格的简单例子
    • </>code //单个使用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调试工具,定义更多样式控制层更多的区域。 复制代码
    • 你也可以去查看layer皮肤制作说明
    • area

    • 宽高
    • 类型:String/Array,默认:'auto'
    • 在默认状态下,layer是宽高都自适应的,但当你只想定义宽度时,你可以area: '500px' ,高度仍然是自适应的。当你宽高都要定义时,你可以area: ['500px', '300px']
    • 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。如:
    • </>code //eg1layer.alert('酷毙了', {icon: 1});//eg2layer.msg('不开心。。', {icon: 5});//eg3layer.load(1); //风格1的加载 复制代码
    • btn

    • 按钮
    • 类型:String/Array,默认:'确认'
    • 信息框模式时,btn默认是一个确认按钮,其它层类型则默认不显示,加载层和tips层则无效。当您只想自定义一个按钮时,你可以btn: '我知道了' ,当你要定义两个按钮时,你可以btn: ['yes', 'no'] 。当然,你也可以定义更多按钮,比如:btn: ['按钮1', '按钮2', '按钮3', …] ,按钮1的回调是yes,而从按钮2开始,则回调为btn2: function(){},以此类推。如:
    • </>code //eg1 layer.confirm('纳尼?', { btn: ['按钮一', '按钮二', '按钮三'] //可以无限个按钮 ,btn3: function(index, layero){ //按钮【按钮三】的回调 }}, function(index, layero){ //按钮【按钮一】的回调}, function(index){ //按钮【按钮二】的回调}); //eg2layer.open({ content: 'test' ,btn: ['按钮一', '按钮二', '按钮三'] ,yes: function(index, layero){ //按钮【按钮一】的回调 } ,btn2: function(index, layero){ //按钮【按钮二】的回调 //return false 开启该代码可禁止点击该按钮关闭 } ,btn3: function(index, layero){ //按钮【按钮三】的回调 //return false 开启该代码可禁止点击该按钮关闭 } ,cancel: function(){ //右上角关闭回调 //return false 开启该代码可禁止点击该按钮关闭 }}); 复制代码
    • btnAlign

    • 按钮排列
    • 类型:String,默认:r
    • 你可以快捷定义按钮的排列位置,btnAlign的默认值为r,即右对齐。该参数可支持的赋值如下:
    • 值备注btnAlign: 'l'按钮左对齐btnAlign: 'c'按钮居中对齐btnAlign: 'r'按钮右对齐。默认值,不用设置
    • closeBtn

    • 关闭按钮
    • 类型:String/Boolean,默认:1
    • layer提供了两种风格的关闭按钮,可通过配置12来展示,如果不显示,则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毫秒)
    • id

    • 用于控制弹层唯一标识
    • 类型:String,默认:空字符
    • 设置该值后,不管是什么类型的层,都只允许同时弹出一个。一般用于页面层和iframe层模式
    • anim

    • 弹出动画
    • 类型:Number,默认:0
    • 我们的出场动画全部采用CSS3。这意味着除了ie6-9,其它所有浏览器都是支持的。目前anim可支持的动画类型有0-6 如果不想显示动画,设置 anim: -1 即可。另外需要注意的是,3.0之前的版本用的是 shift 参数
    • 值备注anim: 0平滑放大。默认anim: 1从上掉落anim: 2从最底部往上滑入anim: 3从左滑入anim: 4从左翻滚anim: 5渐显anim: 6抖动
    • isOutAnim

    • 关闭动画 (layer 3.0.3新增)
    • 类型:Boolean,默认:true
    • 默认情况下,关闭层时会有一个过度动画。如果你不想开启,设置 isOutAnim: false 即可
    • maxmin

    • 最大最小化。
    • 类型:Boolean,默认:false
    • 该参数值对type:1type:2有效。默认不显示最大小化按钮。需要显示配置maxmin: true即可
    • fixed

    • 固定
    • 类型:Boolean,默认:true
    • 即鼠标滚动时,层是否固定在可视区域。如果不想,设置fixed: false即可
    • resize

    • 是否允许拉伸
    • 类型:Boolean,默认:true
    • 默认情况下,你可以在弹层右下角拖动来拉伸尺寸。如果对指定的弹层屏蔽该功能,设置 false即可。该参数对loading、tips层无效
    • resizing

    • 监听窗口拉伸动作
    • 类型:Function,默认:null
    • 当你拖拽弹层右下角对窗体进行尺寸调整时,如果你设定了该回调,则会执行。回调返回一个参数:当前层的DOM对象
    • </>code resizing: function(layero){ console.log(layero);} 复制代码
    • scrollbar

    • 是否允许浏览器出现滚动条
    • 类型:Boolean,默认:true
    • 默认允许浏览器滚动,如果设定scrollbar: false,则屏蔽
    • maxWidth

    • 最大宽度
    • 类型:Number,默认:360
    • 请注意:只有当area: 'auto' 时,maxWidth的设定才有效。
    • maxHeight

    • 最大高度
    • 类型:Number,默认:无
    • 请注意:只有当高度自适应时,maxHeight的设定才有效。
    • zIndex

    • 层叠顺序
    • 类型:,默认:19891014(贤心生日 0.0)
    • 一般用于解决和其它组件的层叠冲突。
    • move

    • 触发拖动的元素
    • 类型:String/DOM/Boolean,默认:'.layui-layer-title'
    • 默认是触发标题区域拖拽。如果你想单独定义,指向元素的选择器或者DOM即可。如move: '.mine-move' 。你还配置设定move: false来禁止拖拽
    • moveOut

    • 是否允许拖拽到窗口外
    • 类型:Boolean,默认:false
    • 默认只能在窗口内拖拽,如果你想让拖到窗外,那么设定moveOut: true即可
    • moveEnd

    • 拖动完毕后的回调方法
    • 类型:Function,默认:null
    • 默认不会触发moveEnd,如果你需要,设定moveEnd: function(layero){} 即可。其中layero为当前层的DOM对象
    • tips

    • tips方向和颜色
    • 类型:Number/Array,默认:2
    • tips层的私有参数。支持 四个方向,通过1-4进行方向设定。如tips: 3则表示在元素的下面出现。有时你还可能会定义一些颜色,可以设定tips: [1, '#c00']
    • tipsMore

    • 是否允许多个tips
    • 类型:Boolean,默认:false
    • 允许多个意味着不会销毁之前的tips层。通过tipsMore: true开启
    • success

    • 层弹出后的成功回调方法
    • 类型:Function,默认:null
    • 当你需要在层创建完毕时即执行一些语句,可以通过该回调。success会携带两个参数,分别是当前层DOM 当前层索引。如:
    • </>code layer.open({ content: '测试回调', success: function(layero, index){ console.log(layero, index); }});