引用layer.js后 弹窗为啥会在页面最底部出现

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了引用layer.js后 弹窗为啥会在页面最底部出现相关的知识,希望对你有一定的参考价值。

layer提供7中动画类型,属性:anim,其中一种动画就是从底部出现。PS:目前anim可支持的动画类型有0-6 如果不想显示动画,设置 anim: -1 即可。另外需要注意的是,3.0之前的版本用的是 shift 参数 参考技术A

这个要看layer中content的内容了

/!*
如果是页面层
*/
layer.open(
type: 1,
content: '传入任意的文本或html' //这里content是一个普通的String
);
layer.open(
type: 1,
content: $('#id') //这里content是一个DOM,注意:最好该元素要存放在body最外层,否则可能被其它的相对元素所影响
);

看第二个layer.open:这里content是一个DOM,注意:最好该元素要存放在body最外层,否则可能被其它的相对元素所影响

这里有一篇文章关于 layer 弹层的问题,希望可以帮助到你:

layer遮罩挡住窗体问题的解决方法

参考技术B <script src="__PUBLIC__/js/jquery.min.js"></script>
<script src="__PUBLIC__/js/layer.js"></script>
<script>
$('#test2').on('click',function()
layer.open(
type:1,
area:['600px','360px'],
shadeClose:true,//点击遮罩关闭
content:'\\<\\div style="padding:20px;">asdfasdf\\<\\/div>'
);
);
</script>这是代码

layer.js 注册登录切换的问题

layer.js 是一个很好用的弹窗框架,使用的时候很方便,但是今天遇到一个问题,让我很头疼啊,一直都做不出来,就是登录和注册弹窗的切换问题

这里涉及到两个页面:guide.html 即父页面,denglu.html 页面,即子页面

在父页面中打开子页面:

 1  var adaoli = $("ul.nav ul.right div.dingwei li a");
 2     Adenglureg.on("click", function () {
 3         var index = $(this).index("ul.wel li.left a");
 4         if (index == 0) {
 5             indexk = layer.open({
 6                 title: false,
 7                 type: 2,
 8                 content: [\'./detail/denglu.html\', \'no\'],
 9                 area: [\'400px\', \'420px\'],
10 
11             });
12         } else if (index == 1) {
13             indexk = layer.open({
14                 title: false,
15                 type: 2,
16                 content: [\'./detail/zhuce.html\', \'no\'],
17                 area: [\'400px\', \'650px\'],
18             });
19         };

点击guide.html 上的“登录”,就弹出了以上的弹框;现在想直接点击弹框上(右下角)“注册”按钮,切换到注册页面:

尝试:在 guide.html  中写:

1   $("#backzhucce").on("click", function () {
2         layer.closeAll();
3         layer.open({
4             title: false,
5             type: 2,
6             content: [\'./detail/zhuce.html\', \'no\'],
7             area: [\'400px\', \'650px\'],
8         });
9     });

结果:没有反应,也没有报错

 

尝试:在denglu.html 中写:

1 $("#backzhucce").on("click", function () {
2         layer.closeAll();
3         layer.open({
4             title: false,
5             type: 2,
6             content: [\'../detail/zhuce.html\', \'no\'],
7             area: [\'400px\', \'650px\'],
8         });
9     });

结果:他直接在弹框中重新打开了一个弹框,显然是不对的,不是我们所要的,我们要的应该是这样:先关闭现有的弹框,然后重新打开注册弹框

 

在百度里看了一下:将denglu.html 中内容改写为:

1     $("#backzhucce").on("click", function () {
2         parent.layer.closeAll();
3         parent.layer.open({
4             title: false,
5             type: 2,
6             content: [\'./detail/zhuce.html\', \'no\'],
7             area: [\'400px\', \'650px\'],
8         });
9     });

运行结果:报错

 

不知道是什么原因,于是一直百度,后来与一个朋友讨论了一下:把代码放在服务器上重新运行:

denglu.html 中不变,仍然为:

1  $("#backzhucce").on("click", function () {
2         parent.layer.closeAll();
3         parent.layer.open({
4             title: false,
5             type: 2,
6             content: [\'./detail/zhuce.html\', \'no\'],
7             area: [\'400px\', \'650px\'],
8         });
9     });

运行结果:终于OK le ,先关掉,再重新弹出注册弹框,这才是我们想要的结果

 

终于OK 了,这里涉及到两个页面,需要在服务器上运行;

虽然耗费了好些时间,但是挺高兴的,~~~

 

记住了,需要在服务器上运行,直接用浏览器打开是不行的~~~

 

以上是关于引用layer.js后 弹窗为啥会在页面最底部出现的主要内容,如果未能解决你的问题,请参考以下文章

为啥eclipse每次新建项目时都会出现一个错误弹窗,并会在src下自动生成module-info.java文档?

layer.js 注册登录切换的问题

layer.js 中弹框显示不全的问题

基于iframe父子页面传值的方法。

移动端弹窗 layer.js 使用

Vue将弹窗页面作为pdf下载下来