首页 > web前端 > js教程 > 正文

Javascript入门学习第六篇 js DOM编程_基础知识

PHP中文网
发布: 2016-05-16 19:03:01
原创
1597人浏览过

上篇文章纳闷的问题,将在这章和以后的几章里,慢慢搞定。 从今天起,开始学习DOM编程  让我们慢慢称为一名初级的js程序员。 然后往js匠人方向发展。

学习英文:
dom:文档对象模型。document object model
bom:浏览器对象模型。
注:也可以叫窗口对象模型。(window object model.)
api:应用编程接口。
注:dom其实可以看作一种api。
node:节点。
注:节点分为:元素节点,属性节点,文本节点。
元素节点 包含 属性节点和文本节点。
dom树:
下面我们直接看 到底怎么操作dom。
1,    创建元素节点。createelement():
<script language="javascript">
 var a  = document.createelement("p");
 alert( "节点类型是  : " +a.nodetype   +  " , 节点名称是: "  +  a.nodename);
</script>
输出  ;     nodetype 是  1   .    a.nodename 是  p ;
所以它创建的是一个元素节点 ….你也许会想  为什么文档中没发现 节点 p呢?
我们看下面例子:
<body>
</body>
<script language="javascript">
var a  = document.createelement("p");
document.body.appendchild(a);
</script>
用firebug查看下,发现文档中已经 有我们需要的结果了。


原来createelement()方法创建出来的新元素节点不会被自动添加到文档里,既然没添加到文档里,说明它还是一个游离的状态。如果想把它添加到文档里,可以使用 appendchild()或者insertbefore()方法或者replacechild()方法(后面介绍)。 

2,创建文本节点。createtextnode():
var b = document.createtextnode("my demo");
 alert( "节点类型是  : " +b.nodetype   +  " , 节点名称是: "  +  b.nodename);
输出  ;     nodetype 是  3   .    a.nodename 是  #text ;
所以它创建的是一个文本节点 ….你也许又会想  为什么文档中没发现 这个文本节点 呢?难道也和createelement()一样,需要使用appendchild()添加到文档里。

对的,你的想法非常对。
我们看下面例子:
<body>
</body>
<script language="javascript">
var mes = document.createtextnode("hello world");
var container = document.createelement("p");
container.appendchild(mes);//先把文本节点添加到 元素节点
document.body.appendchild(container);//再把元素节点添加到 文档里
</script>

3,    复制节点。clonenode(boolean) :一个参数:
看一个例子:
<body>
</body>
<script language="javascript">
var mes = document.createtextnode("hello world");
var container = document.createelement("p");
container.appendchild(mes);
document.body.appendchild(container);
var newpara = container.clonenode(true);//true和false的区别
document.body.appendchild(newpara );

var newpara = container.clonenode(false);//true和false的区别
document.body.appendchild(newpara );
</script>
看下firebug下的结果: 


看出 true 和false的区别了吧。
true的话:是<p>hello world</p> 克隆。
false: 只克隆 <p></p> ,里面的文本不克隆。
和createelement()一样,克隆后的新节点 不会被自动插入到文档 。需要appendchild();
另外还有一个注意: 如果克隆后,id一样,不要忘记用 setattribute(“id” , “ new_id “);
来 改变新的节点的id。

4,    插入节点。appendchild():
前面都用到几次了, 应该大概的用法都知道了。
具体解释就是:
给元素追加一个子节点, 新的节点 插入到 最后。
var container = document.createelement("p");
var t =  document.createtextnode("cssrain");
container.appendchild(t);
document.body.appendchild(container);

另外 appendchild()不仅可以用来追加新的元素,也可以你 挪动 文档中现有的元素。
看下面的例子:
<p id="msg">msg</p>
<p id="content">content</p>
<p id="aaa">aaaaaaaa</p>
<script>
var mes = document.getelementbyid("msg");
var container = document.getelementbyid("content");
 container.appendchild(mes);
</script>
//发现msg放到 content 后面去了 。
js内部处理方式:
先把id为msg的从文档中删除,然后再插入到content 后,作为content的最后一个节点 插入。
结果为:
<p id="content">
content
<p id="msg">msg</p>
</p>
<p id="aaa">aaaaaaaa</p>

5,    插入节点。insertbefore():
顾名思义,就是把一个新的节点插入到目标节点的前面。
element.insertbefore( newnode  ,  targernode );
// 注意 第一个参数 是新的节点, 后面是目标节点(插入的位置)。
// 新节点是客人,肯定先服务他咯。。。 ^_^

第二个参数是可选,如果第二个参数不写,将默认添加到文档的最后,相当于appendchild();
我们看看insertbefore()怎么使用:
<p id="cssrian">
<p id="content">1111</p>
<p id="msg">msg<p>test</p></p>
<p id="content">222</p>
<p id="aaa">aaaaaaaa</p>
</p>
<script>
var msg = document.getelementbyid("msg");
var aaa = document.getelementbyid("aaa");
var test = document.getelementbyid("cssrian");
test.insertbefore( msg , aaa );
</script>
// 我们发现id为msg的 插入到了  aaa的前面。
js内部处理方式跟 appendchild()相似。也是:
先把id为msg的从文档中删除,然后再插入到 aaa 前,作为aaa的前面一个节点 插入。


大家自己动动手写写,不然光看记忆性不好。
好了,讲到这里,明天继续讲。
今天讲了 用dom方式 创建节点,复制节点,插入节点。
明天我们将讲 删除节点,替换节点,查找节点等。。。。。。
如果还有不懂,可以google 搜索资料. 

豆包AI编程
豆包AI编程

豆包推出的AI编程助手

豆包AI编程 483
查看详情 豆包AI编程
相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号