jQuery isメソッドをjavascriptのみを使用してどのように記述できるのでしょうか?
サードパーティのライブラリを使用することはできません。ブラウザから提供されるJavaScriptのみ。
is
参考までに、jQueryのメソッド:
現在一致している要素のセットをセレクター、要素、またはjQueryオブジェクトと照合し、これらの要素の少なくとも1つが指定された引数と一致する場合はtrueを返します。
jQuery isメソッドをjavascriptのみを使用してどのように記述できるのでしょうか?
サードパーティのライブラリを使用することはできません。ブラウザから提供されるJavaScriptのみ。
is
参考までに、jQueryのメソッド:
現在一致している要素のセットをセレクター、要素、またはjQueryオブジェクトと照合し、これらの要素の少なくとも1つが指定された引数と一致する場合はtrueを返します。
古いブラウザーのサポートが必要な場合は、jQuery を使用する必要があります。これは、IE9、Firefox、および Chrome で動作するはずです。
//returns true if element matches selector or if element is equal to the node passed as selector
function is( elem, selector ) {
var div = document.createElement("div");
var matchesSelector = div.webkitMatchesSelector || div.mozMatchesSelector || div.msMatchesSelector;
return typeof selector == "string" ? matchesSelector.call( elem, selector ) : selector === elem;
}
//returns true if any elements in the array/nodelist "is" selector
function anyIs( elems, selector ) {
var l = elems.length, i;
for( i = 0; i < l; ++i ) {
if( is( elems[i], selector ) ) {
return true;
}
}
return false;
}
is(document.createElement("div"), "div")
//true
is(document.createElement("div"), "li")
//false
anyIs(document.getElementsByTagName("div"), document.getElementsByTagName("div")[3])
//true
anyIs(document.getElementsByTagName("div"), "div")
//true
function is( elem, selector ) {
var sel = elem.ownerDocument.querySelectorAll( selector );
return [].some.call( sel, function( el ) {
return elem === el;
} );
}
true
いずれかの要素が一致した場合に返されます。