您的位置:首页 > Web前端 > JavaScript

JavaScript学习笔记——eval函数

2016-01-19 00:00 573 查看
摘要: 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”被列为关键字

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: