[] BlogJava@王战锋, Dic.cn, 21Days@Tuota25, 英语学习, 每日一句

中国青年

[ Sharing ]实现Web页面内容动态改变的dhtml操作

  IE的DHTML对象提供了四个可读写的属性来动态操作页面元素的内容:innerText, outerText, innerHTML, outerHTML.

  需注意两点:

  1. 其中innerText,outerText属性的值是作为普通文本呈现的,即使它含有HTML标签也如实反应出来;而innerHTML, outerHTML呈现的是经HTML引擎解析后文本,它可以反应属性中HTML标签的表现效果。

  2. 对对象的outerText,outerHTML属性赋值(即写操作)会删除该对象。

  以上四个属性的赋值操作只是替换原对象的文本内容,想要在页面中指定元素相关位置新增文本内容,需采用insertAdjacentHTML和insertAdjacentText方法。形式如下:

以下是引用片段:
object.insertAdjacentText(sWhere, sText)
object.insertAdjacentHTML(sWhere, sText)

其中 sWhere 表示插入的文本相对于html标签的位置,有如下四个预设值:
以下是引用片段:
beforeBegin,afterBegin,beforeEnd,afterEnd

使用中需注意如下几点:

  1.这两种方法必须在整个文档装载完成之后才能使用,否则将出错。

  2. InsertAdjacentText只能插入普通文本,InsertAdjacentHTML插入html格式的文本

  3. 用InsertAdjacentHTML插入脚本,必须在script元素中使用defer属性,否则脚本执行将出现运行期错误

  4.InsertAdjacentHTML插入html元素后,all以及其他可能的元素集合将自动更新以反应动态变化。如页面后续元素的sourceIndex 属性将改变。

  5.当赋予InsertHTML/outerHTML属性无效的HTML标签,该方法可能出现运行时错。如以下代码将出错:

以下是引用片段:

<BODY> 
<p id=pdiv></p>
<SCRIPT LANGUAGE="JavaScript">
pdiv.innerHTML = "<p>hello</p>"
</SCRIPT>
</BODY>

此外页面内容动态操作还需要注意如下一些细节:

  1.只有文档BODY内显示的内容能被以上属性和方法动态改变,BODY对象的内容能被动态操作,但BODY对象本身无法被替换。

  2.以上属性和方式不能操作空标签(没有内容的html标签),如input,img。

  3.对于table对象而言,只有td(innerHTML/innerText)和table(outerHMTL/outerText)对象可以用某些属性来替换或插入内容;而其他table对象,如tr、tbody不能用这些属性来改变内容。




海纳百川,有容乃大;壁立千仞,无欲则刚。

posted on 2008-04-27 03:49 王战锋 阅读(183) 评论(0)  编辑  收藏 所属分类: xHTML


只有注册用户登录后才能发表评论。


网站导航:
 
<2008年4月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

导航

统计

公告

为人处世要光明磊落,与人相处要稀里糊涂。
说实话,做实事;先做后说,多做少说。

常用链接

留言簿(3)

随笔分类(11)

随笔档案(12)

文章分类(958)

文章档案(957)

新闻分类(5)

新闻档案(5)

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜