js关闭浏览器窗口的实现方式

更新日期: 2022-02-12阅读: 3k标签: 窗口

这篇文章主要介绍:js关闭当前页面(窗口)的实现方法。


需求

我需要在网页上创建一个按钮,用户点击:提示是否关闭浏览器(窗口),如果用户点击“是”,关闭该页面,如果“否”,则什么也不做。


代码实现

/**
* 关闭浏览器窗口
*/
export const closeWindow = () => {
var userAgent = navigator.userAgent
if (userAgent.indexOf('Firefox') !== -1 || userAgent.indexOf('Chrome') !== -1) {
window.location.replace('about:blank')
} else {
window.opener = null
window.open('', '_self')
}
window.close()
}

代码说明:

1、location.replace() 方法可用一个新文档取代当前文档。我们这里使用一个空白“about:blank”。

2、opener属性是一个可读可写的属性,可返回对创建该窗口的 Window 对象的引用,这里我们赋值为空null;使用window.open()打开一个窗口,赋值空字符串代表空白窗口。

3、window.close() 方法用于关闭浏览器窗口,所有主要浏览器基本都支持 close() 方法。

4、如果是“Firefox”和“Chrome”执行location.replace() 方法,其他浏览器执行window.opener = null;window.open('', '_self')。


总结

在某些实际应用中,window.close() 和self.close() 是不能关闭非弹出窗口的。

非弹出窗口,即是指(opener=null 及 非window.open()打开的窗口,比如URL直接输入的浏览器窗体, 或由其它程序调用产生的浏览器窗口)。

而且由于部分浏览器的限制,部分版本的保护加强,会导致上述代码被拦截。比如:对于火狐来说,默认js不能关闭用户打开的网页,单可以通过提醒用户改firefox的配置文件来实现:

步骤:

1、在地址栏输入about:config然后回车,警告确认
2、在过滤器中输入”dom.allow_scripts_to_close_windows“,双击即可将此值设为true

这种方法虽然可以很快解决问题,但是实际应用中不可能去要求每个用户去改自己浏览器的配置。


链接: https://www.fly63.com/article/detial/11101

H5解决浏览器,微信背景的上下滑动问题,脱离窗口的js局部滚动解决方法

当我们使用手机浏览器或微信浏览器打开Html网页的时候,如果上下滑动页面,页面就会出现黑色的空白(如图所示)。那么如何解决滑动的时候如何避免出界,出现头部和底部的黑底?

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

使用iframe(注意Iframe的高度默认150px,如果要改变iframe的高度,只能设置成具体的像素值,不能是百分比,使用window.open()直接打开外部窗口,在外部窗口中处理完成所有的操作后回到原来的页面,原来的页面出现一个确认是否完成操作的弹框。点击确认或者“cancel”之后接着调用其他的接口。

实现a元素href URL链接自动刷新或新窗口打开

希望实现这样一个功能:点击一个链接,如果这个链接浏览器已经打开过,则刷新已经打开的链接窗口;如果这个链接没有打开过,则使用新窗口打开这个链接页面。这是一个非常好的体验增强功能

24个关于设备视窗口的 CSS 单位

过去CSS 有 4 个你必须知道的识别视窗口的单位,并且它们能够很好地处理每个可以想象的用例。然而,随着时间的推移和时代的变化,这 4 种视口单位现在不足以解决所有用例。

不同窗口通信(多窗口联动)_BroadcastChannel API

目前现代浏览器(支持最新ES标准)前端通信有PostMessage和Boradcast Channel两种消息机制。这里介绍Broadcast Channel API , 它可以实现同 源 下浏览器不同窗口、Tab 页、frame 或者 iframe 下的 浏览器上下文 (通常是同一个网站下不同的页面) 之间的简单通讯。

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!