導航:首頁 > 編程語言 > js判斷瀏覽器支持事件

js判斷瀏覽器支持事件

發布時間:2025-08-22 06:31:20

js判斷是否是IE瀏覽器的幾種方法

前幾天在網上看到一個技術牛人寫的世界上判斷是否IE瀏覽器之最短的js代碼,如下:<scriptif(!+[1,])alert(這是ie瀏覽器);
else alert(這不是ie瀏覽器);
</script
其實有很多判斷的方法,大都是根據瀏覽器的特性來的。
比如庫prototype的方法是:!!(window.attachEvent && navigator.userAgent.indexOf('Opera') === -1) 。就是根據ie支持window.attachEvent添加偵聽事件,非ie用window.addEventListener添加偵聽事件來判斷的。navigator.userAgent.indexOf('Opera') === -1是因為opara瀏覽器能偽裝成ie.如果!!(window.attachEvent )為真,就是ie;反之,如果!window.addEventListener為真,也可以判斷為ie.
Ext使用的是!1[0],他利用IE無法使用數組下標訪問字元串的特性來判斷。在ie8下好像有問題。
在!+[1,]還未被發現前,判斷ie最短的表達式是 !+\v1.它利用的是ie不支持垂直製表符的特性。
以前還有一個常用方法是document.all,由於opera瀏覽器能偽裝成ie。可以這樣寫:!!(document.all && navigator.userAgent.indexOf('Opera') === -1).
還有很多,先記這幾條,便於工作時查閱。
1.+[1,]
2.!+\v1
3.!!(window.attachEvent && navigator.userAgent.indexOf('Opera') === -1)
4.!!(!window.addEventListener&& navigator.userAgent.indexOf('Opera') === -1)
5.!!(document.all && navigator.userAgent.indexOf('Opera') === -1)

⑵ JS捕獲關閉瀏覽器事件之chrome瀏覽器真支持onbeforeunload事件嗎

這個谷歌瀏覽器是支持的,不過你要注意不要試圖用addEventListener或attachEvent綁定這兩個事件,瀏覽器不兼容。

代碼如下:

window.onbeforeunload = function()

{

return false;

}

不過這個瀏覽器不怎麼兼容國內的網站,建議換個同樣可以支持這個事件的瀏覽器。

⑶ js區分瀏覽器頁面是刷新還是關閉

頁面載入時只執行onload
頁面關閉時只執行onunload
頁面刷新時先執行onbeforeunload,然後onunload,最後onload。

經過驗證我得出的結論是:

//對於ie,谷歌,360:

//頁面載入時只執行onload
//頁面刷新時,刷新之前執行onbeforeunload事件,在新頁面即將替換舊頁面時onunload事件,最後onload事件。
//頁面關閉時,先onbeforeunload事件,再onunload事件。

//對於火狐:

//頁面刷新時,只執行onunload;頁面關閉時,只執行onbeforeunload事件
那麼回歸正題,到底怎樣判斷瀏覽器是關閉還是刷新?我按照網上的各種說法實驗千百遍,都未成功,其中各種說法如下:

window.onbeforeunload=function()//author:meizz
{
varn=window.event.screenX-window.screenLeft;
varb=n>document.documentElement.scrollWidth-20;
if(b&&window.event.clientY<0||window.event.altKey)
{
alert("是關閉而非刷新");
window.event.returnValue="";//這里可以放置你想做的操作代碼
}else
{
alert("是刷新而非關閉");
}
}
window.onbeforeunload=function()//author:meizz
{
varn=window.event.screenX-window.screenLeft;
varb=n>document.documentElement.scrollWidth-20;
if(b&&window.event.clientY<0||window.event.altKey)
{
alert("是關閉而非刷新");
window.event.returnValue="";//這里可以放置你想做的操作代碼
}else
{
alert("是刷新而非關閉");
}
}

⑷ js怎麼寫提示用戶升級瀏覽器的代碼

判斷當前瀏覽器的版本,如果是IE較低版本,就跳轉到一個提示瀏覽器升級的頁面專。

直接用js體驗不好,屬也不好看。


具體的代碼

if((!to3d())||document.documentMode==10||document.documentMode==11)
{
window.location="../error.html";
}


這段代碼檢測了瀏覽器是不是支持3d這個屬性,然後檢測了是不是IE10和IE11。然後跳轉到另外一個網頁。你也可以直接簡單粗暴的document.documentMode <11,就可以屏蔽版本低於IE11的瀏覽器了。


不用擔心其他的如FireFox或者Chrome,因為這段代碼在這兩個瀏覽器下是沒有這個屬性的。

閱讀全文

與js判斷瀏覽器支持事件相關的資料

熱點內容
y400開機密碼 瀏覽:331
vss資料庫 瀏覽:854
js日期加零 瀏覽:34
互盾數據恢復怎麼收費 瀏覽:854
ps2020載入筆刷看不到文件 瀏覽:627
迅捷pdf轉換器里有個文件卸載不了 瀏覽:478
數控編程x2000什麼意思 瀏覽:731
關於計算機網路基礎的 瀏覽:641
1kb文件夾快捷方式病毒專殺工具 瀏覽:755
指紋機管理者密碼 瀏覽:624
ip網路攝像頭監控軟體安卓 瀏覽:899
如何添加一個aspx文件 瀏覽:767
redhat修改密碼 瀏覽:705
編程貓從哪裡開始學 瀏覽:980
北京市文件夾加密軟體哪個好 瀏覽:270
大學註解哪個版本好 瀏覽:476
js判斷瀏覽器支持事件 瀏覽:563
網路電纜掉了不知道在哪怎麼辦 瀏覽:691
碧藍航線文件夾 瀏覽:397
java數組轉換成枚舉 瀏覽:419

友情鏈接