Chrome37+代替window.showModalDialog模态窗口方法

这篇博客介绍了如何利用HTML5的window.open和window.postMessage方法来替代Chrome37及以上版本不再支持的window.showModalDialog模态窗口。通过在父级页面调用dialog.js并设置参数,可以打开子级页面。子级页面同样引用dialog.js并通过oDialog.sendMessage返回数据到父级页面。提供了一个详细的调用示例。
摘要由CSDN通过智能技术生成

原理是利用HTML5中的window.open()和window.postMessage()

window.postMessage详情请查看:window.postMessage - Web API 接口参考 | MDN

首先是自己写的dialog.js

function Dialog() {
    var d = this.dialog = Dialog.prototype;
    
    d.Popup = null;

    //初始化
    d.init = function () {
        //執行頁面消息監聽事件
        if (!d.isModalDialog()) {
            d.addEventListener();
        }
    };

    /**
     * 後台系統彈窗
     * @param {String}      url             窗口地址
     * @param {Int}         width           窗口寬度
     * @param {Int}         height          窗口高度
     * @param {Boolean}     bScroll         窗口是否允許滾動條
     * @param {Function}    evt[可選]       窗口返回數據回調函數
     */
    d.show = function (url, width,
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值