layer.open如何关闭自身弹出窗口

Posted 30go

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了layer.open如何关闭自身弹出窗口相关的知识,希望对你有一定的参考价值。

1. 弹出窗口中本身可以添加按钮事件如下:

layer.open({
 title: ‘打印‘
,type: 2
,content: [ctx + ‘/saleOrder/eorderEdit?orderNbr=‘ + orderNbr, ‘yes‘]
,area:[‘900px‘, ‘600px‘]
        ,btn: [‘打印预览‘, ‘关闭‘]
    ,btnAlign:‘c‘
    ,yes: function(index, layero){
        //这里怎么获取到弹出框到表单内容??
    }
    ,btn2: function(){
        layer.closeAll();
    }
});

  但是这里在点击打印预览时候,想获取到页面中到form表单中到值比较麻烦。

  所有我就直接在弹出框中定义了button按钮。

  2. 调整后如下,先注释掉父级的按钮:

             layer.open({
                 title: ‘打印‘
                ,type: 2
                ,content: [ctx + ‘/saleOrder/eorderEdit?orderNbr=‘ + orderNbr, ‘yes‘]
                ,area:[‘900px‘, ‘600px‘]
//                         ,btn: [‘打印预览‘, ‘关闭‘]
//                     ,btnAlign:‘c‘
//                     ,yes: function(index, layero){
//                         //这里怎么获取到弹出框到表单内容??
//                     }
//                     ,btn2: function(){
//                         layer.closeAll();
//                     }
             });

然后在弹出的框中添加button

        <!-- foot button -->
        <div class="layui-form-item layui-layout-admin">
                <div class="layui-input-block">
                        <div class="layui-footer" >
                                <button class="layui-btn" lay-submit="" lay-filter="form-print">打印预览</button>
                                <button class="layui-btn" onclick="formClose();">关闭</button>
                        </div>
                </div>
        </div>      

接下来遇到的一个问题就是,怎么关闭这个弹出框。

3. 在弹出框中使用onclick事件触发关闭自身的动作。

       //关闭自身 
       window.formClose = function(){
              var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
              //layer.msg(index);
              parent.layer.close(index); //再执行关闭   
        }

 

以上是关于layer.open如何关闭自身弹出窗口的主要内容,如果未能解决你的问题,请参考以下文章

layer 打开关闭弹出窗口与获取父窗口值

layer弹出层显示在top顶层

layer.open怎么设置弹出框之后,父窗口呈现灰色

fastadmin: layer.open 弹出层如何在表单提交之后自动关闭?

layer.open如何在iframe层关闭自己

layer弹出加载层不显示