`

javascript eval和JSON之间的联系

阅读更多
本文着重解释eval函数和JSON数据格式之间的联系以及一些细节上的问题。

如果您想详细了解eval和JSON请参考以下链接:
eval  :https://developer.mozilla.org/En/Core_JavaScript_1.5_Reference/Global_Functions/Eval

JSON:http://www.json.org/

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 + ')');


文章转自 http://www.jb51.net/article/21688.htm
分享到:
评论

相关推荐

    javascript eval和JSON

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。JSON基于JavaScript的一个子集,使用键值对的形式来存储数据,其结构可以是对象或者数组。 JSON的...

    巧用eval解析json对象

    本篇将聚焦于如何巧妙地使用`eval`函数来解析JSON对象,虽然在实际开发中,由于安全考虑我们通常会避免使用`eval`,但理解其工作原理对于学习JavaScript和JSON解析至关重要。 首先,JSON对象本质上是符合JSON语法的...

    javascript中eval解析JSON字符串.docx

    ### JavaScript中eval解析JSON字符串详解 #### 一、前言 在JavaScript开发中,解析JSON字符串是一项常见的任务。其中一种方法是使用`eval()`函数。虽然这种方法并不推荐,但了解其工作原理及其潜在风险仍然非常...

    javascript中eval解析JSON字符串

    我们都知道,高级浏览器可以用 JSON.parse() API 将一个 JSON 字符串解析成 JSON 数据,稍微欠妥点的做法,我们可以用 eval() 函数。 var str = '{"name": "hanzichi", "age": 10}'; var obj = eval('...

    json------javascript eval()以及Example

    总的来说,理解JSON和`eval()`的关系,以及如何在JavaScript和Java中安全地处理JSON数据,是现代Web开发中的基本技能。同时,熟悉像Struts2这样的框架如何处理JSON响应,有助于构建更高效、更安全的Web应用。

    JavaScript 中处理JSON

    在现代 Web 开发中,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。它基于JavaScript的一个子集,但作为一种独立的数据格式,它不仅仅用于...

    js下用eval生成JSON对象.docx

    然而,尽管`eval()`和`new Function()`在某些情况下方便快捷,但它们并不是解析JSON的最佳选择,因为它们可能会执行任意的JavaScript代码,从而引入安全漏洞。现代浏览器提供了`JSON.parse()`方法,这是一个专为解析...

    在Javascript中Eval函数的使用?

    由于JSON字符串不能直接在JavaScript环境中操作,所以通常会使用`eval()`来转换它: ```javascript let jsonString = '{"name": "John", "age": 30}'; let jsonObject = eval('(' + jsonString + ')'); console.log...

    js使用eval解析json(js中使用json)

    由于JSON规范要求数据用双引号包围,而JavaScript中对象的键默认需要用单引号或双引号,因此在使用`eval()`时,通常会在字符串前面和后面加上额外的括号,以确保解析为JavaScript对象而不是语句。 然而,这种方法...

    JSON在Javascript中的使用(eval和JSON.parse的区别)详细解析

    有两类主要的方法用于将JSON字符串转化为JavaScript对象:`eval()`和`JSON.parse()`。 `eval()`函数在JavaScript中通常用来执行一段JavaScript代码。当用于解析JSON时,`eval`会将JSON字符串视为JavaScript代码执行...

    纯javascript实现json与对象的互相转换项目

    这个项目专注于使用纯JavaScript来实现JSON与JavaScript对象之间的转换,这对于数据传输、存储以及在前端和后端之间进行通信至关重要。 首先,我们需要理解JSON的基本结构。JSON是一种文本格式,主要由键值对组成,...

    JavaScript的eval JSON object问题

    4. JSON与eval函数的结合:在AJAX开发中,一种常见的做法是在客户端回调函数中使用eval函数将服务器返回的JSON格式字符串转换成JavaScript对象,以便于后续的数据操作和使用。代码示例如下:`var jsonData = eval...

    javascript 自定义eval函数实现

    在本讨论中,我们将深入探讨如何自定义`eval()`函数以提高代码的安全性和效率,同时也会涉及到JavaScript的动态执行特性以及其在实际开发中的应用。 首先,`eval()`的默认行为是将其接收到的字符串当作JavaScript...

    js使用eval解析json实例与注意事项分享

    JSON与JavaScript对象之间的关系非常紧密,因为JSON的结构与JavaScript的Object字面量几乎是一致的,这就意味着在JavaScript中处理JSON数据时,不需要任何特殊的API或工具包。 当JSON数据以字符串的形式存在时,...

    JS中Eval解析JSON字符串的一个小问题

    在处理JSON字符串时,通常有两种方法将其转换为JavaScript对象:`JSON.parse()`和`eval()`函数。`JSON.parse()`是现代浏览器内置的方法,专门用于解析JSON字符串,它是安全且推荐的解析方式。然而,在一些老版本或者...

Global site tag (gtag.js) - Google Analytics