Vue前端面试题(一)

1.闭包

闭包:一个方法里返回一个方法

function a(){
 let a=2
let b=1
return function(){
return b                 //闭包里面返回什么外部才能拿到什么 因为代码结束后闭包中b没被销毁,常驻于内存中
}
}

闭包存在的意义

1延长变量的生命周期

例如:上面代码块中的b 代码执行结束不会被销毁 ,常驻于内存中,因此闭包要慎用(类似于全局变量不会被垃圾回收)

2创造私有环境

Vue中data(){}为什么是一个函数

data(){
return:{          //这就是一个闭包,把各个组件中的data设为私有属性,其它组件访问不到

}


2.作用域链

let name="小张"function fn2(){

    let name="小白"
    function fn3(){
        let name="小红"                  
        console.log(name)  //会输出小红  因为存在作用域链会一层一层往上找(就近原则输出)
    }
    fn3()
}
fn2() 

3..ES6相关面试题

3.1.let 和var

代码提升

console.log(name)              console.log(name)
let name="张三" //报错         var name="张三"  //undefined

let不能重复声明

var name="张三"                   let  name="张三"
var name="李四"                   let name="李四"
console.log(name)  //李四         console.log(name)//报错

let有块级作用域

function fn(){
for(var i=0;i<3;i++){
console.log(i) //0  1  2
}
console.log(i) //3  var没有块级作用域在for循环体外可以访问
}
fn()

3.2 const

  • const声明的值必须赋值否则报错

  • const声明的值不能被修改否则报错(数组和对象除外)

  • const支持let的上面特点

3.3关于解构相关

a b 互换

let a=1
let b=2
[a,b]=[b,a]
console.log(a,b) //2,1

3.4数组去重set集合

let arr=[1,2,3,2,3,4]
let result=[...new set(arr)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr.指尖舞者

如果帮助到了你,请给点赞助支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值