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


Posted in Javascript onNovember 15, 2017

本文实例讲述了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框架的程序设计有所帮助。

Javascript 相关文章推荐
JavaScript中的事件处理
Jan 16 Javascript
JavaScript 判断浏览器类型及版本
Feb 21 Javascript
关于javascript中this关键字(翻译+自我理解)
Oct 20 Javascript
javascript 节点排序 2
Jan 31 Javascript
js一般方法改写成面向对象方法的无限级折叠菜单示例代码
Jul 04 Javascript
JavaScript的9种继承实现方式归纳
May 18 Javascript
JS+CSS实现下拉刷新/上拉加载插件
Mar 31 Javascript
js-FCC算法-No repeats please字符串的全排列(详解)
May 02 Javascript
浅谈angular2子组件的事件传递(任意组件事件传递)
Sep 30 Javascript
新手如何快速理解js异步编程
Jun 24 Javascript
JavaScript enum枚举类型定义及使用方法
May 15 Javascript
JavaScript的一些小技巧分享
Jan 06 Javascript
layer实现关闭弹出层刷新父界面功能详解
Nov 15 #Javascript
layui.js实现的表单验证功能示例
Nov 15 #Javascript
javascript函数的节流[throttle]与防抖[debounce]
Nov 15 #Javascript
基于jQuery实现定位导航位置效果
Nov 15 #jQuery
详解如何使用PM2将Node.js的集群变得更加容易
Nov 15 #Javascript
vuejs实现本地数据的筛选分页功能思路详解
Nov 15 #Javascript
Js判断H5上下滑动方向及滑动到顶部和底部判断的示例代码
Nov 15 #Javascript
You might like
php 购物车的例子
2009/05/04 PHP
php获取post中的json数据的实现方法
2011/06/08 PHP
使用php shell命令合并图片的代码
2011/06/23 PHP
php上传文件,创建递归目录的实例代码
2013/10/18 PHP
用js生产批量批处理执行命令
2008/07/28 Javascript
IE关闭时判断及AJAX注销案例学习
2013/02/18 Javascript
Extjs Gird 支持中文拼音排序实现代码
2013/04/15 Javascript
Javascript让DEDECMS告别手写Tag
2014/09/01 Javascript
javascript 动态创建表格的2种方法总结
2015/03/04 Javascript
JavaScript中constructor()方法的使用简介
2015/06/05 Javascript
jQuery调用WebMethod(PageMethod) NET2.0的方法
2016/04/15 Javascript
JS 组件系列之Bootstrap Table的冻结列功能彻底解决高度问题
2017/06/30 Javascript
详解Vue微信公众号开发踩坑全记录
2017/08/21 Javascript
Javascript 严格模式use strict详解
2017/09/16 Javascript
javascript用rem来做响应式开发
2018/01/13 Javascript
浅谈ng-zorro使用心得
2018/12/03 Javascript
详解一些适用于Node.js的命名约定
2019/12/08 Javascript
JavaScript隐式类型转换代码实例
2020/05/29 Javascript
深入理解Python装饰器
2016/07/27 Python
在python中实现同行输入/接收多个数据的示例
2019/07/20 Python
春节到了 教你使用python来抢票回家
2020/01/06 Python
python Tensor和Array对比分析
2020/01/08 Python
使用python-pptx包批量修改ppt格式的实现
2020/02/14 Python
python2.7使用scapy发送syn实例
2020/05/05 Python
C#如何进行LDAP用户校验
2012/11/21 面试题
养牛场项目建议书
2014/05/13 职场文书
食品安全汇报材料
2014/08/18 职场文书
诉讼授权委托书
2014/10/15 职场文书
个园导游词
2015/02/04 职场文书
工作试用期自我评价
2015/03/10 职场文书
2015大学生求职信范文
2015/03/20 职场文书
幼儿园小班班务总结
2015/08/03 职场文书
学法用法心得体会(2016推荐篇)
2016/01/21 职场文书
中秋节英文祝福语句(14句)
2019/09/11 职场文书
分布式架构Redis中有哪些数据结构及底层实现原理
2022/03/13 Redis
Apache Linkis 中间件架构及快速安装步骤
2022/03/16 Servers