欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JSON掃盲帖 JSON.as類教程

 更新時間:2009年02月16日 13:02:05   作者:  
如果json字符串是從html用FlashVars來傳遞參數(shù)時那么字符串中的第一個雙引號(包括雙引號)以后的內(nèi)容就不會得到傳送.

補充內(nèi)容:
如果json字符串是從html用FlashVars來傳遞參數(shù)時那么字符串中的第一個雙引號(包括雙引號)以后的內(nèi)容就不會得到傳送. 而adobe的官方j(luò)son.as類包里解析josn對象中是少不了雙引號的. 所以搞了半天只后用個字符串替換函數(shù)啦!
方法看另一篇文章:
html傳帶雙引號的參數(shù)給flash解決方案
--------------------------------------------------------------------------------------
先看下面的轉(zhuǎn)載內(nèi)容吧! 前面這些是根據(jù)自己的需求的補充內(nèi)容:
--------------------------------------------------------------------------------------
昨天發(fā)了json的AS3解析類,從大家的跟帖上來看,好多人還是不知道這個東西的,特建一個掃盲貼。
其實在AS中使用json其實并不是一個必須或是很好的選擇,因為AS對xml的解析已經(jīng)很不錯了,但是為什么可以考慮使用json呢,有以下幾點:
json是介于單純的文本方式(如:firstName=Brett&lastName=McLaughlin&email=brett@newInstance.com)和xml(<request><firstName>Brett</firstName><lastName>McLaughlin</lastName><email>brett@newInstance.com</email></request>)中間的一種格式,他具有文本和xml的中性優(yōu)勢:數(shù)據(jù)量小和清晰的數(shù)據(jù)格式。
json是JavaScript Object Notation的簡寫,那么意思就是說他是來自于javascript的東西。因為現(xiàn)在ajax的流行,大部分網(wǎng)站會采用ajax的模式和構(gòu)架,那么json會是一個數(shù)據(jù)傳輸?shù)氖走x(文本方式太簡單,要是大數(shù)據(jù)量的時候無法理解,xml的方式數(shù)據(jù)量大,在解析的時候會增加服務(wù)器負擔(dān)),那么要是一個網(wǎng)站從ajax構(gòu)架的基礎(chǔ)上出一個flex/flash版的界面的時候使用json會最少地減少服務(wù)器端的程序改動。
服務(wù)器端現(xiàn)在有成熟的JSON解析代碼(因為JSON運用太廣泛了),那么在開發(fā)的時候也不用擔(dān)心服務(wù)器端的解析。
ps:我怎么只能想到上面三點啊,會不會理由太少了?
JSON 是什么?
簡單 JSON 示例
按照最簡單的形式,可以用下面這樣的 JSON 表示名稱/值對:

復(fù)制代碼 代碼如下:

{ "firstName": "Brett" }

復(fù)制代碼這個示例非?;?,而且實際上比等效的純文本名稱/值對占用更多的空間:
復(fù)制代碼 代碼如下:

firstName=Brett

復(fù)制代碼但是,當(dāng)將多個名稱/值對串在一起時,JSON 就會體現(xiàn)出它的價值了。首先,可以創(chuàng)建包含多個名稱/值對的記錄,比如:
復(fù)制代碼 代碼如下:

{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" }

復(fù)制代碼從語法方面來看,這與名稱/值對相比并沒有很大的優(yōu)勢,但是在這種情況下 JSON 更容易使用,而且可讀性更好。例如,它明確地表示以上三個值都是同一記錄的一部分;花括號使這些值有了某種聯(lián)系。
值的數(shù)組
當(dāng)需要表示一組值時,JSON 不但能夠提高可讀性,而且可以減少復(fù)雜性。例如,假設(shè)您希望表示一個人名列表。在 XML 中,需要許多開始標記和結(jié)束標記;如果使用典型的名稱/值對(就像在本系列前面文章中看到的那種名稱/值對),那么必須建立一種專有的數(shù)據(jù)格式,或者將鍵名稱修改為 person1-firstName 這樣的形式。
如果使用 JSON,就只需將多個帶花括號的記錄分組在一起:
復(fù)制代碼 代碼如下:

{ "people": [
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },
{ "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }
]}

復(fù)制代碼這不難理解。在這個示例中,只有一個名為 people 的變量,值是包含三個條目的數(shù)組,每個條目是一個人的記錄,其中包含名、姓和電子郵件地址。上面的示例演示如何用括號將記錄組合成一個值。當(dāng)然,可以使用相同的語法表示多個值(每個值包含多個記錄): { "programmers": [
復(fù)制代碼 代碼如下:

{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },
{ "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }
],
"authors": [
{ "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },
{ "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },
{ "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }
],
"musicians": [
{ "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },
{ "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }
]
}

復(fù)制代碼這里最值得注意的是,能夠表示多個值,每個值進而包含多個值。但是還應(yīng)該注意,在不同的主條目(programmers、authors 和 musicians)之間,記錄中實際的名稱/值對可以不一樣。JSON 是完全動態(tài)的,允許在 JSON 結(jié)構(gòu)的中間改變表示數(shù)據(jù)的方式。
在處理 JSON 格式的數(shù)據(jù)時,沒有需要遵守的預(yù)定義的約束。所以,在同樣的數(shù)據(jù)結(jié)構(gòu)中,可以改變表示數(shù)據(jù)的方式,甚至可以以不同方式表示同一事物。
ps:以上例子都是來自http://www.ibm.com/developerworks/cn/web/wa-ajaxintro10/,掌握 Ajax,自己懶,看人家有就順便用了

當(dāng)當(dāng)當(dāng),我又回來了,上周忙這上班沒顧上寫用法,下面就介紹一下adobe的json類的用法。
上次發(fā)表的json類有問題(http://bbs.actionscript3.cn/thread-1625-1-1.html),因為我也是從別人處下載的,誰知道是一個半成品。望大家別生氣啊,建議管理員給刪除了!
這次是adobe的官方的類,我修改了一下包,這次就可以用了。
下面是教程,比較簡單:
1、服務(wù)器端來的json
怎么樣獲得服務(wù)器端的json我就不說了吧(就是通訊),那么得到的應(yīng)該是一個字符串,存入變量serverJSON,使用方式如下:

復(fù)制代碼 代碼如下:

import json.*;
var json:Object = new Object();
json = JSON.decode(serverJSON);


json就是一個對象了,簡單吧。
舉一個例子:
上面的JSON的一段代碼:
復(fù)制代碼 代碼如下:

{ "programmers": [
{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },
{ "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },
{ "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }
],
"authors": [
{ "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },
{ "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },
{ "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }
],
"musicians": [
{ "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },
{ "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }
]
}

存入變量:serverJSON
代碼:

復(fù)制代碼 代碼如下:

var serverJSON:String = '{ "programmers": [{ "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },{ "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" }, { "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@macfaq.com" }],"authors": [{ "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },{ "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },{ "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }],"musicians": [{ "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },{ "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }]}'
var s:Object = JSON.decode(serverJSON);
//開始使用
trace(s.programmers[0].firstName);//輸出:Brett


不是吧這么簡單。其實轉(zhuǎn)變后就成為一個對象了,可以通過點語法來訪問這些值了。XML靠邊去。
2、本地對象做成JSON
你要是能自己拼出JSON字符串也可以,不過我們是在面向?qū)ο蟮氖澜绨?,那么我們都是對象啊,到時候?qū)ο笾苯泳涂梢詠碛昧恕?
舉一個例子:

復(fù)制代碼 代碼如下:

import json.*;
var myObject:Object = new Object();
myObject.ab = "adfsdf";
myObject.cd = Math.random();
trace(JSON.encode( myObject ));//輸出:{"ab":"adfsdf","cd":0.0599129400216043}

這樣就可以給服務(wù)器了。
總結(jié):就兩個方法,JSON.decode(String),JSON.encode(Object),有這么簡單的方式實現(xiàn)傳輸量小,而且簡單的數(shù)據(jù)格式,我們?yōu)槭裁催€不用呢?
其實XML自然也有他自己的強勢,當(dāng)一個結(jié)構(gòu)復(fù)雜的數(shù)據(jù)結(jié)構(gòu)出現(xiàn)的時候,這個時候JSON就很難搞定了,XML就是首選了。

相關(guān)文章

  • json2.js 入門教程之使用方法與實例分析

    json2.js 入門教程之使用方法與實例分析

    這篇文章主要介紹了json2.js 入門教程之使用方法與實例分析,需要的朋友可以參考下
    2017-09-09
  • JSON 數(shù)據(jù)格式介紹

    JSON 數(shù)據(jù)格式介紹

    這篇文章講的比較深入,所以不用我畫蛇添足了,只是下面這段代碼很好的演示了JSON如何處理字符串?dāng)?shù)據(jù)
    2012-01-01
  • json數(shù)據(jù)傳到前臺并解析展示成列表的方法

    json數(shù)據(jù)傳到前臺并解析展示成列表的方法

    今天小編就為大家分享一篇json數(shù)據(jù)傳到前臺并解析展示成列表的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • json跟xml的對比分析

    json跟xml的對比分析

    JSON和XML的可讀性可謂不相上下,一邊是建議的語法,一邊是規(guī)范的標簽形式,很難分出勝負。
    2008-06-06
  • 如何實現(xiàn)json數(shù)據(jù)可視化詳解

    如何實現(xiàn)json數(shù)據(jù)可視化詳解

    最近在工作中開發(fā)一個內(nèi)部功能時碰到的一個需求,要把json數(shù)據(jù)在頁面上展示出來,平時瀏覽器會安裝jsonView這樣的擴展來看json數(shù)據(jù),但是程序要用到的話該怎么辦呢?今天在網(wǎng)上搜索的時候,發(fā)現(xiàn)了這個小技巧,分享給大家,有需要的朋友們可以參考借鑒,下面來一起看看吧
    2016-11-11
  • json的定義、標準格式及json字符串檢驗

    json的定義、標準格式及json字符串檢驗

    今天分享和總結(jié)一些json的基本定義、格式、字符串的格式,以及在做測試的時候使用json時做一些簡單的校驗
    2014-05-05
  • JSON 入門教程基礎(chǔ)篇 json入門學(xué)習(xí)筆記

    JSON 入門教程基礎(chǔ)篇 json入門學(xué)習(xí)筆記

    剛開始接觸json的時候感覺有點奇怪的命名,后來使用才發(fā)現(xiàn)這么簡單而且用好用,擴展性很強,這里就為大家整理一下
    2020-09-09
  • 父子窗體間傳遞JSON格式的數(shù)據(jù)的代碼

    父子窗體間傳遞JSON格式的數(shù)據(jù)的代碼

    在開發(fā)的項目中,遇到這樣一個例子:當(dāng)用戶選擇某一個用戶名時,彈出當(dāng)前用戶的評分卷,該評分卷列出了所有一級評分項,讓用戶進行評分操作。
    2010-12-12
  • JSON 必知必會 觀后記

    JSON 必知必會 觀后記

    這篇文章主要介紹了個人看了JSON 必知必會一書的讀后感,此書從各個方面介紹了json的一些注意事項與優(yōu)缺點。
    2016-10-10
  • JSON.parse 數(shù)據(jù)不完整的解決方法

    JSON.parse 數(shù)據(jù)不完整的解決方法

    本文主要介紹了JSON.parse 數(shù)據(jù)不完整的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07

最新評論