首页 > web前端 > js教程 > 正文

layer.js之父子页面实例详解

韦小宝
发布: 2018-03-12 10:03:06
原创
1838 人浏览过

本文主要和大家分享layer.js之父子页面实例,关于父子页面的知识我们可能有所了解,希望本文能帮助大家更加掌握layer.js之父子页面。

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.js弹出多个<span style="font-size: 18px;">iframe</span>如何找到父页面方法

父亲页面–

function aa() {
    var index = parent.layer.getFrameIndex(window.name);
    var iframeName = &#39;layui-layer-iframe&#39; + index;
    openDialog1(&#39;选择XXX&#39;, &#39;${ctx}/*****,&#39;800px &#39;, &#39;500px &#39;,iframeName);      
    }  &#39;
登录后复制
function openDialog1(title, url, width, height, target) {
    top.layer.open({
        type: 2,
        area: [width, height],
        title: title,
        maxmin: true,
        //开启最大化最小化按钮  
        content: url,
        btn: [&#39;确定&#39;, &#39;关闭&#39;],
        yes: function(index, layero) {
            var body = top.layer.getChildFrame(&#39;body&#39;, index);
            var iframeWin = layero.find(&#39;iframe&#39;)[0]; //得到iframe页的窗口对象,执行iframe页的方法:iframeWin.method();  
            var inputForm = body.find(&#39;#inputForm&#39;);
            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(&#39;请至少选择一条数据!&#39;, {
            icon: 0,
            title: &#39;警告&#39;
        });        return false;
    } else {        for (var i = 0; i < size; i++) {
            top.window[iframeName].addRecord(sel[i].name, sel[i].value);
        }        return true;
    }
}
登录后复制

  以上就是本篇文章的内容,大家对layer不熟悉的同学可以看看哦!

相关推荐:

layer子层给父层页面元素赋值实例讲解

以上是layer.js之父子页面实例详解的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板