欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

layui框架中layer父子页面交互的方法分析

程序员文章站 2022-07-05 19:27:16
本文实例讲述了layui框架中layer父子页面交互的方法。分享给大家供大家参考,具体如下: layer是一款近年来备受青睐的web弹层组件,官网地址是:http://l...

本文实例讲述了layui框架中layer父子页面交互的方法。分享给大家供大家参考,具体如下:

layer是一款近年来备受青睐的web弹层组件,官网地址是:http://layer.layui.com/

可以从官网上下载最新版本。

还可点击此处。

当layer以iframe层的方式弹出新的窗口(子页面),如何在子页面中访问父页面的元素和函数。

1、访问父页面元素值

var parentid=parent.$("#id").val();//访问父页面元素值

2、访问父页面方法

var parentmethodvalue=parent.getmethodvalue();//访问父页面方法

3、如何关闭弹出的子页面窗口

var index = parent.layer.getframeindex(window.name); //获取窗口索引
parent.layer.close(index);//关闭弹出的子页面窗口

4、如何从子页面执行刷新父页面操作

parent.location.reload(); // 父页面刷新

附:layer弹出多个iframe找到父页面的方法

父页面:

function aa(){
    var index = parent.layer.getframeindex(window.name);
    var iframename = 'layui-layer-iframe'+index;
    opendialog1('选择xxx', '${ctx}/*****,'800px', '500px',iframename);
}
function opendialog1(title,url,width,height,target){
    top.layer.open({
      type: 2,
      area: [width, height],
      title: title,
      maxmin: true, //开启最大化最小化按钮
      content: url ,
      btn: ['确定', '关闭'],
      yes: function(index, layero){
         var body = top.layer.getchildframe('body', index);
         var iframewin = layero.find('iframe')[0]; //得到iframe页的窗口对象,执行iframe页的方法:iframewin.method();
         var inputform = body.find('#inputform');
         var top_iframe;
         if(target){
           top_iframe = target;//如果指定了iframe,则在改frame中跳转
         }else{
           top_iframe = top.getactivetab().attr("name");//获取当前active的tab的iframe
         }
         inputform.attr("target",top_iframe);//表单提交成功后,从服务器返回的url在当前tab中展示
         if(iframewin.contentwindow.dosubmit(top_iframe) ){
           top.layer.close(index);//关闭对话框。
           top.window[iframename].frames.location.reload();//刷新父亲
         }
     },
     cancel: function(index){
      }
  });
}
//子页面回调方法
function addrecord(name,chainname){
  alert(name);
}

子页面

function dosubmit(iframename) {
    var sel=$("tbody tr td input.i-checks:checked");
    var size = sel.size();
    if(size==0){
      top.layer.alert('请至少选择一条数据!', {icon: 0, title:'警告'});
      return false;
    }else{
      for(var i=0;i<size;i++){
        top.window[iframename].addrecord(sel[i].name,sel[i].value);
      }
      return true;
    }
}

另:layui完整源码可点击此处。

希望本文所述对大家基于layui框架的程序设计有所帮助。