本文实例讲述了jQuery处理json数据返回数组和输出的方法。分享给大家供大家参考。具体实现方法如下:

复制代码 代码如下:/*print the json object
 *
 *$("selector").print_r_json(json,opts) : return formatted string (and print)
 *sprint_r_json : just return the string;
 *print_r_json : return the formatted string and print json data
 *contribute 明河
 *
 *auth iorichina
 *
 *example:
 *3 ways to use it
 *<script language="javascript">
 *$("selector").print_r_json({"a":"aa","d":{"ef":{"a":"d","d":["a","b"]},"ed":"dd"},"g":"g"},{if_print:true,return_array:true});
 *document.write($.sprint_r_json({"a":"aa","d":{"ef":{"a":"d","d":["a","b"]},"ed":"dd"},"g":"g"}));
 *$.print_r_json({"a":"aa","d":{"ef":{"a":"d","d":["a","b"]},"ed":"dd"},"g":"g"});
 *</script>
 *
*/
$.fn.print_r_json = function(json,options){
    if(typeof(json)!="object") return false;
    var opts = $.extend({},$.fn.print_r_json.defaults,options);
    var data = '';
    if(opts.if_print)
    {
        data = $.sprint_r_json(json)
        $(this).html('<div style="font-weight:bold">'+(opts.return_array"object")
        {
            var text='<div style="font-weight:bold;">{</div><div style="margin-left:25px;">';
          document.write('<div style="font-weight:bold;">{</div><div style="margin-left:25px;">');
          for(var p in json)
          {
            if(typeof(json[p])=="object")
            {
              document.write('<div>["'+p+'"] => ');
                text+='<div>["'+p+'"] => '+$.print_r_json(json[p])+'</div>';
              document.write('</div>');
            }
            else
            {
                text+='<div>['+((/^\d+$/).test(p)"'+p+'"'))+'] => "'+json[p]+'"</div>';
              document.write('<div>['+p+'] => '+json[p]+'</div>');
            }
          } 
          text+='</div><div style="font-weight:bold;">}</div>';
          document.write('</div><div style="font-weight:bold;">}</div>');
          return (text);
        }
        else
        {
            document.write(json);
            return (json);
        }
    },
    sprint_r_json : function(json)
    {
        if(typeof(json)=="object")
        {
          var text = '<div style="font-weight:bold;">{</div><div style="margin-left:25px;">';
          for(var p in json)
          {
            if(typeof(json[p])=="object")
            {
              text += '<div>["'+p+'"] => '+$.sprint_r_json(json[p])+'</div>';
            }
            else
            {
              text += '<div>['+((/^\d+$/).test(p)"'+p+'"'))+'] => "'+json[p]+'"</div>';
            }
          } 
          text += '</div><div style="font-weight:bold;">}</div>';
          return (text);
        }
        else
        {
            return (json);
        }
    },
    json_to_array : function(json)
    {
        if(typeof(json)=="object")
        {
          var text = new Array();
          for(var p in json)
          {
            if(typeof(json[p])=="object")
            {
              text[p] = $.json_to_array(json[p]);
            }
            else
            {
              text[p] = json[p];
            }
          }
          return (text);
        }
        else
        {
            return (json);
        }
    }
});

希望本文所述对大家的jQuery程序设计有所帮助。

标签:
jQuery,json数据,返回数组,输出,方法

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。