标签:blog 加载 需要 另一个 get 父页面 lan func 阅读
Layer是一款近年来备受青睐的web弹层组件,基于jquery,易用、实用,兼容包括IE6在内的所有主流浏览器,拥有丰富强大的可自定义的功能。
Layer官网地址:http://layer.layui.com/
layer.open({ type: 2, title: ‘layer mobile页‘, shadeClose: true, shade: 0.8, area: [‘380px‘, ‘90%‘], content: ‘mobile/‘ //iframe的url });
content参数可传入要打开的页面,type参数传2,即可打开iframe类型的弹层
layer.open({ type: 2, title: false, closeBtn: 0, //不显示关闭按钮 shade: [0], area: [‘340px‘, ‘215px‘], offset: ‘rb‘, //右下角弹出 time: 2000, //2秒后自动关闭 anim: 2, content: [‘test/guodu.html‘, ‘no‘], //iframe的url,no代表不显示滚动条 end: function(){ //此处用于演示 layer.open({ type: 2, title: ‘很多时候,我们想最大化看,比如像这个页面。‘, shadeClose: true, shade: false, maxmin: true, //开启最大化最小化按钮 area: [‘893px‘, ‘600px‘], content: ‘//fly.layui.com/‘ }); } });
可根据项目需求,简单封装弹出层打开方法,如下:
//在弹出层A(子页面1)打开新弹出层B(子页面2),弹出层A、B在同一DOM层级,即父页面内有多个iframe,子页面2不嵌套在子页面1中;
//在弹出层A(子页面1)中封装如下方法,在需要触发打开新弹出层B事件中执行如下方法; function openLayerUrl(url, width, height) { parent.layer.open({ type: 2, title: false, closeBtn: false, shadeClose: false, shade: 0.6, border: [0], area: [width <= 0 ? "auto" : width + ‘px‘, height <= 0 ? "auto" : height + ‘px‘], content: url, }) }
//当在iframe页面关闭自身时,在iframe页执行以下js脚本 var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引 parent.layer.close(index); //再执行关闭
如果没有弹层叠加等复杂逻辑,可根据需要关闭所有弹出层
layer.closeAll(); //疯狂模式,关闭所有层 layer.closeAll(‘dialog‘); //关闭信息框 layer.closeAll(‘page‘); //关闭所有页面层 layer.closeAll(‘iframe‘); //关闭所有的iframe层 layer.closeAll(‘loading‘); //关闭加载层 layer.closeAll(‘tips‘); //关闭所有的tips层
layer.iframeSrc(index, ‘http://sentsin.com‘) //官方示例,其中参数index为iframe索引,第二个参数为iframe的URL,暂未使用过
parent.$("iframe").each(function () { $(this).attr(‘src‘, $(this).attr(‘src‘));//需要引用jquery })
如果刷新所有iframe不影响,则可以重置所有iframe。在弹层A关闭后,需要刷新弹层B,在弹层A执行以上脚本后关闭当前弹层A;
var collectionId = parent.$("#hideCollectionId").val();//可在父页面定义隐藏域,id为hideCollectionId,需要引用jquery
比如在弹出层A按钮打开另一个弹出层B,可在layer.open()函数content参数配置中,以URL形式传参即可,(content:‘http://www.baidu.com?id=‘+100)
<a href="javascript:void(0);" class="a1"
onclick="openLayerUrl(‘@domainTeamUrl/Notice/Update?id=‘+ @Model.Id,876,575);closeLayer()">修改</a>
//在ASP.Net MVC Razor视图中使用示例,openLayerUrl()为本篇中介绍的打开Layer弹出层的封装方法,closeLayer()为封装的关闭layer弹出层的方法;
也可以考虑使用success(弹出后回调)、end(销毁后回调)、cancel(关闭回调)等参数配置中做其他工作;
如果使用嵌套的iframe也是可以的,如iframe弹出层B(子页面2)嵌套在iframe弹出层A(子页面1)中,iframe弹出层A嵌套在父页面中,
jquery取得父页面元素:
parent.parent.$("#hideCollectionId").val();//取得父页面之父页面的非动态生成的元素
$("#hideCollectionId",parent.parent.document).val();//取得父页面之父页面的动态生成的元素
有时候不想让iframe弹层出现滚动条,则可以在content参数中传入一个字符串数组
layer.open({ type: 2, content: ‘http://sentsin.com‘ //这里content是一个URL,如果你不想让iframe出现滚动条,你还可以content: [‘http://sentsin.com‘, ‘no‘] });
更多使用技巧,请移步官网阅读弹层组件开发文档
本篇介绍了Layer弹出层组件在多个弹出层场景使用及传参方法,包括非嵌套弹出层和嵌套弹出层打开与关闭方法。
标签:blog 加载 需要 另一个 get 父页面 lan func 阅读
原文地址:http://www.cnblogs.com/EvanFan/p/7718065.html