javascript新手问题~那怎么老是显示出#text啊!
<scriptlanguage="javascript">functionmyDOMInspector(){varoUl=document.getElementById(...
<script language="javascript">
function myDOMInspector(){
var oUl= document.getElementById("myList"); //获取<ul>标记
var DOMString="";
if(oUl.hasChildNodes())//判断是否有字节点
{
var oCh=oUl.childNodes; //获得子标记
for(var i=0;i<oCh.length;i++)
DOMString+=oCh[i].nodeName+"\n";
}
alert(DOMString);
}
</script>
</head>
<body onload="myDOMInspector()">
<ul id="myList">
<li>撒的</li>
<li>JavaScript</li>
<li>CSS</li>
<li>ASP.NET</li>
<li>JSP</li>
<li>PHP</li>
</ul>
</body>
</html> 展开
function myDOMInspector(){
var oUl= document.getElementById("myList"); //获取<ul>标记
var DOMString="";
if(oUl.hasChildNodes())//判断是否有字节点
{
var oCh=oUl.childNodes; //获得子标记
for(var i=0;i<oCh.length;i++)
DOMString+=oCh[i].nodeName+"\n";
}
alert(DOMString);
}
</script>
</head>
<body onload="myDOMInspector()">
<ul id="myList">
<li>撒的</li>
<li>JavaScript</li>
<li>CSS</li>
<li>ASP.NET</li>
<li>JSP</li>
<li>PHP</li>
</ul>
</body>
</html> 展开
4个回答
展开全部
这是获取不到文本的,你对这个理解错了
你可以看下这些资料
1,nodeName属性 : 节点的名字。
如果节点是元素节点,那么返回这个元素的名字。此时,相当于tagName属性。
比如:
<p>aaaa</p> : 则返回 p ;
如果是属性节点,nodeName将返回这个属性的名字。
如果是文本节点,nodeName将返回一个#text的字符串。另外我要说的是: nodeName属性是一个只读属性,不能进行设置.(写)
它返回 大写字母的值。2,,nodeType属性 : 返回一个整数,代表这个节点的类型。
我们常用的3中类型:
nodeType == 1 : 元素节点
nodeType == 2 : 属性节点
nodeType == 3 : 文本节点
如果想记住的话,我们可以这么去记:
比如: <p title="cssrain" >test</p> 从前往后读: 你会发现 先是元素节点(1),然后是属性节点(2),最后是文本节点(3),这样你就很容易记住了 nodeType分别代表什么类型了。(我总结的一点小技巧, ^_^。)nodeType属性经常跟 if 配合使用,以确保不会在错误的节点类型上 执行错误的操作。
比如:
function cs_demo(mynode){
if(mynode.nodeType == 1){
mynode.setAttribute("title","demo");
}
}
代码解释: 先检查mynode的nodeType属性,以确保它所代表的节点确实是 一个元素节点。
和nodeName属性一样,他也是只读属性,不能进行设置.(写)。3,nodeValue属性 : 返回一个字符串,这个节点的值。
如果节点是元素节点,那么返回null;(注意下)
如果是属性节点,nodeValue将返回这个属性的值。
如果是文本节点,nodeValue将返回这个文本节点的内容。
比如:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
alert( c.nodeValue );//返回null
</SCRIPT>
nodeValue是一个可以读、写的属性。 但它不能设置元素节点的值。
再看看下面的例子:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
c.nodeValue =" dddddddddddd"; //不能设置
//alert( c.firstChild.nodeValue ) //元素节点 包括属性节点和文本节点。
c.firstChild.nodeValue = "test"//能设置
</SCRIPT>
当然我们为了确保能正确运行:可以加一段代码:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
c.nodeValue =" dddddddddddd"; //不能设置
//alert( c.firstChild.nodeValue )
if( c.firstChild.nodeType==3 ){ //判断是不是 文本节点
c.firstChild.nodeValue = "test"//能设置
}
</SCRIPT>
//可以看出,如果要设置元素节点,不能直接设置,而必须先使用firstChild或者lastChild等 然后设置nodeValue.
nodeValue一般只用来设置 文本节点的值。如果要刷新属性节点的值,一般使用setAttribute().
你可以看下这些资料
1,nodeName属性 : 节点的名字。
如果节点是元素节点,那么返回这个元素的名字。此时,相当于tagName属性。
比如:
<p>aaaa</p> : 则返回 p ;
如果是属性节点,nodeName将返回这个属性的名字。
如果是文本节点,nodeName将返回一个#text的字符串。另外我要说的是: nodeName属性是一个只读属性,不能进行设置.(写)
它返回 大写字母的值。2,,nodeType属性 : 返回一个整数,代表这个节点的类型。
我们常用的3中类型:
nodeType == 1 : 元素节点
nodeType == 2 : 属性节点
nodeType == 3 : 文本节点
如果想记住的话,我们可以这么去记:
比如: <p title="cssrain" >test</p> 从前往后读: 你会发现 先是元素节点(1),然后是属性节点(2),最后是文本节点(3),这样你就很容易记住了 nodeType分别代表什么类型了。(我总结的一点小技巧, ^_^。)nodeType属性经常跟 if 配合使用,以确保不会在错误的节点类型上 执行错误的操作。
比如:
function cs_demo(mynode){
if(mynode.nodeType == 1){
mynode.setAttribute("title","demo");
}
}
代码解释: 先检查mynode的nodeType属性,以确保它所代表的节点确实是 一个元素节点。
和nodeName属性一样,他也是只读属性,不能进行设置.(写)。3,nodeValue属性 : 返回一个字符串,这个节点的值。
如果节点是元素节点,那么返回null;(注意下)
如果是属性节点,nodeValue将返回这个属性的值。
如果是文本节点,nodeValue将返回这个文本节点的内容。
比如:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
alert( c.nodeValue );//返回null
</SCRIPT>
nodeValue是一个可以读、写的属性。 但它不能设置元素节点的值。
再看看下面的例子:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
c.nodeValue =" dddddddddddd"; //不能设置
//alert( c.firstChild.nodeValue ) //元素节点 包括属性节点和文本节点。
c.firstChild.nodeValue = "test"//能设置
</SCRIPT>
当然我们为了确保能正确运行:可以加一段代码:
<div id="c">aaaaaaaaaaaaaaaa</div>
<SCRIPT LANGUAGE="JavaScript">
var c= document.getElementById("c");
c.nodeValue =" dddddddddddd"; //不能设置
//alert( c.firstChild.nodeValue )
if( c.firstChild.nodeType==3 ){ //判断是不是 文本节点
c.firstChild.nodeValue = "test"//能设置
}
</SCRIPT>
//可以看出,如果要设置元素节点,不能直接设置,而必须先使用firstChild或者lastChild等 然后设置nodeValue.
nodeValue一般只用来设置 文本节点的值。如果要刷新属性节点的值,一般使用setAttribute().
展开全部
你写的js不是获取html标准方法,是解析xml方法。childNodes包含LI和内部的文本,#TEXT其实就是里面有文本。建议你看下javascript相关操作的书。或者直接使用jquery
正确的方法如下:
<html>
<head>
<script language="javascript">
function myDOMInspector(){
var oUl= document.getElementById("myList"); //获取<ul>标记
var DOMString="";
if(oUl.hasChildNodes())//判断是否有字节点
{
var oCh=oUl.getElementsByTagName("li"); //获得子标记
for(var i=0;i<oCh.length;i++)
DOMString += oCh[i].tagName+":"+oCh[i].innerText+"\n";
}
alert(DOMString);
}
</script>
</head>
<body onload="myDOMInspector()">
<ul id="myList">
<li>撒的</li>
<li>JavaScript</li>
<li>CSS</li>
<li>ASP.NET</li>
<li>JSP</li>
<li>PHP</li>
</ul>
</body>
</html>
正确的方法如下:
<html>
<head>
<script language="javascript">
function myDOMInspector(){
var oUl= document.getElementById("myList"); //获取<ul>标记
var DOMString="";
if(oUl.hasChildNodes())//判断是否有字节点
{
var oCh=oUl.getElementsByTagName("li"); //获得子标记
for(var i=0;i<oCh.length;i++)
DOMString += oCh[i].tagName+":"+oCh[i].innerText+"\n";
}
alert(DOMString);
}
</script>
</head>
<body onload="myDOMInspector()">
<ul id="myList">
<li>撒的</li>
<li>JavaScript</li>
<li>CSS</li>
<li>ASP.NET</li>
<li>JSP</li>
<li>PHP</li>
</ul>
</body>
</html>
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
首先要说明的是,在DOM中,文本也是一个节点,类型为DOM Text
这里你使用childNodes属性获取所有节点,就包含进去了每个li节点前面的文本节点"回车 ",即一个回车后面跟很多空格
所以要获取li节点应该使用
oUl.getElementsByTagName("li")
希望对您有帮助~
By Billskate
这里你使用childNodes属性获取所有节点,就包含进去了每个li节点前面的文本节点"回车 ",即一个回车后面跟很多空格
所以要获取li节点应该使用
oUl.getElementsByTagName("li")
希望对您有帮助~
By Billskate
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
alert(DOMString); //此语句弹出提示
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询