Использование элемента HTML и просмотр вкладки «Свойства» в Chrome Dev Tools
мы можем видеть потомков:
html-> HTMLHtmlElement-> HTMLElement-> элемент-> node-> EventTarget-> Object
Теперь мы не хотим проверять первые 2, несмотря ни на что, слишком много разных возможностей
так что оставьте нас с HTMLElement или Element. Так в чем же разница?
HTML, HEAD, SCRIPT, META, BODY, DIV, P и UL имеют одинаковое наследование:
HTMLElement-> элемент-> node-> EventTarget-> Object
Теперь несколько негативных результатов из типичного документа, где:
<!DOCTYPE html> DocumentType->Node->EventTarget->Object
<!-- COMMENT --> Comment->CharacterData->Node->EventTarget->Object
Итак, Node является общим знаменателем, но вопрос в том, как проверить действительный узел DOM, а именно в том, как проверить действительный элемент узла DOM. Таким образом, любой объект с HTMLElement вернет true, иначе вернет false.
Хорошо, теперь с помощью Chrome Dev Tools давайте посмотрим на элемент HTML:
$obj.nodeType; //1 No help what so ever
$obj.nodeName; //HTML Gives use the tag names
$obj.nodeValue; //null Waste of DOM space
давайте проверим прототип или __proto?
$obj.prototype.nodeType; //TypeError
$obj.prototype.nodeName; //TypeError
$obj.prototype.nodeValue; //TypeError
$obj.__proto__.nodeType; //undefined
$obj.__proto__.nodeName; //undefined
$obj.__proto__.nodeValue; //undefined
Хорошо, поэтому использование узла является мертвым для использования. Перейдем к конструктору.
$obj.constructor.name
//"HTMLHtmlElement" promising...
$obj.constructor.__proto__.prototype.toString()
//[object Object]
$obj.constructor.__proto__.constructor.name
Function
$obj.constructor.__proto__.prototype.constructor.name
HTMLElement
//BINGO
Теперь давайте завернем в полезную чистую эффективную функцию утилиты.
//readable version
isElement=function($obj){
try {
return ($obj.constructor.__proto__.prototype.constructor.name)?true:false;
}catch(e){
return false;
}
}
/**
* PRODUCTION
* Return true if object parameter is a DOM Element and false otherwise.
*
* @param {object} Object to test
* @return {boolean}
*/
isElement=function(a){try{return a.constructor.__proto__.prototype.constructor.name?!0:!1}catch(b){return!1}};
Тесты:
$html=get('html')[0]; //[<html data-role="webpage" data-theme="dark" data-require="fa" data-hello="world">…</html>]
isElement($html); //"HTMLElement"
isElement($html.dataset); //false
isElement($html.firstChild); //"HTMLElement"
isElement($html.textContent); //false
$tail=gei('tail'); //<tail id="tail">…</tail>
isElement($tail); //"HTMLElement"
isElement(get('title')[0]); //"HTMLElement"