DOM

常用的DOM获取方法:

  • node.children 返回子元素节点,没有兼容性问题,动态获取
  • node.parentNode 获取父节点,没有兼容性问题
  • node.offsetParent 获取最近的定位父节点
  • node.tagName 获取元素节点的标签名

常用的DOM操作:

  • document.createElement(“TagName”) 创建一个元素节点

  • parentNode.appendChild(node) 在父节点内容的最后添加子节点

  • parentNode.insertBefore(insertNode,targetNode) 在目标节点前插入一个节点

  • parentNode.replaceChild(replaceNode,targetNode) 用一个节点替换掉目标节点

  • parentNode.removeChild(Node) 删除某个子节点

  • node.cloneNode(Boolean) 接受一个布尔值作为参数,false时为浅克隆,只复制节点本身;true时为深克隆,节点和它的后代节点全部克隆(但是它们自身的事件是不会克隆过来的)

  • document.createDocumentFragment() 文档碎片,作为中间仓库,把要插入所有的节点先存起来,再一次性插入。

innerHTML 和 appendChild() 方法添加子元素节点的区别

  • node.innerHTML()方法是用字符串的形式添加子元素节点,要注意这样做会覆盖原先存在的节点,导致原节点身上的事件无效

  • appendChild()每次调用会让页面重新渲染,所以调用次数过多会使页面性能下降

因此如果操作的节点身上没有事件的话,推荐使用innerHTML方法;若添加的节点身上带有事件而且数量还挺多的话可以使用文档碎片方法

文档节点的相关属性

以下属性都没有单位,默认为px。

  • client:没有兼容性问题,只读属性

    clientWidth / clientHeight

    在元素上使用,获取的是content大小 + padding大小

    document.documentElement(就是html元素) 使用:文档可视区域的大小,不是总大小(不包含滚动条)

    clientTop / clientLeft

    边框的厚度

  • offset: 没有兼容问题

    offsetWidth / offsetHeight

    在元素上使用,获取的是content大小 + padding大小 + 边框大小

    document.documentElement 使用 : 只能获取可视区域的宽度,但是能获取实际高度

    offsetTop / offsetLeft

    获取元素顶部距离定位父级顶部距离的值,但是不包含定位父级的边框厚度

    获取元素左边距离定位父级左边距离的值,但是不包含定位父级的边框厚度

  • scroll:

    scrollWidth / scrollHeight

    在元素上使用,获取的是content大小 + padding大小

    当元素内容超出,宽度 = content大小 + 左padding大小 + 超出部分的大小 = 左padding + 内容宽度

    如果元素内容超出,并且使用overflow:hidden,宽度 = content大小 + padding大小 + 超出部分的大小 = padding + 内容宽度

    scrollTop / scrollLeft IE5不行,可写属性

    document.documentElement.scrollTop / document.body.scrollTop(不同浏览器会兼容其一种写法,最好两种同时写上)

    document.documentElement.scrollLeft / document.body.scrollLeft

    获取滚动轴x轴或者y轴方向的滚动偏移值

  • inner: 不兼容IE8,了解即可

    innerWidth / innerHeight window专属,获取窗口的可视区域宽高(加上滚动条的宽度)

鼠标属性

事件对象e(IE是window.event)下的鼠标属性:

  • client: 没有兼容问题

    clientX / clientY

    鼠标到可视区域的top和left值(鼠标当前点击鼠标的x和y坐标)
  • page: 不兼容IE8及以下 (用client+scroll替代)

    pageX / pageY

    鼠标到文档顶部的left和top值

阻止事件冒泡

事件冒泡:指的是子类触发了某个事件,若子类的父级存在相同的事件类型也会依次全部触发。

阻止冒泡:只是阻止了事件的冒泡,事件源的事件依然会执行。

事件源.事件 = function(e){
e = e || window.event; //兼容ie
if(e.stopPropagation){
e.stopPropagation();
}else{
e.cancelBubble = true; //兼容ie
}
}

DOM2级事件

IE10以上和其他浏览器:

addEventListener(事件名不加on, 事件处理函数, 布尔值)/removeEventListener(事件名不加on, 事件处理函数, 布尔值) 顺序执行,先绑定的先执行

这里布尔值默认为false,表示冒泡。若设置为true则表示捕获,其执行则触发其子元素同类事件执行。

兼容IE10以下:

attachEvent(on+事件名, 事件处理函数)/detachEvent(on+事件名, 事件处理函数) 逆序执行,先绑定的后执行。要特别注意,此时事件处理函数中的this不再指向事件源而是指向window,因此需要用call函数处理。

事件代理(事件委托)

原理是利用事件的冒泡(/捕获)的特性,在子元素触发事件后冒泡被父元素捕捉到,因此在父元素事件对象中的target属性(IE中为e.srcElement)就会指向这个触发事件的子元素。e.currentTarget指向的是添加监听事件的父元素本身。

因此要注意,只有能冒泡的事件才能用事件代理!像onmouseenter和onmouseleave这两个不冒泡的事件是不行的!

阻止默认行为

阻止事件触发时默认会执行的行为。

target.onXXX = function(event){
event = event || window.event;
if(event.preventDefault){
event.preventDefault(); //主流浏览器
}else{
event.returnValue = false; //低版本IE
}
}

滚轮事件

  • 谷歌和IE浏览器

    滚轮事件 mousewheel (未绑定事件时,在谷歌和IE中这个属性为null,在火狐浏览器中为undefined,可以依此做兼容性处理)

    滚动方向步长 event.wheelDelta 上滚+120 下滚-120

  • 火狐独有

    滚轮事件 DOMMouseScroll 只允许DOM2级事件绑定

    滚动方向步长 event.detail 上滚-3 下滚+3

前端知识点回顾——Javascript篇(五)的更多相关文章

  1. 前端知识点回顾——Javascript篇(二)

    JavaScript的解析顺序 第一阶段:编译期 寻找关键字声明的变量.函数声明的变量,同时会对变量进行作用域的绑定 var声明的变量,在编译期会赋一个默认值undefined,变量提升的特性. ES ...

  2. 前端知识点回顾——Javascript篇(六)

    fetch 在原生ajax+es6promise的基础上封装的一个语法糖,返回promise对象. fetch(url, initObj) .then(res=>res.json()) .the ...

  3. 前端知识点回顾——Javascript篇(四)

    Symbol 为什么需要symbol ES5里面对象的属性名都是字符串,如果你需要使用一个别人提供的对象,你对这个对象有哪些属性也不是很清楚,但又想为这个对象新增一些属性,那么你新增的属性名就很可能和 ...

  4. 前端知识点回顾——Javascript篇(三)

    数组的冒泡.选择和插入排序法 冒泡排序法(从小到大) function bubble(arr){ for(let i = 0 ;i<arr.length-1;i++){ for(let j = ...

  5. 前端知识点回顾——Javascript篇(一)

    DOM特殊元素获取 document.documentElement //HTML标签 document.head //head标签 document.title //title标签 document ...

  6. web前端知识点(JavaScript篇)

    call,apply,bind call,apply,bind这三者的区别,及内部实现原理,点这里 promise promise函数的内部实现原理,点这里 闭包 闭包就是能够读取其他函数内部变量的函 ...

  7. 前端知识点回顾——HTML,CSS篇

    前端知识点回顾篇--是我当初刚转行为了面试而将自己学过的前端知识整理成的一份笔记,个人目的性很强,仅供参考. doctype 有什么用 doctype是一种标准通用标记语言的文档类型声明,目的是告诉标 ...

  8. [转] Web前端优化之 Javascript篇

    原文链接: http://lunax.info/archives/3099.html Web 前端优化最佳实践之 JavaScript 篇,这部分有 6 条规则,和 CSS 篇 重复的有几条.前端优化 ...

  9. 前端开发之JavaScript篇

    一.JavaScript介绍  前端三剑客之JavaScript,简称js,可能是这三个里面最难的一个了.很早以前,市面上流通着三种js版本,为了统一,ECMA(欧洲计算机制造协会)定义了规范的版本, ...

随机推荐

  1. js 数值精确运算使用math.js

    javaScript 浮点数运算的精度问题 问题:编程中你可能会遇到0.1*7=0.7000000000000001; 原因:几乎所有的编程语言都采用了 IEEE-745 浮点数表示法,任何使用二进制 ...

  2. WPF实战案例-MVVM模式下用附加属性在Xaml中弹出窗体

    嗯..最近回家去了,2个月没写过代码了,面试只能吹牛,基础都忘了,今天回顾一下,分享一篇通过附加属性去处理窗体弹出的情况. 或许老司机已经想到了,通过设置附加属性值,值变更的回调函数去处理窗体弹出,是 ...

  3. 解决No module named 'sklearn.cross_validation'

    sklearn中已经废弃cross_validation,将其中的内容整合到model_selection中 将sklearn.cross_validation 替换为 sklearn.model_s ...

  4. Hadoop_16_MapRduce_MapTask并行度(切片)的决定机制

    MapTask的并行度决定map阶段的任务处理并发度,进而影响到整个job的处理速度那么,mapTask并行实例是否越多 越好呢?其并行度又是如何决定呢?Mapper数量由输入文件的数目.大小及配置参 ...

  5. HTML5 离线缓存manifest

    1.简介W3C官方对manifest的介绍是HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问. 应用程序缓存为应用带来三个优势: 离线浏览 - 用户可在 ...

  6. 团队第三次作业:Alpha版本发布

    这个作业属于哪个课程 课程链接 这个作业要求在哪里 作业要求链接 团队名称 众志陈成 这个作业的目标 通过团队协作了解软件开发的大致流程,并在这个过程中体会调整与优化程序的方法,为以后真实的软件开发奠 ...

  7. VLC 可能的 XML parser error 解决

    由于 VLC 设置不当 (通常是动了 skin 选项……),再次加载时 VLC 不能正常启动,并报如下错误: [00007f7dd003b670] xml xml reader error: XML ...

  8. [USACO15FEB]Superbull 超级牛

    题意概况 题目描述 \(Bessie\)和她的朋友们正在一年一度的\(Superbull\)锦标赛中打球,而\(Farmer John\)负责让比赛尽可能激动人心. 总共有 \(N\) 支队伍 \(1 ...

  9. RAID 5 是一种存储性能、数据安全和存储成本兼顾的存储解决方案

    可用容量:(n-1)/n的总磁盘容量(n为磁盘数) 原因:RAID5把数据和相对应的奇偶校验信息存储到组成RAID5的各个磁盘上,并且奇偶校验信息和相对应的数据分别存储于不同的磁盘上,其中任意N-1块 ...

  10. BZOJ3331 [BeiJing2013]压力[圆方树+树上差分]

    圆方树新技能get.具体笔记见图连通性问题学习笔记. 这题求无向图的必经点,这个是一个固定套路:首先,一张连通的无向图中,每对点双和点双之间是以一个且仅一个割点连接起来的(如果超过一个就不能是割点了) ...