JavaScript学习笔记——eval函数

1.  eval()只有一个参数:
  • 参数不是字符串,直接返回这个参数 -
  • 是字符串,会被当成JavaScript代码进行编译 
    1)编译失败抛出一个语法错误
    2)编译成功,则执行这段代码 

2. eval()使用了调用它的变量作用域环境

var a = 1;
f();
function f(){
    var a = 2;
    eval("a++");
    eval("var b; b =4;");
    console.log("local:" + a); //输出3
    console.log("local:" + b); //输出4
}

console.log("global:" + a); //输出1
console.log("global:" + b); //undefined

3. 直接调用eval()时,总是在调用它的上下文作用域内执行,其他间接调用则使用全局对象作为其上下文作用域,并且无法读,写,定义局部变量和函数

var geval = eval;
f();
function f(){
    var b = 1;
    geval("b++");
    geval("var c = 1;"); //全局变量c
    geval("function h(){c++;}");//全局函数h
    console.log(c);
    console.log(h);
}	
console.log(c); 
console.log(h);

4. 严格eval:在ECMAScript 5严格模式下,或eval()执行的代码段以“use strict”开始

    · eval()执行的代码段可以查询或更改局部变量,但不能在局部作用域中定义新的变量或函数

    · “eval”被列为关键字






你可能感兴趣的:(JavaScript学习笔记——eval函数)