原生JS forEach和map遍历的区别以及兼容写法

JavaScript06

原生JS forEach和map遍历的区别以及兼容写法,第1张

Array.prototype.map()

map() 方法创建一个新数组,其结果是该数组中的每个元素调用一个提供的函数。

Array.prototype.forEach()

forEach() 方法对数组的每个元素执行一次提供的函数。

虽然都是循环遍历一次 但是map是可以带返回值的 可以在循环中用回调创建一个新的数组, forEach仅是循环 与基本的的for无异

pdf.js兼容ie8的写法如下:var DEFAULT_URL = '**.pdf'只用修改viewer.js文件中的pdf路径参数即可。如果pdf文件与viewer.html不在一层目录中,改成相对路径即可。

pdf.js是一个由HTML5建立的PDF阅读器。依托开源社区驱动和Mozilla实验室的技术支持。目标是建立一个通用的,基于web的解析和渲染PDF文件的平台。

    开发中,当执行一个事件时需要去知道触发这个事件的对象是谁?那么,如何获取,在这里我就对 event.srcElement与event.target 操作获取略作区分 。

event.srcElement: 表示可以获取当前作用事件的对象。

event.target: 事件属性可返回事件的目标节点(触发该事件的节点),如生成事件的元素、文档或窗口。

兼容性:

event.target: Ie9+ 火狐、谷歌;

event.srcElement:ie 678;

srcElement 是 IE 下的属性

target 是 Firefox 下的属性

Chrome 浏览器同时有这两个属性

一、利用event.srcElement 获取标签:

event.srcElement.tagName :因为它获取出来的都是以 大写 的形式,例如(“A”,“DIV”)所以需要转换 obj.tagName.toLowerCase()="a"

二、 利用event.srcElement 获取子对象:

第一个子标签 :event.srcElement.firstChild

最后个一个是: event.srcElement.lastChild

第几个孩子: event.srcElement.children[i]

所有孩子: event.srcElement.children

所有孩子节点: event.srcElement.childNodes

三、利用event.srcElement 获取父对象:

.event.srcElement.parentElement; 可以理解成是在鼠标所在对象的上一个对象。

四、vent.target的 判断使用  

 js中事件是会泡的,event.target它永远是直接接受事件的目标DOM元素  

一般是获取这个对象的id,兼容的写法如下:

var targetId = event.target ? event.target.id : event.srcElement.id

获取id后再拿到事件中去判断。

谢谢观读~

��