zoukankan      html  css  js  c++  java
  • [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    javascript eval函数解析json数据时为什么 加上圆括号?
    为什么要 eval这里要添加 “("("+data+")");//”呢?
     
    原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

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

     ****************************************************************************************************************************************************************************************

     《javascript 高级程序设计 第二版》page73,第五章,引用类型

    5.1object类型

    到目前为止,我们看到的大多数引用类型值都是object类型的实例;而且,object也是ECMAScript中使用最多的一个类型。虽然object的实例不具备多少功能,但对于在应用程序中存储和传输数据而言,它们确实是非常理想的选择。

      创建object实例的方式有两种。第一种是使用new操作符后跟object构造函数,如下所示:

    var person=new object();

    person.name="Nicholas";

    person.age=29;

      另一种方式是使用对象字面量表示法。对象字面量是对象定义的一种简写形式,目的在于简化创建包含大量属性的对象的过程。下面这个例子就使用了对象字面量语法定义了与前面那个例子中相同的person对象:

    var person={

             name:"Nicholas",

             age:29

    };

    在这个例子中,左边的花括号({)表示对象字面量的开始,因为它出现在了赋值操作符的后面(在其他环境中,左花括号表示的是语句块的开始)。然后,我们定义了name属性,之后是一个冒号,再后面是这个属性的值。在对象字面量中,使用逗号来分隔不同的属性,因此“Nicholas”后面是一个逗号。但是,在age属性的值29的后面不能添加逗号,因为age是这个对象的最后一个属性。在最后一个属性后面添加逗号,会在IE及Opera中导致错误。

       在使用对象字面量语法时,属性名也可以使用字符串,如下面这个例子所示:

      var person={

       "name":"Nicholas",

      "age":29

    };

      以上代码也会得到与前面例子相同的结果;创建一个带有name和age属性的新对象。

      另外,使用对象字面量语法时,如果留空其花括号,则可以定义只包含默认属性和方法的对象,

    ---下面这个是天蓝自己找的---

    http://www.zhihu.com/question/19884767

    在 JavaScript 中,怎样把一个对象转化成 JSON 字符串?

    用或者不用 jQuery。
    是问如何把js对象方便的转为json字符串哦~~

    (而不是把json字符串变成js对象)
  • 相关阅读:
    spring boot整合quartz存储到数据库
    java多线程定时器和java判断一个时间是否在时间区间内和用正则表达式获取String字符串之间的数据
    maven项目通过java加载mqtt存储到mysql数据库,实现发布和接收
    java往MongDB导入大量数据
    SSH面试题收藏
    Spring面试题
    Hibernate面试题收藏
    Spring MVC
    浅谈 Struts2 面试题收藏
    JSP 新闻发布会
  • 原文地址:https://www.cnblogs.com/seapub/p/3326075.html
Copyright © 2011-2022 走看看