zoukankan      html  css  js  c++  java
  • jQuery1.4与json格式兼容问题

    原文发布时间为:2010-10-10 —— 来源于本人的百度文章 [由搬家工具导入]

    原来使用jQuery1.3.2编写的代码,更换到1.4.2后,使用jQuery.ajax()加载的json文件,不能正常加载。(使用jQuery.getJSON()也一样)

    原json文件内容为:

    {
        label: 'Europe (EU27)',
        data: [[1999, 3.0], [2000, 3.9], [2001, 2.0], [2002, 1.2], [2003, 1.3], [2004, 2.5], [2005, 2.0], [2006, 3.1], [2007, 2.9], [2008, 0.9]]
    }

    解决方法一:

    改成标准的json格式,要求对字符串都使用""限定,修改后的内容为:

    {
        "label": "Europe (EU27)",
        "data": [[1999, 3.0], [2000, 3.9], [2001, 2.0], [2002, 1.2], [2003, 1.3], [2004, 2.5], [2005, 2.0], [2006, 3.1], [2007, 2.9], [2008, 0.9]]
    }

    这样就可以正常加载了。

    解决方法二:

    在jQuery-1.4.2.js中找到"parseJSON: function",可发现有如下代码:

    Js代码 复制代码
    1.         // Logic borrowed from http://json.org/json2.js   
    2. if ( /^[],:{}s]*$/.test(data.replace(/\(?:["\/bfnrt]|u[0-9a-fA-F]{4})/g, "@")   
    3.      .replace(/"[^"\ ]*"|true|false|null|-?d+(?:.d*)?(?:[eE][+-]?d+)?/g, "]")   
    4.      .replace(/(?:^|:|,)(?:s*[)+/g, "")) ) {   
    5.   
    6.   
    7.     // Try to use the native JSON parser first   
    8.     return window.JSON && window.JSON.parse ?   
    9.          window.JSON.parse( data ) :   
    10.          (new Function("return " + data))();   
    11.   
    12. } else {   
    13.      jQuery.error( "Invalid JSON: " + data );   
    14. }  
    // Logic borrowed from http://json.org/json2.js if ( /^[],:{}s]*$/.test(data.replace(/\(?:["\/bfnrt]|u[0-9a-fA-F]{4})/g, "@") .replace(/"[^"\ ]*"|true|false|null|-?d+(?:.d*)?(?:[eE][+-]?d+)?/g, "]") .replace(/(?:^|:|,)(?:s*[)+/g, "")) ) { // Try to use the native JSON parser first return window.JSON && window.JSON.parse ? window.JSON.parse( data ) : (new Function("return " + data))(); } else { jQuery.error( "Invalid JSON: " + data ); }


    在httpData: function中用到了parseJSON函数:

    Js代码 复制代码
    1. // Get the JavaScript object, if JSON is used.   
    2.             if ( type === "json" || !type && ct.indexOf("json") >= 0 ) {   
    3.                  data = jQuery.parseJSON( data );  
    // Get the JavaScript object, if JSON is used. if ( type === "json" || !type && ct.indexOf("json") >= 0 ) { data = jQuery.parseJSON( data );

    在jQuery1.3.2中,没有parseJSON这个方法,而是直接使用下面的代码。

    Js代码 复制代码
    1. // Get the JavaScript object, if JSON is used.   
    2.             if ( type == "json" )   
    3.                  data = window["eval"]("(" + data + ")");  
    // Get the JavaScript object, if JSON is used. if ( type == "json" ) data = window["eval"]("(" + data + ")");

    替换成原来1.3.2的代码就可以了。

  • 相关阅读:
    C++ VC实现对话框窗口任意分割
    C++ 关于滚动条的滚动问题
    C++ 自定义控件的移植(将在其它程序中设计的自定义控件,移植到现在的系统中)
    C++ 动态创建按钮及 按钮的消息响应
    C++ Custom Control控件 向父窗体发送对应的消息
    C++ MFC 改变控件大小和位置
    C++ 使用VS2010创建MFC ActiveX工程项目
    VC++ 自定义控件的建立及使用方法
    C++ CTreeview的checkbox使用方法
    C++ vc中怎么使用SendMessage自定义消息函数
  • 原文地址:https://www.cnblogs.com/handboy/p/7163919.html
Copyright © 2011-2022 走看看