eval函数的工作原理

eval函数会评估一个给定的含有JavaScript代码的字符串,并且试图去执行包含在字符串里的表达式或者一系列的合法的JavaScript语句。eval函数将把最后一个表达式或者语句所包含的值或引用作为返回值。

举例说明

  • eval评估JavaScript表达式
var bar = 'bar';
var foobar = eval('"foo" + bar');
alert(foobar);
  • eval评估JavaScript语句
var bar = 'bar';
// if variable bar equals 'bar', foobar is the result of
// last executing statement: bar="foo-bar";
var foobar = eval('if(bar == "bar") {bar="foo-bar";} else {bar = "bar-foo";}');
alert(foobar);// change the valuebar = 'foo';
// now our the last executed statement is: bar = "bar-foo";
// therefore the value of variable foobar has been changed
// into 'bar-foo'
foobar = eval('if(bar == "bar") {bar="foo-bar";} else {bar = "bar-foo";}');
alert(foobar);

JSON的格式

JSON的格式是由大括号和由冒号(:)构成的名值对所组成的。注意JSON格式与对象字面量 (object literals) 的区别:JSON的名字部分严格用引号+名字来表示。

举例说明

  • 对象的字面量
var objectLiteral = {
name: "Objector.L",
age: "24",
special: "JavaScript",
sayName: function() {
return this.name;
}
};
  • JSON对象
var jsonFormat = {
"summary": "Blogs",
"blogrolls": [
{
"title": "Explore JavaScript",
"link": "http://example.com/"
},
{
"title": "Explore JavaScript",
"link": "http://example.com/"
}
]
};

eval和JSON

由于Ajax的兴起,JSON这种轻量级的数据格式作为客户端与服务器之间的传输格式逐渐地流行起来,进而出现的问题是如何将服务器端构建好的JSON数据转化为可用的JavaScript对象。利用eval函数无疑是一种简单而直接的方法。在转化的时候需要将JSON字符串的外面包装一层圆括号:

var jsonObject = eval("(" + jsonFormat + ")");

为什么要加括号?

加上圆括号的目的是迫使eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:

alert(eval("{}"); // return undefined
alert(eval("({})");// return object[Object]

JSON格式的名字部分为什么要加引号?

因为eval函数会将{foo:”bar”}解释成合法的JavaScript语句,而非表达式。但是人们往往想要的是让eval将这段代码解释成一个对象。所以JSON格式会强制你去在名字的外侧加上引号再结合圆括号,这样eval就不会错误的将JSON解释成代码块。

举例说明

  • eval错误解析语义
alert(eval('{foo:"bar"}'));   // return "bar", incorrect
  • eval正确解析JSON
alert(eval('({"foo": "bar"})')); // return JSON object, correct

结论

理解eval的工作原理和json的严格的限定格式,合理结合eval和json应用于JavaScript的数据传递和对象转换。

following this format:

eval('{' + jsonString + ')');

最新文章

  1. 【 D3.js 进阶系列 — 6.1 】 缩放的应用(Zoom)
  2. 使用Eclipse为Android定义style
  3. 关于update set from where
  4. [Android Pro] Java进阶学习:jar打包详解
  5. 实现AJAX的基本步骤 。。转
  6. Win 環境構建調試用TreeWalker
  7. php引用详解
  8. HDFS Federation与HDFS High Availability详解
  9. 轻量级的中文分词工具包 - IK Analyzer
  10. SqlServer经典函数之数字去零
  11. Java "==和equals区别"
  12. 设置批量商品优惠、如何修改ZenCart产品显示图片的大小
  13. flex控件总结
  14. oracle分组-神奇的cube和rollup
  15. ARTS打卡计划第二周-Algorithm
  16. QQ Protect 的删除
  17. .NET(C#) win Form窗体的常用属性以及事件
  18. window.history的跳转实质-HTML5 history API 解析
  19. slave have equal MySQL Server UUIDs原因及解决
  20. 记一次优化ansible inventory的小例子

热门文章

  1. 如何在CentOS 7上修改主机名
  2. 关于char与varchar,varchar2的区别
  3. QT5-控件-QFontComboBox-字体选择下拉列表,使用一个标签查看效果
  4. QC 2.0为啥可以快充
  5. 3.4 C与汇编程序的相互调用
  6. 关于 typings install 的使用
  7. CentOS下安装vsftpd架设ftp服务器
  8. 统计建模与R软件习题二答案
  9. Apple Pay 应用 demo --备用哦
  10. ural 1613 For Fans of Statistics