前端面试你所不知道系列--var和不var

写在开始

又到了一年的伊始,很多人可能因为各种原因想换一份工作,而找工作难免遇到各种各样头痛的面试题,于是我打算写一个系列,关于面试中最常见或者前端一些基础但又不是很深入了解的知识,供大家参考。

先来道开胃菜

使用var定义

var a = 'hello World'
function bb(){
 var a = 'hello Tom';
    console.log(a);   
}
bb()   
console.log(a);    
复制代码

不使用var定义

var e = 'hello world';
function cc(){
    e = 'hello Tom';
    console.log(e);
}
cc()   
console.log(e)    
复制代码

猜猜会执行什么?

其实很简单,使用var先后打印// 'hello Tom' // 'hello world',

不使用var先后打印// 'hello Tom' // 'hello Tom'

大家都知道Javascript声明变量是通过关键字var。使用var关键字是在当前域中声明变量,如果在方法中声明,则为局部变量(local varibble);如果在全局域中声明,则为全局变量。

但在非严格模式下,不通过var直接声明变量,则是全局变量,好像也不会报错,例如a = 1 console.log(a) // 1,但这样真的没问题吗?那么执行a = 1; 发生了什么呢?

它会尝试在当前作用域链(如果是在方法中,则当前作用域链代表全局和方法局部作用域)中解析a;如果在任何当前作用域找到a;则会对a属性赋值;如果没有找到a,它会在全局对象(当前作用域最顶层,如window对象)中创造a属性并赋值。

请注意!!!是创建一个全局对象的属性,而不是声明了一个全局变量。

或许你可能不是很明白‘声明变量’和‘创建对象属性’有什么区别。但事实上,Javascript 的变量声明、创建属性都有一定的标志去声明他们的属性如:只读(ReadOnly)不可枚举(DontEnum)不可删除(DontDelete)等等。

由于‘变量声明’自带不可删除属性,比较var a = 1 跟 a = 1,前者是变量声明,带不可删除属性,因此无法被删除;后者为全局变量的一个属性,因此可以从全局变量中删除。

    var a = 1
    b = 2
    console.log(delete a) // false
    console.log(delete b) // true
复制代码

变量提升

使用var定义:

function hh(){
    console.log(a);
    var a = 'hello world';
}
hh()    //undefined
复制代码

不使用var定义:

function hh(){
    console.log(a);
    a = 'hello world';
}
hh()    // 'a is not defined'
复制代码

还有一点很容易被忽略,在ES5的'use strict'模式下,如果变量没有使用var定义,就会报错。 这也是一个差别。

总结

1.在函数作用域内 加var定义的变量是局部变量,不加var定义的就成了全局变量。

2.在全局作用域下,使用var定义的变量不可以delete,没有var 定义的变量可以delete。

3.使用var 定义变量还会提升变量声明。

4.在ES5的'use strict'模式下,如果变量没有使用var定义,就会报错。

写在最后

由于个人能力有限,如果文中出现任何错误,欢迎各位大神提出批评和建议,这是鄙人首次发表技术性文章,希望大家多多支持。

下期预告:前端面试你所不知道系列--伪类和伪元素

转载于:https://juejin.im/post/5a72a7f26fb9a01c94062e24

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些拼多多面试中可能会涉及到的前端面试题和答案: 1. 说一下 CSS 盒模型? 答:CSS 盒模型是指在网页布局时,每个元素所占据的空间可以看做是一个矩形的盒子。盒模型包括内容区域(content)、内边距区域(padding)、边框区域(border)和外边距区域(margin)。 2. 什么是闭包? 答:闭包是指在函数内部定义的函数,它可以访问到它外部函数的变量和参数,即使外部函数已经执行完毕,闭包仍然可以访问到这些变量和参数。闭包在 JavaScript 中非常常见,比如在事件处理器、定时器、Ajax 请求等场景中都会用到。 3. 什么是跨域?如何解决跨域问题? 答:跨域是指在浏览器中,如果一个网页的脚本试图访问不同源(协议、域名、端口)的服务器资源,就会引发跨域问题。为了保证浏览器的安全性,浏览器会限制脚本访问不同源的资源。 解决跨域问题的方法有很多种,常用的方法包括: - JSONP:利用 <script> 标签可以跨域访问资源的特性,通过动态创建 <script> 标签,将需要获取的数据以参数的形式传递给服务器,服务器在返回时将数据包裹在一个函数调用中,从而实现跨域获取数据。 - CORS:CORS(Cross-Origin Resource Sharing)是一种基于 HTTP 头部的跨域解决方案,它允许服务器在响应头中设置 Access-Control-Allow-Origin 头部,表明哪些源可以访问该资源。 - 代理:通过在同源服务器上设置代理,在代理服务器上转发请求,从而实现跨域访问资源。 4. 如何实现一个简单的 Promise? 答: ```javascript function MyPromise(fn) { var self = this; self.value = null; self.error = null; self.onFulfilled = null; self.onRejected = null; function resolve(value) { setTimeout(function() { self.value = value; self.onFulfilled(self.value); }, 0); } function reject(error) { setTimeout(function() { self.error = error; self.onRejected(self.error); }, 0); } fn(resolve, reject); } MyPromise.prototype.then = function(onFulfilled, onRejected) { var self = this; self.onFulfilled = onFulfilled; self.onRejected = onRejected; }; ``` 5. 什么是事件冒泡和捕获?如何阻止事件冒泡? 答:事件冒泡和捕获是指在页面中,当一个元素触发了某个事件时,该事件会先从最外层的元素开始依次向下传递,直到触发该事件的元素为止,这个过程称为事件冒泡;相反,事件捕获是从最外层元素开始,依次向下寻找触发该事件的元素,这个过程称为事件捕获。 阻止事件冒泡的方法包括: - 使用 Event 对象的 stopPropagation() 方法,可以阻止事件继续向上传播。 - 在事件处理函数中,返回 false 可以阻止事件继续向上传播。 以上是一些常见的拼多多前端面试题和答案,希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值