项目中打开新窗口的3种方式

31次阅读

共计 811 个字符,预计需要花费 3 分钟才能阅读完成。

1. 使用 iframe(注意 Iframe 的高度默认 150px,如果要改变 iframe 的高度,只能设置成具体的像素值,不能是百分比)
2. 使用 window.open() 直接打开外部窗口,在外部窗口中处理完成所有的操作后回到原来的页面,原来的页面出现一个确认是否完成操作的弹框。点击确认或者“cancel”之后接着调用其他的接口。
3. 使用 window.open() 在当前窗口打开另一个窗口,在新开窗口中操作完成之后,关闭该窗口,在当前窗口中监听新窗口什么时候关闭,一旦检测到窗口关闭就执行回调。使用这种方式需要考虑浏览器的跨域问题,在 ie 上如果使用 window.open() 打开跨域了的窗口,window.open() 是获取不到 window 对象的。
detectCreditCardFilledOut: (callback, url, openWin) => {
let creditCarWin = null;

let s = null;

const stopF = () => {
clearInterval(s);
creditCarWin = null;
s = null;
callback();
};

const checkCloseWindowOrNot= () => {
if (creditCarWin != null && creditCarWin.closed) {
stopF();
}
};

const openCreditCard = () => {
try {
creditCarWin = openWin(url, ‘CreditCard’);
creditCarWin.focus();
runF();
} catch (e) {
Util.NotificationUtil(‘error’, {
description: lang.openWindowError
})
}
};

const runF = () => {
s = setInterval(checkCloseWindowOrNot, 500);
};

openCreditCard();
},

正文完
 0