Rumah hujung hadapan web tutorial js javascript 浏览器兼容性代码一览表

javascript 浏览器兼容性代码一览表

Jun 01, 2016 am 09:54 AM
javascript keserasian

序号

操作

分类

IE
(6.0)

FireFox
(2.0)

Mozilla
(1.5)

当前
浏览器

备注

1

"."

访问tag的固有属性

OK

OK

OK

OK

 

2

"."

访问tag的用户定义属性
eg: myattr="test">

OK

NO

NO

OK

可以用getAttribute函数 替代

3

obj.getAttribute

访问tag的固有属性

OK

OK

OK

OK

 

4

obj.getAttribute

访问tag的用户定义属性
eg: myattr="test">

OK

OK

OK

OK

 

5

document.all

访问document的所有子元素
eg:document.all

OK

OK

NO

OK

建议用childNodes对象或者getElementById函数实现对应操作。
有人说它不能取Div元素,测试结果是可以,不知道是不是还有其它因素会影响测试结果。

6

obj.all

访问非document元素的所有子元素
eg: document.getElementById("mydiv").all

OK

NO

NO

OK

同上

7

getElementById()

根据元素的id/name来取得元素。
如果元素只设置name属性,没有设置id属性。

OK

NO

NO

OK

注意:很多元素是没有name属性的,eg: td, div,span...

8

变量名 = ""

隐式定义变量-通过向变量名附值方式定义一个新的变量。

OK

OK

OK

OK

建议:为避免必要的麻烦,显示定义变量。
eg:var tmp;

9

id

通过id直接调用对象
eg: test_result_1.innerHTML = ""

OK

OK

NO

OK

eval()函数用来执行脚本,所以向eval函数里面传入对象id/name的话,IE同样会返回对象的引用。
建议用document.getElementById(id)方式调用
注意:因为这个原因,IE中隐式定义的变量不能和HTML中元素的id/name相同。

10

name

通过name直接调用对象
eg: test_for_this_name.innerHTML = ""

OK

NO

NO

OK

同上/ 原因同7

11

name

支持的特殊字符("!",".","@","#","$"," eg: document.getElementsByName("aaaa!page");

NO

OK

OK

NO

其它的字符没有测试

12

tr.innerHTML = ""

设置TR元素的内部HTML脚本

NO

OK

OK

NO

在IE中,table、tr的innerHTML是只读属性,不能够对其直接设置。可以通过insertRow/insertCell函数进行设置。

13

cells对象访问

访问tr的cells对象
前提:tr元素是被删除后的tr对象,或者是用cloneNode(true)复制的删除前的tr对象

NO

OK

OK

undefined

可以将其插入Table再访问,或者可以用getElementsByTagName函数 对td/th访问。
删除后的rows对象不存在这个问题。其它元素?

14

(index)

访问集合类对象
eg: document.
getElementsByTagName("TD")(0)

OK

NO

NO

OK

建议用正式的操作符"[]".

15

obj.toString()

取得对象的字符串"[object 对象类型的名称]".
eg: td == "[object HTMLTableCellElement]"

NO

OK

OK

NO

可以省略toString()函数,直接用对象来操作。
注:在IE中返回"[object]"。

16

obj.class

定义对象的css式样/风格。
eg: td.class="XPstyle";

NO

OK

NO

-

无法写测试代码,会有编译错误!可以自己用typeof(class) == null来测试一下,没有异常就在代码中可以使用。
在HTML脚本中用class,但是在Javascript中应该用classname(class是JS的保留关键字).
注意:用 setAttribute可以把class值设置到对象中去,但是不会被当作css式样来解析。

17

const

保留关键字,用于定义常量。
eg:const HOURS = 24;

NO

OK

OK

-

暂时只能不使用const。

18

input.type

变更input元素的类型
eg: input.type="button";

NO

OK

OK

NO

IE可以初始input元素类型,但是不能变更类型。
如果必须变更,可以用更换input元素的方式。

19

obj.children

访问对象的子元素集合
eg: document.body.children.length;

OK

NO

NO

OK

可以用childNodes对象替代。

20

node.replaceNode

替换新的节点对象
eg: oldNode.replaceNode(newNode);

OK

NO

NO

OK

可以用replaceChild函数替换。

21

node.removeNode

删除已有节点对象
eg.oldNode.removeNode(true);

OK

NO

NO

OK

可以用oldNode.parentNode.removeChild(oldNode)方式实现。

22

node.insertBefore

在指定节点对象前面插入一个节点对象
document.body.insertBefore(newN, oldN);

OK

OK

OK

OK

 

23

obj.parentElement

访问对象的父元素
eg: document.body.parentElement.id;

OK

NO

NO

OK

可以用parentNode对象替代。

24

obj.childNodes.length

返回子节点的数量,和tag的数量相同。
eg:document.body.childNodes.length;

OK

NO

NO

OK

FF/Mozilla中,空白或者换行是文本节点,是childNodes的成员。
可以用node.getElementsByTagName()回避。

25

obj.
insertAdjacentElement

向指定的位置插入元素
eg: obj.insertAdjacentElement("beforeBegin",button);

OK

NO

NO

OK

insertAdjacentElement函数和insertAdjacentText函数也类似。
可以用insertBefore函数实现类似功能。

26

createElement()

创建指定类型元素。
前提:元素为HTML脚本
eg:document.createElment("");

OK

NO

NO

OK

可以先创建出对象元素,再进行属性设置;或者直接以InnerHTML的形式加到对应位置。
 

27

nodeName

取对象(tag,attribute,textnode)节点名称
eg: name = obj.nodeName;

OK

OK

OK

OK

有人说存在差异,不知道是具体的前提条件,先记录备考。
替代方案:
如果节点是tag元素可以用"tagName"取值;如果节点是attribut对象可以用"name"取值;如果节点是textnode元素可以用nodeType==3判断。

28

window.event

取得当前的事件对象
eg: window.event;

OK

NO

NO

?

可以主动向事件的响应函数传入event参数。
eg:help

29

event.target

取得事件的触发对象
eg: e.target;

NO

OK

OK

可以和srcElement共同使用;可以主动向事件的响应函数传入触发对象元素。
eg:help

30

event.srcElement

取得事件的触发对象
eg: e.srcElement;

OK

NO

NO

可以和target共同使用;可以主动向事件的响应函数传入触发对象。
eg: var obj = (e.target) ? e.target : e.srcElemtn;

31

event对象属性

当前三个浏览器的共同拥有的属性:
altKey
button
cancelBubble
clientX
clientY
ctrlKey
screenX
screenY
shiftKey
type

 

altLeft
behaviorCookie
behaviorPart
bookmarks
boundElements
contentOverflow
ctrlLeft
dataFld
dataTransfer
fromElement
keyCode
nextPage
offsetX
offsetY
propertyName
qualifier
reason
recordset
repeat
returnValue
srcElement
shiftLeft
srcFilter
srcUrn
toElement
wheelDelta
x
y
 

bubbles
cancelable
currentTarget
detail
eventPhase
explicitOriginalTarget
isChar
isTrusted
layerX
layerY
metaKey
originalTarget
pageX
pageY
rangeOffset
rangeParent
relatedTarget
target
timeStamp
view
which

bubbles
cancelable
charCode
currentTarget
detail
eventPhase
explicitOriginalTarget
isChar
keyCode
layerX
layerY
metaKey
originalTarget
pageX
pageY
popupWindowURI
rangeOffset
rangeParent
relatedTarget
requestingWindowURI
target
timeStamp
view
which

?

event对象的不同点太多,在使用的时候需要一一检查才行。具体可以用页面下方的测试区域试验。

32

注册event

用attachEvent函数注册

OK

NO

NO

-

小心内存泄漏!!!
事件处理完后一定要调用detachEvent函数销毁事件,而且要注意避免重复注册。

33

注册event

addEventListener函数注册

NO

OK

OK

-

 

34

注册event

obj.onxxx = Function("响应函数名称或代码");方式注册
eg: btn.onclick = Function(doclick);
btn.onclick = Function("return 1+1;");

OK

OK

OK

-

 

35

销毁event

detachEvent函数销毁

OK

NO

NO

-

 

36

销毁event

removeEventListener函数销毁

NO

OK

OK

-

 

37

销毁event

obj.onxxx = null;方式注册
eg: btn.onclick = null;

OK

OK

OK

-

 

38

触发event

fireEvent函数
eg:btn.fireEvent("onclick");
FF:
var e = document.createEvent("Events"); 
e.initEvent("click", true, false); 
element.dispatchEvent(event)

OK

NO

NO

-

 

39

触发event

dispatchEvent函数
eg: 
var evt = document.createEvent("MouseEvents");
evt.initMouseEvent("click", true, true);
btn.dispatchEvent(evt);

NO

OK

OK

-

 

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Analisis perbandingan dan perbezaan versi Bluetooth 5.3 dan 5.2 Analisis perbandingan dan perbezaan versi Bluetooth 5.3 dan 5.2 Dec 28, 2023 pm 06:08 PM

Pada masa kini, banyak telefon mudah alih mendakwa menyokong versi Bluetooth 5.3, jadi apakah perbezaan antara Bluetooth 5.3 dan 5.2 Sebenarnya, ia pada dasarnya adalah versi terkini Bluetooth 5, dan tidak banyak perbezaan dalam kebanyakan prestasi dan fungsi. Perbezaan antara Bluetooth 5.3 dan 5.2: 1. Kadar data 1 dan 5.3 boleh menyokong kadar data yang lebih tinggi sehingga 2Mbps. 2. Walaupun 5.2 hanya boleh mencapai maksimum 1Mbps, ini bermakna 5.3 boleh menghantar data dengan lebih cepat dan lebih stabil. 2. Peningkatan kawalan penyulitan 2. Bluetooth 5.3 menambah baik pilihan kawalan panjang kunci penyulitan, meningkatkan keselamatan dan boleh menyambung dengan lebih baik kepada kawalan akses dan peranti lain. 3. Pada masa yang sama, kerana kawalan pentadbir adalah lebih mudah, ia adalah lebih mudah dan lebih cepat untuk menyambung, yang tidak mungkin dalam 5.2.

Penyelesaian kepada i7-7700 tidak dapat menaik taraf kepada Windows 11 Penyelesaian kepada i7-7700 tidak dapat menaik taraf kepada Windows 11 Dec 26, 2023 pm 06:52 PM

Prestasi i77700 adalah mencukupi untuk menjalankan win11, tetapi pengguna mendapati bahawa i77700 mereka tidak boleh dinaik taraf kepada win11 Ini terutamanya disebabkan oleh sekatan yang dikenakan oleh Microsoft, jadi mereka boleh memasangnya selagi mereka melangkau sekatan ini. i77700 tidak boleh dinaik taraf kepada win11: 1. Kerana Microsoft mengehadkan versi CPU. 2. Hanya Intel generasi kelapan dan versi ke atas boleh terus menaik taraf kepada win11 3. Sebagai generasi ke-7, i77700 tidak dapat memenuhi keperluan naik taraf win11. 4. Walau bagaimanapun, i77700 benar-benar mampu menggunakan win11 dengan lancar dari segi prestasi. 5. Jadi anda boleh menggunakan sistem pemasangan langsung win11 laman web ini. 6. Selepas muat turun selesai, klik kanan fail dan "muat"nya. 7. Klik dua kali untuk menjalankan "Satu klik

Bolehkah saya menggunakan fon kepala Bluetooth dalam mod kapal terbang? Bolehkah saya menggunakan fon kepala Bluetooth dalam mod kapal terbang? Feb 19, 2024 pm 10:56 PM

Dengan perkembangan berterusan teknologi moden, set kepala Bluetooth tanpa wayar telah menjadi bahagian yang amat diperlukan dalam kehidupan seharian manusia. Kemunculan fon kepala tanpa wayar membebaskan tangan kita, membolehkan kita menikmati muzik, panggilan dan aktiviti hiburan lain dengan lebih bebas. Walau bagaimanapun, apabila kita terbang, kita sering diminta untuk meletakkan telefon kita dalam mod kapal terbang. Jadi persoalannya, bolehkah saya menggunakan fon kepala Bluetooth dalam mod kapal terbang? Dalam artikel ini, kami akan meneroka soalan ini. Mula-mula, mari kita fahami maksud dan maksud mod kapal terbang. Mod pesawat ialah mod khas untuk telefon bimbit

Sejauh manakah bahasa Go pada sistem Linux? Sejauh manakah bahasa Go pada sistem Linux? Mar 22, 2024 am 10:36 AM

Bahasa Go mempunyai keserasian yang sangat baik pada sistem Linux Ia boleh berjalan dengan lancar pada pelbagai pengedaran Linux dan menyokong pemproses seni bina yang berbeza. Artikel ini akan memperkenalkan keserasian bahasa Go pada sistem Linux dan menunjukkan kebolehgunaannya yang berkuasa melalui contoh kod tertentu. 1. Pasang persekitaran bahasa Go Memasang persekitaran bahasa Go pada sistem Linux Anda hanya perlu memuat turun pakej binari Go yang sepadan dan menetapkan pembolehubah persekitaran yang berkaitan. Berikut ialah langkah-langkah untuk memasang bahasa Go pada sistem Ubuntu:

Keserasian WIN10 hilang, langkah untuk memulihkannya Keserasian WIN10 hilang, langkah untuk memulihkannya Mar 27, 2024 am 11:36 AM

1. Klik kanan program dan mendapati tab [Keserasian] tidak ditemui dalam tetingkap sifat yang terbuka. 2. Pada desktop Win10, klik kanan butang Mula di sudut kiri bawah desktop dan pilih item menu [Run] dalam menu pop timbul. 3. Tetingkap Win10 run akan dibuka, masukkan gpedit.msc dalam tetingkap, dan kemudian klik butang OK. 4. Tetingkap Editor Dasar Kumpulan Tempatan akan dibuka Klik item menu [Konfigurasi Komputer/Templat Pentadbiran/Komponen Windows] dalam tetingkap. 5. Dalam menu komponen Windows yang dibuka, cari item menu [Application Compatibility], dan kemudian cari item tetapan [Remove Program Compatibility Property Page] dalam tetingkap kanan. 6. Klik kanan pada item tetapan, dan dalam menu pop timbul

Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Tutorial JavaScript Mudah: Cara Mendapatkan Kod Status HTTP Jan 05, 2024 pm 06:08 PM

Tutorial JavaScript: Bagaimana untuk mendapatkan kod status HTTP, contoh kod khusus diperlukan: Dalam pembangunan web, interaksi data dengan pelayan sering terlibat. Apabila berkomunikasi dengan pelayan, kami selalunya perlu mendapatkan kod status HTTP yang dikembalikan untuk menentukan sama ada operasi itu berjaya dan melaksanakan pemprosesan yang sepadan berdasarkan kod status yang berbeza. Artikel ini akan mengajar anda cara menggunakan JavaScript untuk mendapatkan kod status HTTP dan menyediakan beberapa contoh kod praktikal. Menggunakan XMLHttpRequest

Penjelasan terperinci tentang isu keserasian win11 dengan perisian win10 Penjelasan terperinci tentang isu keserasian win11 dengan perisian win10 Jan 05, 2024 am 11:18 AM

Perisian dalam sistem win10 telah dioptimumkan dengan sempurna, tetapi bagi pengguna win11 terkini, semua orang mesti ingin tahu sama ada sistem ini boleh disokong, jadi berikut adalah pengenalan terperinci kepada perisian yang tidak menyokong win10 dalam win11 keluar bersama. Adakah win11 menyokong perisian win10: 1. Perisian sistem Win10 dan juga aplikasi sistem Win7 sangat serasi. 2. Menurut maklum balas daripada pakar yang menggunakan sistem Win11, pada masa ini tiada isu ketidakserasian aplikasi. 3. Jadi anda boleh menaik taraf dengan berani dengan yakin, tetapi pengguna biasa dinasihatkan untuk menunggu sehingga versi rasmi Win11 dikeluarkan sebelum menaik taraf. 4. Win11 bukan sahaja mempunyai keserasian yang baik, tetapi juga mempunyai Windo

Memperkenalkan kaedah muat turun pemacu untuk win10 untuk memastikan keserasian Memperkenalkan kaedah muat turun pemacu untuk win10 untuk memastikan keserasian Jan 01, 2024 pm 06:59 PM

Pemacu peranti perkakasan adalah salah satu atur cara yang paling penting untuk kita menggunakan peranti ini secara normal, tetapi kadangkala kita mungkin menghadapi bahawa pemacu yang kita muat turun dan pasang tidak serasi Malah, sistem secara automatik boleh mencari pemacu yang serasi untuk dimuat turun dan pasang. Mari kita lihat bersama-sama. Bagaimana untuk menjadikan pemacu win10 serasi? 1. Mula-mula cari komputer ini pada desktop, klik kanan dan pilih untuk membuka "Properties" 2. Kemudian cari dan buka "Pengurus Peranti" di sebelah kiri 3. Cari peranti yang anda ingin muat turun dan pasang dalam pengurus peranti, klik kanan dan pilih "Kemas kini pemacu" 4. Kemudian pilih "Cari perisian pemacu yang dikemas kini secara automatik" 5. Akhir sekali, tunggu sebentar dan tetingkap berikut akan muncul, yang bermaksud pemasangan pemacu telah selesai .

See all articles