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. 5.AOP配置与应用(annotation的方式)

    步骤: a)在beans.xml文件中加上对应的xsd文件 spring-aop.xsd b)加上<aop:aspectj-autoproxy>,使用aspectj来完成aop <! ...

  2. C#面向对象(抽象类、接口、构造函数、重载、静态方法和静态成员)

    1.抽象类    抽象类关键词   abstract   (抽象)  override    (重写) 在父集中用   abstract 表示抽象类,抽象方法,在子集中用  override 改写 抽 ...

  3. 【Distributed】CDN

    一.概述 1.1 Web前端优化 1.2 DNS域名解析过程 1.3 传统方式请求静态资源 二.CDN内容分发 2.1 什么是CDN 2.2 CDN内容分发原理 2.3 阿里云环境实战搭建CDN内容分 ...

  4. python 之math模块

    一.math 简介 import math # 导入模块 ret = dir(math) # 查看所有函数名列表 print(ret) # ['__doc__', '__loader__', '__n ...

  5. 蓝桥杯入门——1.Fibonacci数列

    问题描述 Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1. 当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少. 输入格式 输入包含一个整数n ...

  6. Ubuntu系统---安装搜狗输入法

    Ubuntu_搜狗输入法 第一步: 1,下载搜狗输入法的安装包. 下载地址为:http://pinyin.sogou.com/linux/ ,如下图,要选择与自己系统位数一致的安装包,我的系统是64位 ...

  7. [SHOI2013]阶乘字符串

    题目描述 给定一个由前\(n\)个小写字母组成的串\(S\). 串\(S\)是阶乘字符串当且仅当前\(n\)个小写字母的全排列(共\(n!\)种)都作为\(S\)的子序列(可以不连续)出现. 由这个定 ...

  8. SpiderMan成长记(爬虫之路)

    第一章 爬虫基础 1.1 爬虫基本原理 1.2 请求库 -- urllib库的使用 1.3 请求库 -- requests库的使用 1.4 数据解析 -- 正则基础 1.5 数据解析 -- lxml与 ...

  9. C++踩坑记录(一)std:;string的析构

    之前写服务端程序有一个往消息队列里面推json的过程,然后发现推进去C#端取到的无论如何都是个空指针 简单复现一下现场 string str1 = string("hello1") ...

  10. 在MyEclipse10中使用Maven

    虽然很多人说maven比起gradle来已经又落后了,但还是有必要了解一下的. 这两天看了好多文章,也跟着做了很多例子,无一例外,创建的pom.xml文件都是有错的.而且由于使用的开发工具不一致,导致 ...