JavaScript Es5与Es6语法优缺点总结

本文总结了JavaScript ES5与ES6在定义变量、箭头函数与Function函数的差异,包括var、let、const的区别,箭头函数与传统函数的this指向问题,并探讨了Function函数的this在不同场景的指向。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. var 、let 与const定义变量的区别

区别一 :

  • 原始js使用var进行变量的定义
  • 只存在两个作用域:全局作用域 局部作用域
  • ES6之后:新增定义变量的方式 let 与const
  • 新增一个作用域:块级作用域
if(true){
   	var x = 20;
}
console.log(x); // 20

if(true){
    let y = 20;
}
console.log(y); // 报错,变量y未定义

区别二 : 利用var 定义变量 存在变量的默认提升功能,let与const不存在这个问题

console.log(x); // undefined 
var x=20
console.log(x); // 报错
let x=20

区别三: 利用var定义变量可以重复定义,但是let 和const不可以

var index = 20
var index = 30
console.log(index); // 30

let index = 20;
let index = 30;
console.log(index); //报错

区别四: 利用var定义的变量,会自动挂载到window,但是let和const不会

var x = 20;
console.log(window.x); // 20

let y = 30;
console.log(window.y); // undefined

区别五:

  • let和const 存在暂时性死区问题
  • 使用let定义变量 在声明之前 永远不可用
var a = 30;
if(true){
    a = 40;
    console.log(a); // 报错
    let a = 50;
} 

const用于定义常量,定义时必须赋初始值,且不能更改

const a = 10;
console.log(a); // 10

a = 12;
console.log(a); // 报错 

2. 箭头函数与Function函数的对比

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()

3.Function函数的this指向

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();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值