JavaScript学习笔记——eval函数
2016-01-19 00:00
573 查看
摘要: eval可以动态判断源代码中的字符串,功能强大到几乎没有必要在实际中应用
1.
eval()只有一个参数:
参数不是字符串,直接返回这个参数 -
是字符串,会被当成JavaScript代码进行编译
1)编译失败抛出一个语法错误
2)编译成功,则执行这段代码
2. eval()使用了调用它的变量作用域环境
3. 直接调用eval()时,总是在调用它的上下文作用域内执行,其他间接调用则使用全局对象作为其上下文作用域,并且无法读,写,定义局部变量和函数
· eval()执行的代码段可以查询或更改局部变量,但不能在局部作用域中定义新的变量或函数
· “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”被列为关键字
相关文章推荐
- json
- JavaScript 闭包 分析
- js 设计模式
- javascript检测浏览器版本信息
- json序列化时,不序列化值为null和""的字段
- 说说JSON和JSONP
- 《JavaScript语言精粹》读书笔记
- js学习笔记:操作iframe
- 关于Litjson的简单使用
- JavaScript基础—插曲
- jstl标签用法技巧
- JS弹出窗口代码大全(详细整理)
- Jsp状态管理(Cookie和Session的对比)
- Jekyll search组件
- JavaScript-浏览器对象
- json web token登录
- 如何解析JSON数组,并只拿到其中的一个属性集
- R和JSON的傻瓜式编程
- 【BZOJ1823】 [JSOI2010]满汉全席
- json formatter