window.open的小技巧分享(转)

摘要:
1234567891011121314151617181920212223242526272829303132333435363738394041<窗打开提示<单击新建窗口<data=newWindow.data;

   今天再次谈起window.open是因为发现了一个比较好玩的小技巧,详细内容我们稍后详细说明。

 
    聊到window.open,不得不说明一下他的使用方法,主要有两种形式:
 
  • window.open()没有任何参数,这种方式可以新标签打开页面
  • window.open(url, name, pars),带有参数的可以在当前页面打开窗口
 
    详细的使用方法,之前有过介绍,如果想了解,可以点击这里
 
    知道了如何使用,接下来介绍几个特别的属性和方法(下面所说到的都是同域页面):
 
  1. window.open()打开的窗口或者新标签返回窗口的window对象
  2. 在新窗口里也可以取到父窗口(执行window.open的环境)的window对象,通过window.opner
  3. window.close()方法可以关闭窗口
  4. window.onunload和window.onbeforeunload事件,监听窗口关闭情况
 
    了解了上面的使用方法之后,介绍一个很巧妙的使用方式。
 
    一共有两个页面:第一个页面(window.open.html)的功能是新开一个窗口,第二个页面(window.close.html)为新开窗口的请求的返回信息,可以在第一个页面中,监听新开窗口请求的数据。下面分别介绍两个页面:
 
    window.open.html页面内容如下:
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<!DOCTYPE>
<html>
<head>
    <metacharset="utf-8">
    <title>window.open小技巧</title>
</head>
<body>
我是窗口:window.open
<buttonid="openWindow">点击新开窗口</button>
<scripttype="text/javascript">
(function() {
    var openWindowEl = document.getElementById('openWindow');
    var newWindow;
    var data;
   
    window.windowName = 'window.open';
 
    openWindowEl.onclick = function() {
        newWindow = window.open('window.close.php', '_blank', 'width=500,height=500;');
        //需要window.close.html js正常执行之后才行
        /*setTimeout(function() {
            console.log(newWindow.userName);
        }, 1000);*/
        newWindow.onbeforeunload = function() {
            userName = newWindow.windowName;
            data = newWindow.data;
        }
       
        newWindow.onunload = function() {
            alert(userName);
            if(data.errno == 0) {
                alert(data.errmsg);
            }else {
                alert(data.errmsg);
            }
        }
    };
})();
</script>
</body>
</html>
  
  window.close.html页面内容如下:
   
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE>
<html>
<head>
    <metacharset="utf-8">
    <title>window新开窗口</title>
</head>
<body>
我是窗口:window.close
<scripttype="text/javascript">
(function() {
    window.windowName = 'window.close';
    if(Math.random() > 0.5) {
        window.data = {
            errno: 0,
            errmsg: '成功~'
        };
    }else {
        window.data = {
            errno: 1,
            errmsg: '数据异常~'
        }; 
    }
    setTimeout(function() {
        //拿到的是父窗口的window
        alert(window.opener.windowName);
    }, 100);
    setTimeout(function() {
        window.close();
    }, 1000);
})();
</script>
</body>
</html>
 
    通过上面介绍的这种方式可以解决,微博等第三方登录无刷新父页面得知返回状态的需求。同时也是解决跨域请求的一个比较好的方式(安全性不知道如何)。测试小例子
 
    今天就分享这么一个小技巧吧~
http://www.cnblogs.com/xiaoheimiaoer/p/4734977.html

免责声明:文章转载自《window.open的小技巧分享(转)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇flink 启动job命令VSIX 插件右键菜单下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

有道词典中的OCR功能:第三方库的变化

  之前有点好奇有道词典中的OCR功能,具体来说就是强力取词功能。我知道的最有名的OCR库是tesseract,这个库是惠普在早些年前开源的。   在用python做爬虫处理验证码的时候,就会用到这个库,对应的python封装版本名字叫pytesseract。在github上可以找到tesseract的源码。   不过,此前在有道词典安装之后的文件夹中,我...

Vim 命令整理

1. 文件命令 2. 模式切换 3. 移动命令 4. 书签命令 5. 修改命令 6. 可视化操作 7. 区域选择 8. 宏命令 9. 分屏 10. 系统设置命令 1. 文件命令 [:]开始的命令需要输入[Enter]结束   :q:退出 :q!:退出不保存 :qa!:退出所有文件不保存 :w:保存 :e <file>:关闭当前文件并打开另一个...

百度地图滚轮缩放时产生位置偏移 问题

最近在调用百度地图的过程中,发生了在地图上滚轮缩放,结果产生了位置偏移的情况,同样在移动端,双指缩放也有同样的问题。 这个问题产生的原因主要是因为百度地图加载的位置因为定位等原因,与整个html 页面产生了不同步滚动的问题。 百度地图的缩放是基于body层的,如果body层有滚动条,并且不在最顶端,在当前位置插入了百度地图,也就是出现该问题时的状态,这个时...

Mongoose

Mongoose轻松搞定MongoDB MEAN开发栈中使用MongoDB的时候,与之配对的ORM最好的选择就是Mongoose了。本文就和大家一起探讨一下如何使用Mongoose来实现MongoDB的增删改查。 为了能使文中的例子更加生动,我们会实现一个对于用户的增删改查的RESTful API。 Mongoose简介 mongoose是一个nodejs...

JS 页面弹窗,弹出DIV并使整个页面背景变暗的功能的实现代码

首先写一个遮罩层div,然后再写一个弹窗的div <!-- 遮罩层 --><div style="background: #000; position: absolute; left: 0px; top: 0px; 100%; filter: alpha(opacity=30); opacity: 0.3; display: non...

通过form上传文件(php)

 前段代码 //提交form表单,包含file //方法1:使用jquery-form.js插件 /* $("form").ajaxSubmit(function (resp_img_url) { //直接返回图片的url $("#btn_titlepic").html(str_old); $("#img_titlepic").attr("src"...