<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    emu in blogjava

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      171 隨筆 :: 103 文章 :: 1052 評論 :: 2 Trackbacks
    這個是基本的轉換例子
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> json-to-string </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="emu">
    <META NAME="Keywords" CONTENT="json convert">
    <META NAME="Description" CONTENT="convert a javascript object into a JSON string">
    </HEAD>

    <BODY>
    <SCRIPT LANGUAGE="JavaScript">
    <!--
    var data={host:{url:"ad.market.com",page:[{name:"all",area:[{name:"rightbanner",tname:"all",tclass:"none",type:"jpg",ad:[{url:"abc.gif",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]},{name:"leftbanner",tname:"all",tclass:"none",type:"jpg",ad:[{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]}]},{name:"index.htm",area:[{name:"rightbanner",tname:"index.htm",tclass:"none",type:"swf",ad:[{url:"abcdef.swf",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]},{name:"leftbanner",tname:"index.htm",tclass:"none",type:"text",ad:[{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""},{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""},{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]}]}]}}

    function obj2str(o){
        
    var r = [];
        
    if(typeof o =="string"return "\""+o.replace(/([\'\"\\])/g,"\\$1").replace(/(\n)/g,"\\n").replace(/(\r)/g,"\\r").replace(/(\t)/g,"\\t")+"\"";
        if(typeof o ==
    "undefined") return "undefined";
        if(typeof o == 
    "object"){
            if(o===null) return 
    "null";
            else if(!o.sort){
                for(var i in o)
                    r.push(i+
    ":"+obj2str(o[i]))
                r=
    "{"+r.join()+"}"
            }else{
                for(var i =0;i<o.length;i++)
                    r.push(obj2str(o[i]))
                r=
    "["+r.join()+"]"
            }
            return r;
        }
        return o.toString();
    }

    alert(obj2str(data))
    //-->
    </SCRIPT>
    </BODY>
    </HTML>


    要是想重載系統的native code函數(比如toString,join),就要根據不同的瀏覽器上不同的內部函數的具體表現做特殊對待了。比如重載toString函數在IE里面是默認遍歷不到的,而firefox偏偏就可以。下面的例子在IE和firefox下面測試通過:

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
    <HTML>
    <HEAD>
    <TITLE> json-to-string </TITLE>
    <META NAME="Generator" CONTENT="EditPlus">
    <META NAME="Author" CONTENT="emu">
    <META NAME="Keywords" CONTENT="json convert">
    <META NAME="Description" CONTENT="convert a javascript object into a JSON string">
    </HEAD>

    <BODY>
    <SCRIPT LANGUAGE="JavaScript">
    <!--
    var data={host:{url:"ad.market.com",page:[{name:"all",area:[{name:"rightbanner",tname:"all",tclass:"none",type:"jpg",ad:[{url:"abc.gif",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]},{name:"leftbanner",tname:"all",tclass:"none",type:"jpg",ad:[{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]}]},{name:"index.htm",area:[{name:"rightbanner",tname:"index.htm",tclass:"none",type:"swf",ad:[{url:"abcdef.swf",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]},{name:"leftbanner",tname:"index.htm",tclass:"none",type:"text",ad:[{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""},{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""},{url:"",width:"",height:"",menu:"red",tran:"",href:"http://music.qq.com",alt:"aaaaaaaaa",target:"_blank",top:"",bottom:"",left:"",right:""}]}]}]},toString:function(){return obj2str(this)}}

    function obj2str(o){
        
    var r = [];
        
    if(typeof o =="string"return "\""+o.replace(/([\'\"\\])/g,"\\$1").replace(/(\n)/g,"\\n").replace(/(\r)/g,"\\r").replace(/(\t)/g,"\\t")+"\"";
        if(typeof o == 
    "object"){
            if(!o.sort){
                for(var i in o)
                    r.push(i+
    ":"+obj2str(o[i]));
                if(!!document.all && !/^\n?function\s*toString\(\)\s*\{\n?\s*\[native code\]\n?\s*\}\n?\s*$/.test(o.toString)){
                    r.push(
    "toString:"+o.toString.toString());
                }
                r=
    "{"+r.join()+"}"
            }else{
                for(var i =0;i<o.length;i++)
                    r.push(obj2str(o[i]))
                r=
    "["+r.join()+"]"
            }
            return r;
        }
        return o.toString();
    }
    alert(obj2str(data))
    //-->
    </SCRIPT>
    </BODY>
    </HTML>
    posted on 2007-01-04 17:30 emu 閱讀(4379) 評論(6)  編輯  收藏

    評論

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子 2007-08-15 20:29 emu
    補充一個object克隆的簡單方法,不支持function:
    function objClone(o){
    if(typeof o == "object"){
    var r=(o.sort)?[]:{}
    for(var i in o)
    r[i]=objClone(o[i]);
    return r;
    }
    return o;
    }
      回復  更多評論
      

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子 2009-04-11 15:52 谷歌
    經過測試,不支持谷歌  回復  更多評論
      

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子 2009-04-11 16:01 谷歌
    汗,我能把上面的刪除嘛,你給我刪了個,經過仔細測試,支持谷歌  回復  更多評論
      

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子 2010-07-15 11:00 lingcarlos
    遞歸用的很熟啊  回復  更多評論
      

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子[未登錄] 2011-03-15 11:12 benx203
    可不可以修改下,轉換后保持對象的key是引號引起來的啊,有的地方要求格式比較嚴格  回復  更多評論
      

    # re: 應twinsen要求寫了個轉換js對象為json字符串的例子[未登錄] 2011-03-15 11:15 benx203
    我把r.push(i+":"+obj2str(o[i]))修改成r.push("\""+i+"\":"+obj2str(o[i]))可以用了,謝謝!  回復  更多評論
      


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 日韩精品免费一区二区三区| 日本亚洲视频在线| fc2成年免费共享视频18| 国产亚洲免费的视频看| AA免费观看的1000部电影| 国产亚洲精品美女| 久久亚洲精品国产精品黑人| 性感美女视频免费网站午夜| 国产日韩久久免费影院| 亚洲AV无码国产精品色| 国产a v无码专区亚洲av| 999久久久免费精品国产| 国产免费一区二区三区免费视频| 亚洲另类视频在线观看| 青青草原亚洲视频| 黄瓜视频高清在线看免费下载| AAAAA级少妇高潮大片免费看| 亚洲一区在线免费观看| 国产精品亚洲一区二区三区在线| 成人免费视频软件网站| 日韩在线不卡免费视频一区| 边摸边脱吃奶边高潮视频免费| 久久久久久久亚洲Av无码| 亚洲精品无码久久毛片| 黑人粗长大战亚洲女2021国产精品成人免费视频| h片在线观看免费| jzzijzzij在线观看亚洲熟妇| 亚洲第一成年人网站| 亚洲精品一品区二品区三品区| 日韩午夜免费视频| 麻豆最新国产剧情AV原创免费| 中国videos性高清免费| 免费看又黄又爽又猛的视频软件| 亚洲中文字幕无码一去台湾 | 美女视频黄的免费视频网页 | 亚洲欧洲国产精品你懂的| 亚洲AV中文无码乱人伦在线视色 | 亚洲AV乱码一区二区三区林ゆな| 亚洲av午夜精品一区二区三区| 在线观看人成视频免费| 日本在线高清免费爱做网站|