返回顶部
首页 > 资讯 > 前端开发 > node.js >JavaScript中BOM和DOM有什么区别
  • 819
分享到

JavaScript中BOM和DOM有什么区别

2024-04-02 19:04:59 819人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关javascript中BOM和DOM有什么区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。BOM定义了JavaScript可以

这篇文章将为大家详细讲解有关javascript中BOM和DOM有什么区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

BOM定义了JavaScript可以进行操作的浏览器的各个功能部件的接口,提供访问文档各个功能部件(如窗口本身、屏幕功能部件、浏览历史记录等)的途径以及操作方法。

遗憾的是,BOM只是JavaScript脚本实现的一部分,没有任何相关的标准,每种浏览器都有自己的BOM实现,这可以说是BOM的软肋所在通常情况下浏览器特定的JavaScript扩展都被看作BOM的一部分,主要包括:

◆关闭、移动浏览器及调整浏览器窗口大小;
◆弹出新的浏览器窗口;
◆提供浏览器详细信息的定位对象;
◆提供载入到浏览器窗口的文档详细信息的定位对象;
◆提供用户屏幕分辨率详细信息的屏幕对象;
◆提供对cookie的支持;
◆加入ActiveXObject类扩展BOM,通过JavaScript实例化ActiveX对象。

BOM有一些事实上的标准,如窗口对象、导航对象等,但每种浏览器都为这些对象定义或扩展了属性及方法。Document Object Model,这个就是标准了,由著名的w3c制定,目前***的级别是level 3,不过3还没有彻底完成。

目前主流的浏览器都可以支持到(仅仅是支持到哦,并不是完全遵守的)level 2,对html,也就是html4.x,目前***的是4.01,后来w3c向把html统一向xml靠拢,于是就有了xhtml1.0,再后来,w3c想搞一个xhtml2.0,结果进度缓慢,加之各大厂商又不看好,于是就有了HTML5.0

1、创建节点

createElement():   var a  = document.createElement(“p”);

它创建的是一个元素节点,所以nodeType等于1,a.nodeName将返回p。

注意;createElement()方法创建出来的新元素节点不会被自动添加到文档里,既然没添加到文档里,说明它还是一个游离的状态。所以它也没有nodeParent属性。如果想把它添加到文档里,可以使用 appendChild()或者insertBefore()方法或者replaceChild()方法。当然我们在前面的例子中,自己写了一个 insertAfter()方法,比如:

var a  = document.createElement(“p”);   document.body.appendChild(a);

注意: appendChild()默认是添加到文档的***。也就是lastChild子节点。如果想添加到某个地方,可以使用insertBefore()。如果想在元素插入之前给元素添加属性。可以这么做:

var a  = document.createElement(“p”);   a.setAttribute(“title”,”my demo”);   document.body.appendChild(a);   createTextNode():   var b = document.createTextNode(“my demo”);

它创建的是一个文本节点,所以nodeType等于3 。b.nodeName 将返回 #text ; 跟createElement()一样,用createTextNode()创建的节点也不会自动添加到文档里。需要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它经常与createElement()配合使用,知道为什么吗?(一个元素节点,一个文本节点。)

var mes = document.createTextNode(“hello world”);   var container = document.createElement(“p”);   container.appendChild(mes);   document.body.appendChild(container);

2、复制节点

cloneNode(boolean):

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 );

注意:
 
◆true的话:是<p>aaaa</p>克隆。
◆false: 只克隆 <p></p>,里面的文本不克隆。
◆可以自己写个例子,然后用firebug看看。

克隆后的新节点,和createTextNode()一样  不会被自动插入到文档 。需要appendChild();另外还有一个注意: 如果克隆后,id一样,不要忘记用 setAttribute(“id” , “ another_id “);改变新的节点的ID。

3、插入节点

appendChild() :

var container = document.createElement("p");   var t =  document.createTextNode("CSSrain");   container.appendChild(t);   document.body.appendChild(container);

它经常跟createElement()和createTextNode(),cloneNode()配合使用。另外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 后面去了。  <p id="content">   content   <p id="msg">msg</p>   </p>   <p id="aaa">aaaaaaaa</p>

第二个参数是可选,如果第二个参数不写,将默认添加到文档的***,相当于appendChild();我们看看insertBefore()怎么使用:

<div id="cssrian">   <p id="content">1111</p>   <div id="msg">msg<div>test</div></div>   <p id="content">222</p>   <p id="aaa">aaaaaaaa</p>   </div>   <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()相似。

4、删除节点

removeChild():

<body>   <div id="cssrain">   <div id="a">a </div>   <div id="b">b </div>   <div id="c">c </div>   </div>   </body>   <script>   var msg = document.getElementById("cssrain");   var b = document.getElementById("b");   msg.removeChild(b);   </script>

如果不知道要删除的节点的父节点是什么?可以使用parentNode属性。比如:

<body>   <div id="cssrain">   <div id="a">a </div>   <div id="b">b </div>   <div id="c">c </div>   </div>   </body>   <script>   var b = document.getElementById("b");   var c = b.parentNode;   c.removeChild(b);   </script>

注意:你如果想把某个节点从一处移动到另一个地方,不必使用removeChild()。可以使用前面的 appendChild()和insertBefore(),他们都会自动先删除节点,然后移动到你指定的地方。、

5、替换节点

Element.repalceChild( newNode , oldNode ):   <body>   <div id="cssrain">   <div id="a">a </div>   <div id="b">b </div>   <div id="c">c </div>   </div>   </body>   <script>   var cssrain = document.getElementById("cssrain");   var msg =  document.getElementById("b");   var para =  document.createElement("p");   cssrain.replaceChild( para , msg  );   </script>

6、设置/获取属性节点

setAttribute();//设置    var a  = document.createElement(“p”);   a.setAttribute(“title”,”my demo”);    var a =document.getElementById(“cssrain”);   var b = a.getAttribute(“title”);

获取的时候,如果属性不存在,则返回空,注意ie和ff返回不同,可以看我以前的例子。 返回虽然不同,但是可以用一个方法来判断:if(a.getAttribute(“title”) ){   }

7、查找节点

getElementById();

返回一个对象,对象拥有 nodeName , nodeType , parentNode , ChildNodes 等属性。getElementsByTagName():查找标签名的所有元素。返回一个集合,可以用循环取出每个对象,对象拥有 nodeName , nodeType , parentNode , ChildNodes 等属性。 例子:

var ps = document.getElementsByTagName(“p”);   for(var i=0 ; i< ps.length ; i++){    ps[i].setAttribute(“title”,”hello”);   //也可以使用:  ps.item(i).setAttribute("title","hello");   }      <body>   <div id="cssrain">   <div id="a">a </div>   <div id="b">b </div>   <div id="c">c </div>   </div>   </body>   <script>   var ps = document.getElementById("cssrain")   if(ps.hasChildNodes){           alert( ps.childNodes.length  );     }   </script>

8、DOM属性

我们常用的3中类型:
 
nodeType == 1  : 元素节点
nodeType == 2  : 属性节点
nodeType == 3  : 文本节点

如果想记住的话,上面的顺序我们可以看做是从前到后。比如:<p  title="cssrain" >test</p> 从前往后读:你会发现先是元素节点,然后是属性节点,***是文本节点,这样你就很容易记住了nodeType分别代表什么类型了。nodeType属性经常跟if配合使用,以确保不会在错误的节点类型上执行错误的操作。比如:

function cs_demo(mynode){         if(mynode.nodeType == 1){                 mynode.setAttribute("title","demo");           }   }

代码解释:先检查mynode的nodeType属性,以确保它所代表的节点确实是一个元素节点。和nodeName属性一样,他也是只读属性,不能进行设置.

<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>

nodeValue一般只用来设置 文本节点的值。如果要刷新属性节点的值,一般使用setAttribute(). childNodes属性:返回一个数组,数组由元素节点的子节点构成。由于文本节点和属性节点都不可能再包含任何子节点,所以他们的childNodes属性永远返回一个空数组。

可以使用hasChildNodes方法,它用来判断某个元素有没有子节点。或者if (container.childNodes.length < 1) ;childNodes也是一个只读属性。如果要增加节点,可以使用appendChild()或者insertBefore() ,删除节点可以使用removeChild(); 操作后,childNodes属性会自动刷新。

firstChild属性

由于文本节点和属性节点都不可能再包含任何子节点,所以他们的firstChild属性永远返回一个空数组。 如果没有子节点,将返回null;node.firstChild 等价于  node.childNodes[0] ; firstChild属性是一个只读属性。

lastChild属性

由于文本节点和属性节点都不可能再包含任何子节点,所以他们的lastChild属性永远返回一个空数组。 如果没有子节点,将返回null; node.lastChild  等价于  node.childNodes[ node.childNodes.length - 1 ] ;lastChild属性是一个只读属性。

nextSibling属性

返回目标节点的下一个兄弟节点。如果目标节点后面没有同属于一个父节点的节点,nextSibling 将返回null ;nextSibling 属性是一个只读属性。

previousSibling属性

返回目标节点的前一个兄弟节点。如果目标节点前面没有同属于一个父节点的节点,previousSibling 将返回null ;previousSibling 属性是一个只读属性。

parentNode属性

注:parentNode属性返回的节点永远是一个元素节点,因为只有元素节点才有可能有子节点。

当然有个例外

document节点,他没有父节点。所以document节点的parentNode属性将返回null;parentNode 属性是一个只读属性。

关于JavaScript中BOM和DOM有什么区别就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: JavaScript中BOM和DOM有什么区别

本文链接: https://lsjlt.com/news/69760.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript中BOM和DOM有什么区别
    这篇文章将为大家详细讲解有关JavaScript中BOM和DOM有什么区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。BOM定义了JavaScript可以...
    99+
    2024-04-02
  • js中dom和bom有哪些区别
    这篇文章给大家分享的是有关js中dom和bom有哪些区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JavaScript的特点1.JavaScript主要用来向HTML页面添加交互行为。2.JavaScript...
    99+
    2023-06-14
  • JavaScript的DOM与BOM的区别是什么
    这篇“JavaScript的DOM与BOM的区别是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript的D...
    99+
    2023-06-29
  • JavaScript中DOM与BOM的区别与用法是什么
    本文小编为大家详细介绍“JavaScript中DOM与BOM的区别与用法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript中DOM与BOM的区别与用法是什么”文章能帮助大家解决疑惑,...
    99+
    2024-04-02
  • JavaScript中BOM和DOM详解
    目录BOM(浏览器对象模型) 1. window 获取浏览器c窗口尺寸 2. screen 获取电脑屏幕大小 3. window 开启关闭窗口 4. 浏览器事件 5. locatio...
    99+
    2024-04-02
  • 怎么理解JavaScript中的BOM和DOM
    本篇内容主要讲解“怎么理解JavaScript中的BOM和DOM”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JavaScript中的BOM和DOM”吧...
    99+
    2024-04-02
  • JavaScript的DOM与BOM的区别与用法详解
    目录1. 简述:何为DOM,何为BOM?2. DOM及其相关操作2.1DOM树2.2DOM的一些常见的操作元素方法获取节点的DOM方法 获取/设置元素的属性值的DOM方法创...
    99+
    2024-04-02
  • JavaScript中DOM和BOM原理详析
    目录前言DOM为什么要创建DOM节点或者画一个类似于这样的结构图?DOM的家世1.DOM为啥这么有必要?2.DOM的迭代,有啥区别?3.注意注意!!DOM的好兄弟BOM!小结前言 本...
    99+
    2024-04-02
  • JavaScript中BOM,DOM和事件怎么使用
    这篇文章主要介绍“JavaScript中BOM,DOM和事件怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript中BOM,DOM和事件怎么使用”文章能帮助大家解决问题。BOM概...
    99+
    2023-07-02
  • 使用JavaScript和jquery获取dom对象有什么区别
    使用JavaScript和jquery获取dom对象有什么区别?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。JavaScript是什么JavaScript是一种...
    99+
    2023-06-14
  • Dom 节点和 元素 有什么区别
    这篇文章主要讲解了“Dom 节点和 元素 有什么区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Dom 节点和 元素 有什么区别”吧!DOM 还使用术语元...
    99+
    2024-04-02
  • javascript与DOM有哪些区别
    这篇文章主要介绍javascript与DOM有哪些区别,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! JavaScript与DOM的区别:1、DOM是文档...
    99+
    2024-04-02
  • JavaScript中Object和Map有什么区别
    这篇文章主要讲解了“JavaScript中Object和Map有什么区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中Object和M...
    99+
    2024-04-02
  • JavaScript中Write和Writeln有什么区别
    这篇文章给大家介绍JavaScript中Write和Writeln有什么区别,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Write和Writeln的区别Write不可以换行,Writ...
    99+
    2024-04-02
  • JavaScript中match和exec有什么区别
    JavaScript中match和exec有什么区别?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。java基本数据类型有哪些Java的基本数据类型分为:1、整数类型,用来表示整...
    99+
    2023-06-14
  • JavaScript中splice和slice有什么区别
    JavaScript中splice和slice有什么区别?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、W...
    99+
    2023-06-14
  • JavaScript中join() 和split()有什么区别
    这篇文章给大家介绍JavaScript中join() 和split()有什么区别,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。javascript是一种什么语言javascript是一种动态类型、弱类型的语言,基于对象...
    99+
    2023-06-14
  • JavaScript中setTimeout和setInterval有什么区别
    setTimeout和setInterval都是JavaScript中的定时器函数,用于在一定时间后执行一段代码。setTimeou...
    99+
    2023-09-22
    JavaScript
  • javascript中history.go()和History.back()有什么区别
    history.go()方法用于在浏览器历史记录中向前或向后跳转指定的步数。参数为正数时向前跳转,为负数时向后跳转。 而Histor...
    99+
    2024-03-01
    JavaScript
  • DOM模型和LINQ模型有什么区别
    这篇文章主要介绍“DOM模型和LINQ模型有什么区别”,在日常操作中,相信很多人在DOM模型和LINQ模型有什么区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”DOM模型和LINQ模型有什么区别”的疑惑有所...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作