Function函数
- this对象的指向性不明确,随着环境的变化会发生变化
- 定义的函数,具有默认的提升
- 可以作为构造函数,this会根据new 指向空对象
- 存在arguments集合
function show(){
console.log(this)
}
show() // window
let obj = {
name:"王一",
show:show
}
obj.show() // obj
箭头函数
- 箭头函数this用于指向生产环境 ,不跟随调用着发生变化
- 不存在函数的提升功能
- 无法作为构造函数
- 不存在arguments,但有rest参数 代替arguments
let show=(a,b,...args)=>{
console.log(args) //rest参数 只会保存形参之后的实参
}
show(1,2,3)
let obj={
name:"王一",
show:show
}
obj.show()
this指向问题: 一般情况下this的最终指向的是那个调用它的对象
- 全局作用域或者普通函数中this指向全局对象window( 注意定时器里面的this也是指向window)
console.log(this); // window
function fn() {
console.log(this); // window
}
window.fn();
window.setTimeout(function(){
console.log(this); // window
}, 1000);
- 方法调用中谁调用this就指向谁
var o = {
sayHi: function() {
console.log(this); // this指向的是 o 这个对象
}
}
o.sayHi();
- 事件处理函数中的this指向事件源
<button>点击</button>
<script>
var btn = document.querySelector('button');
btn.onclick = function() {
console.log(this); // this指向的是btn这个按钮对象
}
</script>
- 构造函数中的this指向构造函数的实例
function Fun() {
console.log(this); // this 指向的是fun 实例对象
}
var fun = new Fun();