innerText,outerText,innerHTML,outerHTML
这次我们要使用另一些对象属性对来实现动态改变文本,它们就是:innerText,outerText,innerHTML,outerHTML,千万要注意它们的大小写,因为错一点您就得不到预期的效果了。这是全新的方法,当您掌握它以后将可随心所欲的设计动态内容了,不可错过哦!
例12 动态改变文本和Html
<
html
>
<
head
>
<
title
>
DHtml举例12
</
title
>

<
style
>
...
<!-- 
body {...}{font-family:"宋体";color="blue";font-size="9pt"}
-->
</
style
>

<
script
language
="JavaScript"
>
...
function changeText() 
...{
DT.innerText="我很好!";
}//function 
function changeHtml() 
...{
DH.innerHTML="<i><u>我姓肖!</u></i>";
}//function 
function back() 
...{
DT.innerText="您好吗?";
DH.innerHTML="您姓什么?";
}
</
script
>
</
head
>

<
body
>
<
p
><
font
color
="gray"
>
请点击下边的文字……
</
font
>
<
ul
>
<
li
id
="DT"
onclick
="changeText()"
>
您好吗?
</
li
>
<
li
id
="DH"
onclick
="changeHtml()"
>
您姓什么?
</
li
>
<
li
onclick
="back()"
>
恢复原样!
</
li
>
</
ul
>
</
body
>
</
html
>

innerText属性用来定义对象所要输出的文本,在本例中innerText把对象DT中的文本“您好吗?”变成了“我很好!”(语句DT.innerText="我很好!")。而对对象DH的改变用了innerHTML属性,它除了有innerText的作用外,还可改变对象DH内部的HTML语句,于是它把文本变成了“我姓肖!”,而且文本输出改成了斜体(
<
i
></
i
>
)并下加一条直线(
<
u
></
u
>
),即语句DH.innerHTML="
<
i
><
u
>
我姓肖!
</
u
></
i
>
"。outerText和outerHTML也具有类似的作用,读者不妨自己试试看。 

下面我们来设计一个有趣的动态页面。 
例13 文本的动态输入与输出
<
html
>
<
head
>
<
title
>
DHtml举例13
</
title
>

<
style
>
...
<!-- 
body {...}{font-family:"宋体";color="blue";font-size:"9pt"} 
.blue {...}{color:blue;font-size:9pt}
-->
</
style
>

<
script
language
="JavaScript"
>
...
function OutputText() 
...{
if(frm.txt.text!="") 
...{ Output.innerHTML="在此处输出文本:<u>"+frm.txt.value+"</u>";} //Output为一对象。
else 
...{ Output.innerText="在此处输出文本:";}
}//function 
</
script
>
</
head
>

<
body
>
<
p
><
br
></
p
>

<
form
name
="frm"
>
<
p
><
font
color
="gray"
>
请在文本框中输入文字:
</
font
>
<
input
type
="text"
name
="txt"
size
="50"
><
br
>
<
input
type
="button"
value
="输出文本"
name
="B1"
class
="blue"
onclick
="OutputText()"
></
p
>
</
form
>

<
p
id
="Output"
>
在此处输出文本:
</
p
>
</
body
>
</
html
>

此例的动态效果如下,先在文本框中输入文本,然后按“输出文本”的按钮,接着网页便会自动输出您所输入的文本。 


此外,我们还可使用insertAdjacentHTML和insertAdjacentText方法(方法即是某特定对象能直接调用的函数)在先前文本或Html内容的前边或后边插入新的文本或Html内容,使用这些方法需要参数,这些参数有:BeforeBegin、 AfterBegin、 BeforeEnd和AfterEnd,它们是用来标明文本或Html插入的地方。具体用法如下例: 
例14 使用insertAdjacentHTML插入文本
<
html
>
<
head
>
<
title
>
DHtml举例14
</
title
>

<
style
>
...
<!-- 
body {...}{font-family:"宋体";color="blue";font-size:"9pt"}
-->
</
style
>

<
script
language
="JavaScript"
>
...
function Insert() 
...{
document.all.New.insertAdjacentHTML("AfterBegin","<font color=red>-新插入的内容-<font>");
//第一个参数是用来指明位置,第二个参数是要插入的Html内容。
}//function
</
script
>
</
head
>
<
body
>
<
p
><
br
>
</
p
>
<
p
id
="New"
onclick
="Insert()"
>
点击此行蓝色文字将插入文本
</
p
>
</
body
>
</
html
>


您可以试一下另外三个参数BeforeBegin、BeforeEnd和AfterEnd。insertAdjacentText方法地用法也是类似的。
2064

被折叠的 条评论
为什么被折叠?



