js contains方法實(shí)現(xiàn)代碼
一個(gè)小誤區(qū) JS中的contains
在Java語言中,contains可以用于判斷str1是否包含str2
原生JS中是有contains方法的
結(jié)構(gòu)與測(cè)試代碼如下
<div id="div1">
<div id="div2">
jb51.net
</div>
</div>
<script type="text/javascript">
var div1= document.getElementById("div1");
var div2= document.getElementById("div2");
console.log(div1.contains(div2));
var str1="jb51.net";
var str2="jb51";
console.log(str1.contains(str2));
</script>

但它并不是字符串方法,,僅用于判斷DOM元素的包含關(guān)系,參數(shù)是Element類型

若要在JS中判斷倆字符串的包含關(guān)系,用indexOf()
但是我們可以通過擴(kuò)展的方法來實(shí)現(xiàn)
<div id="div1">
<div id="div2">
jb51.net
</div>
</div>
<script type="text/javascript">
var div1= document.getElementById("div1");
var div2= document.getElementById("div2");
console.log("div1.contains(div2)="+div1.contains(div2));
//字符擴(kuò)展contains就不會(huì)報(bào)錯(cuò)了
String.prototype.contains = function(a) {
return - 1 < this.indexOf(a)
};
var str1="jb51.net";
var str2="jb51";
console.log("str1.contains(str2)="+str1.contains(str2));
//數(shù)組擴(kuò)展contains適用于數(shù)組判斷
Array.prototype.contains = function(a) {
if ("string" == typeof a || "number" == typeof a) for (var b in this) if (a == this[b]) return ! 0;
return ! 1
};
var arr1=["jb51.net","jbzj.com","jb51.com"];
var str3="jb51.net";
console.log("arr1.contains(str3)="+arr1.contains(str3));
</script>
下面是運(yùn)行結(jié)果

IE有許多好用的方法,后來都被其他瀏覽器抄襲了,比如這個(gè)contains方法。如果A元素包含B元素,則返回true,否則false。唯一不支持這個(gè)方法的是IE的死對(duì)頭firefox。
為了兼容IE和FF我們不得不用以下方法:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
不過火狐支持compareDocumentPosition() 方法,這是W3C制定的方法,標(biāo)準(zhǔn)瀏覽器都支持,不過實(shí)用性性很差,因此沒有什么人用,推廣不開來。它的使用形式與contains差不多,但返回的不是一個(gè)布爾值,而是一個(gè)很奇怪的數(shù)值,它是通過如下方式累加計(jì)算出來的:
| Bits | Number | Meaning |
|---|---|---|
| 000000 | 0 | 元素一致 |
| 000001 | 1 | 節(jié)點(diǎn)在不同的文檔(或者一個(gè)在文檔之外) |
| 000010 | 2 | 節(jié)點(diǎn) B 在節(jié)點(diǎn) A 之前 |
| 000100 | 4 | 節(jié)點(diǎn) A 在節(jié)點(diǎn) B 之前 |
| 001000 | 8 | 節(jié)點(diǎn) B 包含節(jié)點(diǎn) A |
| 010000 | 16 | 節(jié)點(diǎn) A 包含節(jié)點(diǎn) B |
| 100000 | 32 | 瀏覽器的私有使用 |
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
PPK給出如下解決方法。
if (window.Node && Node.prototype && !Node.prototype.contains){
Node.prototype.contains = function (arg) {
return !!(this.compareDocumentPosition(arg) & 16)
}
}
我搞出個(gè)更短的:
if(!!window.find){
HTMLElement.prototype.contains = function(B){
return this.compareDocumentPosition(B) - 19 > 0
}
}
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
//2011.9.24 by 司徒正美
var contains = function(root, el) {
if (root.compareDocumentPosition)
return root === el || !!(root.compareDocumentPosition(el) & 16);
if (root.contains && el.nodeType === 1){
return root.contains(el) && root !== el;
}
while ((el = el.parentNode))
if (el === root) return true;
return false;
}
- JavaScript中擴(kuò)展Array contains方法實(shí)例
- javascript contains和compareDocumentPosition 方法來確定是否HTML節(jié)點(diǎn)間的關(guān)系
- JS中判斷某個(gè)字符串是否包含另一個(gè)字符串的五種方法
- js判斷數(shù)組是否包含某個(gè)字符串變量的實(shí)例
- JS給Array添加是否包含字符串的簡(jiǎn)單方法
- jsp 判斷l(xiāng)ist是否包含string的實(shí)現(xiàn)方法
- jstl中判斷l(xiāng)ist中是否包含某個(gè)值的簡(jiǎn)單方法
- 判斷數(shù)組是否包含某個(gè)元素的js函數(shù)實(shí)現(xiàn)方法
- JavaScript判斷數(shù)組是否包含指定元素的方法
- JavaScript判斷一個(gè)字符串是否包含指定子字符串的方法
- js判斷一個(gè)字符串是否包含一個(gè)子串的方法
- JS檢測(cè)輸入字符是否包含非法字符的示例代碼
- 使用js判斷數(shù)組中是否包含某一元素(類似于php中的in_array())
- 編寫js擴(kuò)展方法判斷一個(gè)數(shù)組中是否包含某個(gè)元素
- javascript 判斷字符串是否包含某字符串及indexOf使用示例
- javascript 判斷數(shù)組是否已包含了某個(gè)元素的函數(shù)
- JS實(shí)現(xiàn)判斷數(shù)組是否包含某個(gè)元素示例
- javascript中contains是否包含功能實(shí)現(xiàn)代碼(擴(kuò)展字符、數(shù)組、dom)
相關(guān)文章
js中數(shù)組(Array)的排序(sort)注意事項(xiàng)說明
本篇文章主要是對(duì)js中數(shù)組(Array)的排序(sort)注意事項(xiàng)進(jìn)行了說明介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-01-01
swiper4實(shí)現(xiàn)移動(dòng)端導(dǎo)航欄tab滑動(dòng)切換
這篇文章主要為大家詳細(xì)介紹了swiper4實(shí)現(xiàn)移動(dòng)端導(dǎo)航欄tab滑動(dòng)切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10
iOS和Android用同一個(gè)二維碼實(shí)現(xiàn)跳轉(zhuǎn)下載鏈接的方法
這篇文章給大家分享的是iOS和Android掃描同一個(gè)二維碼,分別跳到各自的下載鏈接的實(shí)現(xiàn)方法,文中給出了實(shí)例代碼,有需要的朋友們可以參考借鑒。2016-09-09
在使用JSON格式處理數(shù)據(jù)時(shí)應(yīng)該注意的問題小結(jié)
這篇文章主要介紹了在使用JSON格式處理數(shù)據(jù)時(shí)應(yīng)該注意的問題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05
BootStrap智能表單實(shí)戰(zhàn)系列(九)表單圖片上傳的支持
這篇文章主要介紹了BootStrap智能表單實(shí)戰(zhàn)系列(九)表單圖片上傳的支持,介紹如何在生成表單后,可以支持上傳圖片后可以及時(shí)預(yù)覽圖片的功能,需要的朋友可以參考下2016-06-06
利用Query+bootstrap和js兩種方式實(shí)現(xiàn)日期選擇器
日期選擇器在我們平時(shí)開發(fā)的時(shí)候經(jīng)常要用到,下面這篇文章主要給大家介紹了利用Query+bootstrap和js這兩種方式實(shí)現(xiàn)日期選擇器的方法,文中兩種方法都給出了詳細(xì)的示例代碼,有需要的朋友可以參考借鑒,下面來一起看看吧。2017-01-01

