window.open 打开模态窗口,并修改标题title。

  • Post author:
  • Post category:其他




方法一:onload

// 打开模态窗口

// 打开模态窗口
  openWindow1(url, title, w, h) {
    const dualScreenLeft = window.screenLeft !== undefined ? window.screenLeft : screen.left;
    const dualScreenTop = window.screenTop !== undefined ? window.screenTop : screen.top;

    const width = window.innerWidth ? window.innerWidth : document.documentElement.clientWidth ? document.documentElement.clientWidth : screen.width;
    const height = window.innerHeight ? window.innerHeight : document.documentElement.clientHeight ? document.documentElement.clientHeight : screen.height;

    const left = ((width / 2) - (w / 2)) + dualScreenLeft;
    const top = ((height / 2) - (h / 2)) + dualScreenTop;
    const newWindow = window.open(url, title, 'toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=no, resizable=yes, copyhistory=no, width=' + w + ', height=' + h + ', top=' + top + ', left=' + left);
    newWindow.onload = function () {
      // 定时器根据实际情况取舍。
      setTimeout(function () {
        newWindow.document.title = title;
      }, 100)
    }

    if (window.focus) {
      newWindow.focus();
    }
  }



方法二 :iframe

// 打开模态窗口

// 打开模态窗口
  openWindow(url, title, w, h) {
    const dualScreenLeft = window.screenLeft !== undefined ? window.screenLeft : screen.left;
    const dualScreenTop = window.screenTop !== undefined ? window.screenTop : screen.top;

    const width = window.innerWidth ? window.innerWidth : document.documentElement.clientWidth ? document.documentElement.clientWidth : screen.width;
    const height = window.innerHeight ? window.innerHeight : document.documentElement.clientHeight ? document.documentElement.clientHeight : screen.height;

    const left = ((width / 2) - (w / 2)) + dualScreenLeft;
    const top = ((height / 2) - (h / 2)) + dualScreenTop;
    const newWindow = window.open('about:blank', title, 'toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=no, resizable=yes, copyhistory=no, width=' + w + ', height=' + h + ', top=' + top + ', left=' + left);
    newWindow.document.title = title;

    let iframe = document.createElement('iframe');
    iframe.src = url;
    iframe.style.width = '100%';
    iframe.style.height = '100vh';
    iframe.style.margin = '0';
    iframe.style.padding = '0';
    iframe.style.overflow = 'hidden';
    iframe.style.border = 'none';

    newWindow.document.body.style.margin = '0';
    newWindow.document.body.appendChild(iframe);

    if (window.focus) {
      newWindow.focus();
    }
  }




推荐 第二种

第一种嵌套少一层,但是加载的html时候会优先加载自己的title,导致标题会变动一次,显示效果差一些。

第二种就不会有这种问题,但是多嵌套了一层。

大家可根据自己的需求使用。



版权声明:本文为ye987987原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。