window.open()方法以post请求方式打开新窗口

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title>window.open()方法以post请求方式打开新窗口</title>
</head>
<body>
<button type="button" οnclick="open()">打开</button>
<script src="jquery-1.10.2.js"></script>
<script>
    function open() {
        var url = "";
        // 请求参数 postData
        var postData = {};
        postData.param1 = "param1";
        postData.param2 = "param2";
        openNewWindow(url,postData);
    }

    /**
     *
     * @param url 请求地址
     * @param postData 请求参数
     */
    function openNewWindow(url,postData) {
        var winWidth = $(window).width() * 0.8;
        var winHeight = $(window).height() * 0.9;
        var winLeft = $(window).width() * 0.1;
        var newWin = window.open("about:blank","_blank","width="+ winWidth +",height="+ winHeight +",top=10,left="+ winLeft +",menubar=no,resizable=no,location=no,status=no");

        // 组装form表单
        var html = "<form action='"+ url +"' method='post'>";
        jQuery.each(postData, function (i,obj) {
            html += "<input type='text' name='"+ i +"' value='"+ obj +"' style='display: none'>";
        });
        html += "</form>";
        newWin.document.body.innerHTML = html;
        newWin.document.forms[0].submit();

        // 监听窗口关闭事件
        var loop = setInterval(function () {
            if(newWin.closed) {
                clearInterval(loop);
            }
        }, 500);
    }
</script>
</body>
</html>

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值