一、在ES5中,js 的作用域

js作用域,只有全局作用域与函数作用域,没有块级作用域。

1、全局作用域


var a = 10;
function aaa() {
alert(a)
} function bbb(){
var a=20;
aaa()
} bbb(); //

a =10 是全局的  而a=20 是局部的

2、变量的查找是就近原则,去寻找var定义的变量,当就近没有找到的时候就去查找外层。

var a=10
function aaa(){
alert(a);
var a=20
} aaa(); // undefined,一是预解析,二是就近查找。
var a = 10
function aaa(){
alert(a)
a=20
}
aaa(); //

这个虽然是就近原则,但是就近找var声明的变量,因为a= 20  没有var声明,只是修改了a 的值,所以到外面去找了,输出的是10。不过没错的是a=20后,a确实为20了,只不过alert的时候还没有执行到那~~

var a = 10
function aaa(){
a=20
alert(a)
}
aaa(); //

3、全局作用域与函数作用域:

var a=10
function aaa(){
bbb();
alert(a);
function bbb(){
var a=20
}
}
aaa(); //

4、当参数跟局部变量重名时,优先级是等同的。

var a=10;
function aaa(a){
alert(a)
var a= 20;
}
aaa(a) // 10

js 中传参时,基本类型传值,引用类型传引用。

 var a = 5;
var b=a;
b +=3
alert(a); //
var a = [1,2,3]
var b=a;
b = [1,2,3,4];
alert(a); //[1,2,3]
var a = [1,2,3]
var b=a;
b.push(4);
alert(a); //[1,2,3,4]

参数与变量一样也是有作用域:

var a=10;
function aaa(a){
a +=3
}
aaa(a)
alert(a) // 10
var a=10;
function aaa(a){
a +=3
alert(a)
}
aaa(a)
// 13

var a= [1,2,3]
function aaa(a){
a=[1,2,3,4]
}
aaa(a)
alert(a) // 1,2,3
var a= [1,2,3]
function aaa(a){
a.push(4)
}
aaa(a)
alert(a) // 1,2,3,4
 

二、es6 中,块级作用域

块作用域由{ }包括,if语句和for语句里面的{ }也属于块作用域。

1、块作用域,var的变量外部是可以访问的。

{
var a= 1;
console.log(a) //
} console.log (a) // ( function A() {
var b=2;
console.log(b) //
}) (); console.log(b); //报错 if(true){
var c=3
} console.log(c) //

2、 var 、 let 、 const 区别

var定义的变量,没有块的概念,可以垮块访问,不能跨函数访问;

let定义的变量,只能在块作用域里访问,不能跨块访问,也不能跨函数访问;

const 用来定义常量,使用时必须初始化(即必须赋值),只能在块作用域里访问,而且不能修改。

<script type="text/javascript">
// 块作用域
{
var a = 1;
let b = 2;
const c = 3;
// c = 4; // 报错
var aa;
let bb;
// const cc; // 报错
console.log(a); //
console.log(b); //
console.log(c); //
console.log(aa); // undefined
console.log(bb); // undefined
}
console.log(a); //
// console.log(b); // 报错
// console.log(c); // 报错 // 函数作用域
(function A() {
var d = 5;
let e = 6;
const f = 7;
console.log(d); //
console.log(e); // 6 (在同一个{ }中,也属于同一个块,可以正常访问到)
console.log(f); // 7 (在同一个{ }中,也属于同一个块,可以正常访问到) })();
// console.log(d); // 报错
// console.log(e); // 报错
// console.log(f); // 报错
</script>

js作用域总结的更多相关文章

  1. JS作用域面试题总结

    关于JS作用域问题,是面试的时候面试官乐此不疲的面试题,有时候确实是令人抓狂,今天看到一个讲解这个问题的视频,明白了那些所谓的“原理”顿时有种豁然开朗的感觉~~~ 1.js作用域(全局变量,局部变量) ...

  2. js作用域问题

    <script type="text/javascript"> alert(i);//Uncaught ReferenceError: i is not defined ...

  3. js 作用域

    js 作用域 js作用域链查找,子函数能取到父函数中定义的变量. 前段时间误写成如下形式: 这只是普通的函数调用,没有父子的关系,child()函数会在全局查找pi变量,没找到所以报错. 最近发现原来 ...

  4. 08.01 签到! js 作用域

    js 作用域 : 1.js 没有块作用域 : for (var i = 0;i < 4; i++){ } alert(i) // i = 3 2.js 没有动态作用域: function f1( ...

  5. js作用域链

    js作用域链 <script> var up = 555; function display(){ var innerVar = 2; function inner(){ var inne ...

  6. easyui datagrid load 封装 参数问题 js 作用域

    var temp = { LoginAccount: $('#LoginAccount').val(), ShopName: $('#ShopName').val() }; function doSe ...

  7. js作用域零碎的知识点,不同的script块,虽然同是全局变量

    如下代码,第一次弹出a,因为解析器里找到var a,赋予a变量undefined,弹出undefined <!DOCTYPE html> <html> <head> ...

  8. JS作用域,作用域,作用链详解

    前言   通过本文,你大概明白作用域,作用域链是什么,毕竟这也算JS中的基本概念. 一.作用域(scope) 什么是作用域,你可以理解为你所声明变量的可用范围,我在某个范围内申明了一个变量,且这个变量 ...

  9. JS作用域和ASP(vbs)作用域比较

    一.js作用域,先上图: 以上代码执行的效果是,依次弹出 undefined, undefined, a, a,为什么是这样的结果啦?因为JS的作用域为链式作用域. 作用域链: 用VAR声明一个变量时 ...

  10. js作用域对象与运用技巧

    1. JS作用域 1.1 全局作用域和局部作用域 函数外面声明的就是 全局作用域 函数内是局部作用域 全局变量可以直接在函数内修改和使用 变量,使用var是声明,没有var是使用变量. 如果在函数内使 ...

随机推荐

  1. 2016.8.19 将div设置为隐藏使用style=“display:none”

    style="display:none"表示隐藏. style="display:block"表示显示. 在代码中则使用$("#id").s ...

  2. Node.js自动化测试及大规模性能测试技术实现(Java&Node.JS)

    后续计划: 改进1:性能测试Tool由Client端设计成Server端,支持分布式中控部署 改进2:SocketTestFramework集成WebSocket协议 改进3:完善Data Analy ...

  3. PGM图片格式与代码

    这两天在搞神经网络,里面的一个人脸数据库的图片格式是PGM,事实上之前早就知道了这个图片格式,可是没去深究这个图片格式的数据究竟是什么安排的.搜索了下百度百科,发现介绍的真是简单,以下就自己来系统地整 ...

  4. js 保留两位小数 javascript

    alert((0.9996*100).toFixed(2)); 得到99.96,这是我想要的! 使用Number.toFixed()可以格式数字显示任意的小数位!

  5. C 语言经典100例

    C 语言经典100例 C 语言练习实例1 C 语言练习实例2 C 语言练习实例3 C 语言练习实例4 C 语言练习实例5 C 语言练习实例6 C 语言练习实例7 C 语言练习实例8 C 语言练习实例9 ...

  6. XTUOJ 1176 I Love Military Chess(模拟)

     I Love Military Chess Accepted : 45   Submit : 141 Time Limit : 1000 MS   Memory Limit : 65536 KB ...

  7. os引导程序boot从扇区拷贝os加载程序loader文件到内存(boot copy kernel to mem in the same method)

    [0]README 0.1) 本代码旨在演示 在boot 代码中,如何 通过 loader文件所在根目录条目 找出该文件的 在 软盘所有全局扇区号(簇号),并执行内存中的 loader 代码: 0.2 ...

  8. UVALive 6530 Football (水

    题目链接:点击打开链 #include <cstdio> #include <vector> #include <algorithm> using namespac ...

  9. windows 2008配置运行PHP5.5.X

    1.安装web5.0平台安装程序.web5.0平台安装程序:http://www.iis.net/downloads (实际上更方便的是用WebPlalform安装PHP:http://www.mic ...

  10. hunnu--11548--找啊找啊找朋友

    找啊找啊找朋友 Time Limit: 1000ms, Special Time Limit:2500ms, Memory Limit:65536KB Total submit users: 14,  ...