1.1-事件委托面试点
- 1.什么是事件委托
- 给父元素注册事件,委托给子元素处理
- 2.事件委托原理:==事件冒泡==
- 3.事件委托注意点
- this : 指向父元素
- e.target : 指向触发事件的子元素
- 4.事件委托场景 :
给动态新增元素注册委托事件
1.2-new关键字做了哪些事情
- 1.创建空对象
- 2.this指向这个对象
- 3.对象赋值
- 4.返回实例对象
1.3-原型链相关
- 1.原型链作用 : 面向对象
继承 - 2.对象访问原型链规则: 就近原则
- 先访问自己,自己没有找原型,原型没有找原型的原型,直到原型链终点。 如果还找不到,属性则获取undefined,方法则报错xxx is not defined
1.4-如何判断this指向
- this : 谁
调用我,我就指向谁 - 普通函数
函数名(): window - 对象方法
对象名.方法名(): 对象 - 构造函数
new 函数名(): new创建的实例对象
1.5-call apply bind区别
- 共同点:
- 都可以修改this,第一个参数都是
修改的this
- 都可以修改this,第一个参数都是
- 不同点
- 传参方式不同: call是逐一传参, apply是数组/伪数组传参
- 函数名.call(修改的this,参数1,参数2....)
- 函数名.apply(修改的this,数组/伪数组)
- 执行机制不同:call和apply会立即执行函数,bind不会立即执行
-
bind会得到一个修改this后的新函数
-
- 传参方式不同: call是逐一传参, apply是数组/伪数组传参
1.6-如何判断数据类型
-
- typeof有两种数据类型无法检测: null 、array
-
- Object.prototype.toString.call(数据)
1.7-闭包
- 1.闭包是什么 :
- 闭包 是 使用其他函数内部变量的 函数 (闭包 = 函数 + 其他函数内部变量)
- 闭包 = 函数 + 上下文引用
- 2.闭包作用 : 解决全局变量污染
1.8-递归及应用场景
- 1.递归 : 在函数内部调用自己
- 2.递归作用 :
-
浅拷贝与深拷贝
-
遍历dom树
-
1.9-浅拷贝与深拷贝
- 1.浅拷贝:拷贝地址, 修改拷贝后的数据原数据也会变化
- 2.深拷贝:拷贝数据, 修改拷贝后的数据原数据不会变化
- 推荐 json : let obj = JSON.parse( JSON.stringify( 对象 ) )
- 递归