如何更改 JS 元素以查看它是节点还是空变量?
这取决于空变量的含义。
如果您的意思是尚未分配值,您可以检查
undefined
alert( someVariable !== "undefined" );
或者如果你知道它有一个值,并且需要查看它是否是一个元素,你可以这样做:
alert( someVariable && someVariable.nodeType );
或者如果您需要验证它是否是类型 1 元素,您可以这样做:
alert( someVariable && someVariable.nodeType === Node.ELEMENT_NODE );
这消除了文本节点、属性节点、注释和其他一些。
一个节点? DOM 元素?它会有一个
.nodeType
属性。
关于另一个答案的
nodeValue
,nodeValue可以为空,但节点将始终有一个nodeType
。
使用 HTML 元素并查看 Chrome 开发工具中的“属性”选项卡 我们可以看到后代:
html->HTMLHtmlElement->HTMLElement->元素->节点->EventTarget->对象
现在我们无论如何都不想检查前两个,太多不同的可能性 这样我们就只剩下 HTMLElement 或 Element。那么有什么区别呢?
HTML、HEAD、SCRIPT、META、BODY、DIV、P 和 UL 都具有相同的继承:
HTMLElement->元素->节点->事件目标->对象
现在来自典型文档的一些负面结果,其中:
<!DOCTYPE html> DocumentType->Node->EventTarget->Object
<!-- COMMENT --> Comment->CharacterData->Node->EventTarget->Object
所以节点是共同点,但问题是如何检查有效的 DOM 节点,即如何检查有效的 DOM 节点元素。因此任何具有 HTMLElement 的对象都返回 true,否则返回 false。
现在使用 Chrome 开发工具来查看 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"
测试 javascript 变量
obj
是否是有效的 DOM 节点元素非常简单:
if (obj instanceof Node)
{
//obj is DOM node element
}