元素的title属性,如下所示: var text=document.getElementsByTagName("p") for (var i=0;i<TEXT.LENGTH;I++) “购物清单”文档里只有一个带有title属性的
元素。假如这份文档还有一个或更多个不带title属性的
元素,则相应的getAttribute("title")调用将返回null。null是JavaScript语言中的空值,其含义是“你说的这个东西不存在”。如果你们想亲自验证一下这件事,请先把下面这段文本插入到“购物清单”文档中的现有文本段落之后:
(插入)
--说明:node值就是下面的person节点 ,prop 是属性如:id
//根据节点获取值
function getValueByProp(node,prop) {
return (node.getElementsByTagName(prop))[0].firstChild.nodeValue;
}
/*
<person>
<id>13</id>
<name>张曼玉</name>
<salary>14000.0</salary>
<age>34</age>
</person>
*/
(插入)
This is just test
然后重新加载这个页面。这一次,你们将看到两个alter对话框,而第二个对话框将是一片空白或者是只显示着单词“null”——具体情况要取决于你的Web浏览器将如何显示null值。 可以修改我们的脚本,让它只在title属性存在时才弹出一条消息。我们将增加一条if语句来检查getAttribute()方法的返回值是不是null。趁着这个机会,我们还增加了几个变量以提高脚本的可读性: var ts=document.getElementsByTagName("li"); for (var i=0; i<TS.LENGTH;I++) gentle } { 在“购物清单”示例文档里,<p 在上例中,我们设置了一个现有节点的title属性,但这个属性原先并不存在。这意味着我们发出的setAttribute()调用实际完成了两项操作:先把这个属性创建出来,然后再对其值进行设置。如果我们把setAttribute()方法用在元素节点的某个现有属性上,这个属性的当前值将被覆盖。 goods”消息。 of list 上面这些语句将在屏幕上弹出两个alert对话框:第一个alter对话框出现在setAttribute()方法被调用之前,它将是一片空白或显示着单词“null”;第二个出现在title属性值被设置之后,它将显示着“a alert(shopping.getAttribute(?title?)); goods?); shopping.setAttribute(?title?,?a shopping='document.getElementById("purchases")' var 我们可以利用getAttribute()方法来证明这个元素的title属性值确实发生了变化: goods?) goods: 在下面的例子里,第一条语句将把id属性值是purchase的元素检索出来,第二条语句将把这个元素的title属性值设置为a obiect.setAttribute(attribute,value) 类似于getAttribute()方法,setAttribute()方法也是一个只能通过元素节点对象调用的函数,但setAttribute()方法需要我们向它传递两个参数: 我们此前介绍给大家的所有方法都只能用来检索信息。setAttribute()方法与它们有一个本质上的区别:它允许我们对属性节点的值做出修改。 3.4.2 setAttribute()方法 alert(text) if(text) {text='ts[i].getAttribute("title");' i元素已经有了一个title属性,这个属性的值是a gentle reminder。我们可以用setAttribute()方法来改变它的当前值: