Eval函数知识总结
2016-04-26 19:23
218 查看
说道Json,我们先来聊聊eval
一、eval是什么?(解析器)
eval是一个函数,看本质function eval() { [native code] }
二、怎样使用eval?
语法:string 必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。通过计算 string 得到的值(如果有的话)
该方法只接受原始字符串作为参数,只接受一个参数
如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。
因此请不要为 eval() 函数传递 String 对象来作为参数。而应该是对象(
如果参数中没有合法的表达式和语句,则抛出 SyntaxError 异常。
如果非法调用 eval(),则抛出 EvalError 异常。
如果传递给 eval() 的 Javascript 代码生成了一个异常,eval() 将把该异常传递给调用者。
)
第一个例子: console.log(eval("1212")); //输出结果为1212;
第二个例子: var msg="hello worle";
eval("alert(msg)");// 输出:hello world 传入参数当做实际的ECMAScript语句来执行;
相当于:alert(msg);
第三个例子:eval定义一个函数;
eval("function sayHi(){alert('hello wold')}");
sayHi(); //输出的结果是hello world (运行机制:在解析代码的时候,它们包含在一个字符串中,它们只在eval()执行的时候的创建)
三、eval(”(执行的内容)”);加上圆括号的目的是迫使eval函数在运行JavaScript代码的时候强制将括号内的表达式转化为对象,而不是作为语句(statement)来执行
例如对象字面量{},如若不加外层的括号,eval会将大括号识别为JavaScript代码块的开始和结束标记,
那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:
eval('{}'); //undefined JavaScript代码块的开始和结束标记 那么{}将会被认为是执行了一句空语句
console.log(eval('({})')); //object(){} eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行
四、eval很强大,但是同样也有弊端
(1)eval方法是在运行时对脚本进行解释执行,而普通的javascript会有一个预处理的过程。
(2)eval通常用在一些需要动态执行字符串,或将字符串转为javascript对象的场景,比如将json字符串转为javascript对象。)
(3)安全隐患
一、eval是什么?(解析器)
eval是一个函数,看本质function eval() { [native code] }
二、怎样使用eval?
语法:string 必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。通过计算 string 得到的值(如果有的话)
该方法只接受原始字符串作为参数,只接受一个参数
如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。
因此请不要为 eval() 函数传递 String 对象来作为参数。而应该是对象(
如果参数中没有合法的表达式和语句,则抛出 SyntaxError 异常。
如果非法调用 eval(),则抛出 EvalError 异常。
如果传递给 eval() 的 Javascript 代码生成了一个异常,eval() 将把该异常传递给调用者。
)
第一个例子: console.log(eval("1212")); //输出结果为1212;
第二个例子: var msg="hello worle";
eval("alert(msg)");// 输出:hello world 传入参数当做实际的ECMAScript语句来执行;
相当于:alert(msg);
第三个例子:eval定义一个函数;
eval("function sayHi(){alert('hello wold')}");
sayHi(); //输出的结果是hello world (运行机制:在解析代码的时候,它们包含在一个字符串中,它们只在eval()执行的时候的创建)
三、eval(”(执行的内容)”);加上圆括号的目的是迫使eval函数在运行JavaScript代码的时候强制将括号内的表达式转化为对象,而不是作为语句(statement)来执行
例如对象字面量{},如若不加外层的括号,eval会将大括号识别为JavaScript代码块的开始和结束标记,
那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:
eval('{}'); //undefined JavaScript代码块的开始和结束标记 那么{}将会被认为是执行了一句空语句
console.log(eval('({})')); //object(){} eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行
四、eval很强大,但是同样也有弊端
(1)eval方法是在运行时对脚本进行解释执行,而普通的javascript会有一个预处理的过程。
(2)eval通常用在一些需要动态执行字符串,或将字符串转为javascript对象的场景,比如将json字符串转为javascript对象。)
(3)安全隐患
虽然 eval() 的功能非常强大,但在实际使用中用到它的情况并不多 《结束》
相关文章推荐
- GMM:高斯混合模型的数学推导笔记(上)
- Spring的事务管理总结
- 【Arduino官方教程第一辑】示例程序 2-5 按键状态改变的探测
- USC Problem A 钓鱼 贪心
- mysql存储过程
- 作业六。合作编程
- CSS3圆角border-radius属性详解
- boost::shared_ptr:传值还是传引用?
- iOS单元测试GHUnit + OCMock(使用cocoapods版)
- Java transient关键字
- 学习笔记之深入浅出MFC 第8章 C++重要性质----基类与派生类:谈继承(Inheritance)
- vnc 安装配置
- 个人工作总结7
- Python数据分析学习笔记一
- 似物性检测——linux下运行objectness-v2.2并分析源码(pami2012论文)
- 在windows中通过jconsole监视远程linux服务器中JVM的运行状态(比如:监视Tomcat的各项运行指标)
- 嘻嘻嘻,我每天的感受
- 个人常用配置文件解析
- 是时候学些养活自己的技术了
- ERROR 1045 (28000): Access denied for user...错误的解决