首頁 web前端 js教程 IE與Firefox在JavaScript語法上的差異_javascript技巧

IE與Firefox在JavaScript語法上的差異_javascript技巧

May 16, 2016 pm 03:04 PM
firefox ie javascript 差異 文法

儘管JavaScript 歷史上使用冗長而令人生厭的程式碼區塊來標的特定瀏覽器的時期已經結束了,但是偶爾使用一些簡單的程式碼區塊和物件偵測來確保一些程式碼在用戶機器上正常運作依然是必要的。

這篇文章中,我會略述 Internet Explorer 和 Firefox 在 JavaScript 語法上不同的 7 個面向。

1. CSS “float” 屬性

取得給定物件的特定 CSS 屬性的基本語法是 object.style 屬性,而且有連字號的屬性要用駱駝命名法來代替。例如,取得 ID 為 “header” 的 div 的 background-color 屬性,我們要使用以下語法:

複製程式碼 程式碼如下:
document.getElementById("header").style.bpBottom= "11px solid #ccc";

但由於 “float” 是 JavaScript 的保留詞,我們就無法使用 object.style.float 來取得 “float” 屬性了。一下是我們在兩種瀏覽器中的使用的方法:

IE 文法: 

複製程式碼 程式碼如下:
document.getElementById("header").style.styleFloat = "left ";

Firefox 語法: 

複製程式碼 程式碼如下:
document.getElementById("header").style.cssFloat = ".leftleft ";

2. 元素的計算樣式

透過使用上述的 object.style.property, JavaScript 可以很容易的取得和修改物件的設定 CSS 樣式。但這語法的限制在於,它只能取得內聯在 HTML 裡的樣式,或是直接使用 JavaScript 設定的樣式。 style 物件不能取得使用外部樣式表設定的樣式。為了獲取物件的”計算樣式”,我們使用以下程式碼:

IE 文法: 

var myObject = document.getElementById("header"); 
var myStyle = myObject.currentStyle.backgroundColor;
登入後複製

Firefox 語法: 

var myObject = document.getElementById("header");
var myComputedStyle = document.defaultView.getComputedStyle(myObject, null);
var myStyle = myComputedStyle.backgroundColor;


登入後複製

3. 取得元素的”class」屬性

類似」float」屬性的情況,這兩種瀏覽器使用不同的 JavaScript 方法來取得這個屬性。

IE 文法: 

var myObject = document.getElementById("header");
var myAttribute = myObject.getAttribute("className");
登入後複製

Firefox 語法: 

var myObject = document.getElementById("header");
var myAttribute = myObject.getAttribute("class");


登入後複製

4. 取得 label 標籤的 “for” 屬性

和 3 一樣,使用 JavaScript 取得 label 的 “for” 屬性也有不同語法。

IE 文法: 

var myObject = document.getElementById("myLabel");
var myAttribute = myObject.getAttribute("htmlFor");
登入後複製

Firefox 語法: 

var myObject = document.getElementById("myLabel");
var myAttribute = myObject.getAttribute("for");
登入後複製

對於 setAtrribute 方法來說也是同樣的語法。

5. 取得遊標位置

取得元素的遊標位置比較少見,如果需要這麼做,IE 和 Firefox 的語法也是不同的。這個範例程式碼是相當基礎的,一般用作許多複雜事件處理的一部分,這裡僅用來描述差異。需要注意的是,IE 中的結果和 Firefox 中是不同的,因此這個方法有些問題。通常,這個差異可以透過取得 「滾動位置」 來補償 - 但那是另外一篇文章的課題了。

IE 文法:

var myCursorPosition = [0, 0];
myCursorPosition[0] = event.clientX;
myCursorPosition[1] = event.clientY;
登入後複製

Firefox 語法: 

var myCursorPosition = [0, 0];
myCursorPosition[0] = event.pageX;
myCursorPosition[1] = event.pageY;
登入後複製

6. 取得視窗或瀏覽器視窗的尺寸

有時需要找出瀏覽器的有效視窗空間的尺寸,一般成為」視窗」。

IE 文法: 

var myBrowserSize = [0, 0];
myBrowserSize[0] = document.documentElement.clientWidth;
myBrowserSize[1] = document.documentElement.clientHeight;


登入後複製

Firefox 語法: 

var myBrowserSize = [0, 0];
myBrowserSize[0] = window.innerWidth;
myBrowserSize[1] = window.innerHeight;


登入後複製

7. Alpha 透明

嗯,这其实不是 JavaScript 的语法项目 - alpha 透明是通过 CSS 来设置的。但是当对象通过 JavaScript 设置为淡入淡出时,这就需要通过获取 CSS 的 alpha 设定来实现,一般是在循环内部。要通过以下 JavaScript 来改变 CSS 代码:

IE 语法:

 #myElement {
filter: alpha(opacity=50);
}
登入後複製

Firefox 语法:

 #myElement {
opacity: 0.5;
}
登入後複製

要使用 JavaScript 获取这些值,需要使用 style 对象:

IE 语法:

var myObject = document.getElementById("myElement");
myObject.style.filter = "alpha(opacity=80)";


登入後複製

Firefox 语法:

var myObject = document.getElementById("myElement");
myObject.style.opacity = "0.5";


登入後複製

当然,已经说到了,一般是在循环中间来改变 opcity/alpha,来创建动画效果,但这这是个简单的例子,只是为了明白地描述方法是如何实现地。

7个方面在JavaScript语法上不同的点,希望对大家的学习有所帮助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Ubuntu Linux如何移除Firefox Snap? Ubuntu Linux如何移除Firefox Snap? Feb 21, 2024 pm 07:00 PM

要在UbuntuLinux中刪除FirefoxSnap,可以按照以下步驟進行操作:打開終端機並以管理員身份登入Ubuntu系統。執行以下命令以卸載FirefoxSnap:sudosnapremovefirefox系統將提示你輸入管理員密碼。輸入密碼並按下Enter鍵以確認。等待指令執行完成。一旦完成,FirefoxSnap將被完全刪除。請注意,這將刪除透過Snap套件管理器安裝的Firefox版本。如果你透過其他方式(如APT套件管理器)安裝了另一個版本的Firefox,則不會受到影響。透過上述步驟

深度比較:天璣8200與驍龍的差異分析 深度比較:天璣8200與驍龍的差異分析 Mar 22, 2024 pm 12:48 PM

在行動網路時代,手機的效能一直是用戶關注的焦點之一。而作為手機晶片市場領頭羊的聯發科和高通,其旗下的晶片也備受消費者矚目。近期,聯發科推出了天璣8200晶片,而高通則有其代表性的驍龍系列晶片。那麼,這兩款晶片之間究竟存在著怎樣的差異呢?本文將對天璣8200與驍龍進行深度的比較分析。首先,從製程製程來看,天璣8200採用了最新的6nm製程工藝,而高通驍龍的一些

win11無法使用ie11瀏覽器怎麼辦? (win11用不了ie瀏覽器) win11無法使用ie11瀏覽器怎麼辦? (win11用不了ie瀏覽器) Feb 10, 2024 am 10:30 AM

越來越多的用戶開始升級win11系統,由於每個用戶的使用習慣不同,還是有不少用戶在使用ie11瀏覽器,那麼win11系統用不了ie瀏覽器,該怎麼辦呢? windows11還支援ie11嗎?下面就來看看解決方法。 win11無法使用ie11瀏覽器的解決方法1、先右鍵開始選單,選擇「命令提示字元(管理員)」開啟。 2.開啟之後,直接輸入“Netshwinsockreset”,回車確定。 3.確定之後再輸入「netshadvfirewallreset&rdqu

Oracle11g和Oracle12c版本差異解讀 Oracle11g和Oracle12c版本差異解讀 Mar 07, 2024 pm 02:30 PM

Oracle資料庫一直是企業級資料庫管理系統的領導者之一,其不斷更新迭代的版本也引起了廣泛關注。其中,Oracle11g和Oracle12c兩個版本作為比較代表性的版本,有著許多的差異。本文將針對Oracle11g和Oracle12c的一些重要差異做一些解讀,並附上具體的程式碼範例,幫助讀者更深入地了解這兩個版本的差異。一、架構差異Oracle1

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

lambda 表達式的語法和結構有什麼特色? lambda 表達式的語法和結構有什麼特色? Apr 25, 2024 pm 01:12 PM

Lambda表達式是無名稱的匿名函數,其語法為:(parameter_list)->expression。它們具有匿名性、多樣性、柯里化和閉包等特徵。在實際應用中,Lambda表達式可用於簡潔地定義函數,如求和函數sum_lambda=lambdax,y:x+y,並透過map()函數應用於列表來進行求和操作。

Win10開啟IE自動跳到Edge怎麼取消_IE瀏覽器頁​​面自動跳轉的解決方法 Win10開啟IE自動跳到Edge怎麼取消_IE瀏覽器頁​​面自動跳轉的解決方法 Mar 20, 2024 pm 09:21 PM

近期不少的win10用戶們在使用電腦瀏覽器的時候發現自己的ie瀏覽器總是自動的跳到edge瀏覽器,那麼win10打開ie自動跳轉edge怎麼關閉?。下面就讓本站來為用戶們來仔細的介紹一下win10打開ie自動跳轉edge關閉方法吧。 1.我們登入edge瀏覽器,點選右上角...,找下拉的設定選項。 2.我們進入設定後,在左側欄點選預設瀏覽器。 3.最後我們在相容性中,勾選不允許IE模式下重新載入網站,重啟ie瀏覽器即可。

ie快捷方式無法刪除如何解決 ie快捷方式無法刪除如何解決 Jan 29, 2024 pm 04:48 PM

ie捷徑無法刪除的解決方法:1、權限問題;2、捷徑損壞;3、軟體衝突;4、登錄問題;5、惡意軟體;6、系統問題;7、重新安裝IE;8、使用第三方工具;9、檢查捷徑的目標路徑;10、考慮其他因素;11、諮詢專業人士。詳細介紹:1、權限問題,右鍵點擊快捷方式,選擇“屬性”,在“安全性”選項卡中,確保有足夠的權限刪除該快捷方式,如果沒有,可以嘗試以管理員身份運行等等。

See all articles