像很多新手一样,我知道js有三部分组成,即ECMAScript、DOM、BOM三部分组成,ECMAScript是核心解释器、DOM(Document Object Model)是文档对象模型、BOM(Browser Object Model)是浏览器对象模型,但是我并没有完全理解其中的含义,还是会经不住去问:它们到底是什么?所以今天我和好朋友坐下来好好探讨了一下,来弥补这个小小的漏洞,如果有哪些不对的地方,还望看到的朋友指正;

  ECMAScript也是一种语言,它本身不包含输入输出定义;ECMA-262规定了语法、类型、语句、关键词、保留字、操作符、对象,ECMAScript就是对实现该规定的各个方面内容的语言的描述。javascript实现了ECMAScript。

  DOM是文档对象模型,它主要包含了获取元素、修改样式、操作元素三个方面的内容,我们的绝大部分操作都是DOM操作,DOM操作大部分是可以兼容的,因为多个浏览器具有兼容写法。我们这里还可以介绍一下DOM的一些具体的内容。

  (一)、DOM树:文档的结构

  (二)、DOM结构

    1、获取父节点  obj.parentNode

         最大的祖宗是document,在往上就是null

    2、获取子节点  childNodes  获取子节点,包括文本节点

      节点类型:文本节点、标签节点

      检测节点的类型可以用nodeType:文本节点是3;标签节点是1;documnent是9

      获取子节点的另一个方法是  children ,但是它和childNodes是有区别的:

                                  (1)它只包括一级子节点,即只包括它的儿女,不包括它的孙子,孙女

                                  (2)它不会获取到文本节点

    3、获取上一个兄弟节点
      obj.previousElementSibling 兼容:高版本浏览器
      obj.previousSibling 兼容:ie6,7,8
      兼容写法
        obj.previousElementSibling||obj.previousSibling;

      获取下一个兄弟节点
      obj.nextElementSibling 兼容:高版本浏览器
      obj.nextSibling 兼容:ie6,7,8
      兼容写法
        obj.nextElementSibling||obj.nextSibling;

    4、获取首尾子节点

      首子节点
        父级.firstElementChild 兼容高版本浏览器
        父级.firstChild 兼容ie6,7,8
        兼容写法
          父级.firstElementChild||父级.firstChild
      尾子节点
        父级.lastElementChild 兼容高版本浏览器
        父级.lastChild 兼容ie6,7,8
        兼容写法
          父级.lastElementChild||父级.lastChild
      PS:这样写看起来太麻烦,所以我们完全可以用children方法搞定
      首子节点  obj.children[0];
      尾子节点  obj.children[obj.children.length-1];

  获取节点的详细内容就讲到这里,之后还有获取物体信息和创建元素
    5、物体信息

      obj.offsetWidth 获取盒子模型的宽度
      obj.offsetHeight 获取盒子模型的高度
      obj.offsetLeft 获取元素距离定位父级左边距。
      obj.offsetTop 获取元素距离定位父级上边距
      没有offsetRight/offsetBottom
      obj.offsetParent 获取定位父级

      这里需要顺带提一下parentNode和offsetParent都是获取父级,但是它们有什么区别呢?parentNode是获取结构上的父级,而offsetParent是获取定位上的父级。

    6、创建元素

      document.createElement('标签名')
      添加元素:
        父级的最后面添加了一个元素:父级.appendChild(新创建的对象);
        把一个元素插入到另一个元素之前:父级.insertBefore(要插入的元素,插入到谁之前);
        删除元素:父级.removeChild(要删除的对象);

    7、克隆元素

      obj.cloneNode();只会克隆这个标签
      obj.cloneNode(true) 深度克隆元素,包括属性内容一起克隆
      *注意:id也会被一起克隆。所以如果有id,每次克隆之后,需要去除id,obj.id='';

  BOM是浏览器对象模型,包括浏览器的一些操作,如window.open、window.alert、window.close等,BOM介于各个浏览器厂商对浏览器的不同规定,所以兼容性很差。

    其中比较重要的一些内容,我们是需要知道的;

     1、获取浏览器的详细信息:window.navigator.userAgent

     2、onscroll 当页面滚动时触发。

      滚动距离(页面滚了多少它就是多少)
       document.documentElement.scrollTop;不兼容chrome

       document.body.scrollTop;兼容chrome的。

       兼容写法:
        document.documentElement.scrollTop||document.body.scrollTop;

     3、获取可视区高度
      document.documentElement.clientHeight;

      获取可视区高度
      document.documentElement.clientWidth

     4、改变窗口大小事件   onresize

  好了,相信大家现在和我一样,对这方面的基础知识应该不会有太多疑问了,我们一起加油吧!

 

我所理解的ECMAScript、DOM、BOM---写给新手们的更多相关文章

  1. DOM&BOM笔记

    day01正课:1. DOM概述2. ***DOM树3. *查找 1. DOM概述: DHTML:动态网页技术的统称 DHTML=HTML+CSS+JS 鄙视题: HTML XHTML DHTML X ...

  2. JavaScript·DOM,BOM

    YI.DOM 1.创建DOM 2.删除DOM 3.文档碎片 文档碎片可以提高DOM操作性能(理论上) 文档碎片(类似于一个口袋,先将多个元素放在口袋里,放完之后,再将口袋放到最终要插入的元素中): d ...

  3. 什么是BOM?,什么是DOM? BOM跟DOM之间的关系

    什么是BOM? BOM是browser object model的缩写,简称浏览器对象模型.是用来获取或设置浏览器的属性.行为,例如:新建窗口.获取屏幕分辨率.浏览器版本号等. 比如 alert(); ...

  4. js初级DOM&BOM知识点总结

    第一章 js的组成DOM BOM ECMAScript javaScript 是一种直译是脚本语言 js语言特点 .脚本编写语言 .基于对象的语言 .简单性 .动态性 .安全性 .跨平台性 C/S是C ...

  5. 深入理解JPEG图像格式Jphide隐写

    0x00 隐写原理 Jphide是基于最低有效位LSB的JPEG格式图像隐写算法,使用JPEG图像作为载体是因为相比其他图像格式更不容易发现隐藏信息,因为JPEG图像在DCT变换域上进行隐藏比空间域隐 ...

  6. 写给新手的WebAPI实践

    此篇是写给新手的Demo,用于参考和借鉴,用于发散思路.老鸟可以忽略了. 自己经常有这种情况,遇到一个新东西或难题,在了解和解决之前总是说“等搞定了一定要写篇文章记录下来”,但是当掌握了之后,就感觉好 ...

  7. JavaScript学习总结(一)——ECMAScript、BOM、DOM(核心、浏览器对象模型与文档对象模型)

    一.JavaScript简介 JavaScript是一种解释执行的脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型,它遵循ECMAScript标准.它的解释器被称为JavaScript引 ...

  8. JavaScript的组成—ECMAScript、BOM和DOM

      JavaScript 是一种基于 ECMAScript 规范的脚本语言,并在此基础上进行了自己的封装.ECMAScript 不是一种编程语言,仅仅是一种脚本语言规范,由欧洲计算机协会制定和发布,任 ...

  9. 关于dom&bom

    javascript 有三部分构成,ECMAScript,DOM和BOM,根据宿主(浏览器)的不同,具体的表现形式也不尽相同,ie和其他的浏览器风格迥异. 1. DOM 是 W3C的标准:[所有浏览器 ...

随机推荐

  1. 怎么找到苹果App Store的应用程序下载链接地址

    http://jingyan.baidu.com/article/6dad5075f6fa79a123e36e85.html 怎么找到苹果App Store的应用程序下载链接地址 每个上传到苹果app ...

  2. 关于JavaScript的判断语句(2)

    上一篇描述的都是一些通过条件判断来执行,符合条件下面的代码块,达到对动作的反应效果 这篇将描述的是for. for/in. while. do/while循环语句. for语句: for(i=0,i& ...

  3. Ehcache Demo

    转自: https://my.oschina.net/zb0423/blog/60957http://www.cnblogs.com/fsjin/articles/3521261.html Ehcac ...

  4. Selenium2学习-042-Selenium3启动Firefox Version 48.x浏览器(ff 原生 geckodriver 诞生)

    今天又被坑了一把,不知谁把 Slave 机的火狐浏览器版本升级为了 48 的版本,导致网页自动化测试脚本无法启动火狐的浏览器,相关的网页自动化脚本全线飘红(可惜不是股票,哈哈哈...),报版本不兼容的 ...

  5. async 和 await小结

    三大返回值: 返回类型 - Task<TResult> 返回类型 - Task 返回类型 - void 当你添加 async 关键字后,需要返回一个将用于后续操作的对象,请使用 Task& ...

  6. jenkins配置邮件

    1.安装 Email Extension Plugin 插件 2.进入系统管理--系统设置 3.按照如下图设置 首先找到 Extended E-mail Notification  

  7. iOS,手势识别简单使用

    1.iOS目前支持的手势识别(6种) 2.点按手势和慢速拖动手势简单使用 iOS目前支持的手势识别(6种) UITapGestureRecognizer(点按) UIPinchGestureRecog ...

  8. ios - runtime运行时应用---交换方法

    runtime运行时用法之一 --- 交换类的方法,此处简单写了把系统的UIView的setBackgroundColor的方法换成了自定义的pb_setBackgroundColor 首先创建UIV ...

  9. CSS实现单行、多行文本溢出显示省略号(…)

    如果实现单行文本的溢出显示省略号同学们应该都知道用text-overflow:ellipsis属性来,当然还需要加宽度width属来兼容部分浏览. 实现方法: overflow: hidden; te ...

  10. 解决web浏览器与servlet之间传输数据时出现的乱码问题

    1.使用getParam等方法获取请求参数时遇到乱码 浏览器发送的请求参数使用的编码就是打开网页时使用的编码.如果服务器端获取到发过来的请求参数,默认使用ISO8859-1进行解码操作,中文一定会有乱 ...