JSON(及其在ajax前後端交互的過程)小識

来源:http://www.cnblogs.com/qjqcs/archive/2016/09/07/5850282.html
-Advertisement-
Play Games

一. json介紹 json是一種輕量級的數據交換格式,規則很簡單: 1. 併列的數據之間用逗號(,)分隔; 2. 映射用冒號(:)表示; 3. 併列數據的集合(數組)用方括弧([])表示; 4. 映射的集合(對象)用大括弧({})表示。 對上述規則解析,可以發現: 數組是用([])創建的,對象是用 ...


一. json介紹


json是一種輕量級的數據交換格式,規則很簡單:

  1. 併列的數據之間用逗號(,)分隔;
  2. 映射用冒號(:)表示;
  3. 併列數據的集合(數組)用方括弧([])表示;
  4. 映射的集合(對象)用大括弧({})表示。
    對上述規則解析,可以發現:
  • 數組是用([])創建的,對象是用({})創建的;
  • 數組和對象裡面的元素都是用(,)隔開:{name:"李華",age:"18",home:"shanghai"}&&[]
  • 對象和數組可以相互嵌套,一個數組中的一個元素可以是對象或數組,一個對象中的一個屬性的值也可以是一個對象或數組;
  • 對象內部,屬性的名稱和值用(:)隔開,不能單獨存在屬性名或者值。
    ```
    對象:
    {name:"lihua",age:"18",home:"shanghai"}

    數組:
    [{"name":"李華","age":"18","home":"上海"},{"name":"小明","age":"21","home":"北京"},{"name":"阿飛","age":"25","home":"深圳"}]
    ```
    數組和對象都是數據的集合,除了使用符號不同,最重要的差異是:數組內的數據是有序的,而對象內的數據是無序的。

二.json在前後端數據交互中的應用

1. 服務端數據處理

1.1 json_encode

後臺將數據處理成json格式,前端通過ajax調用進行DOM操作。在php中,數組分為三類:索引數組;關聯數組;多維數組。而在javascript中,只有索引數組。
所以,php中 json_encode()只將索引數組轉成json數組格式,而將關聯數組/多維數組轉成json對象格式。

$arr = array(111,'aaa','bbb');
$arr1 = array(
'a' => 'aaa',
'b' => 222
);
$arr2 = array(
'a' => 'aaa',
'other' => array(
'bbb',1111
)
);
echo json_encode($arr); //[111,"aaa","bbb"]
echo json_encode($arr1); //{"a":"aaa","b":222}
echo json_encode($arr2); //{"a":"aaa","other":["bbb",1111]}

1.2 json_decode

php對json格式的字元串進行解碼,將其轉為php常量。
下例來自php官網:

<?php
$json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
var_dump(json_decode($json));          //返回一個對象
var_dump(json_decode($json, true));      //返回一個數組

?>
object(stdClass)#1 (5) {
    ["a"] => int(1)
    ["b"] => int(2)
    ["c"] => int(3)
    ["d"] => int(4)
    ["e"] => int(5)
}

array(5) {
    ["a"] => int(1)
    ["b"] => int(2)
    ["c"] => int(3)
    ["d"] => int(4)
    ["e"] => int(5)
}

2.前端對json的處理

前端通過ajax請求回數據後,如果使用jquery中的$.ajax,則只需要聲明返回的數據類型dataType:'json';
如果用原生javascript解析json,則有三種方法:

  • eval()
  • new Function()
  • JSON.parse()
    這裡就不贅述了,有需要的可以自行去查閱。

    2.1 遍歷複雜json

    有時候需要對json進行迴圈遍歷,比如畫echart圖的時候,如果用json中元素的某個屬性值作為x軸數據,用另外一個屬性值作為映射值。

     [{"name":"李華","age":"18","home":"上海"},{"name":"小明","age":"21","home":"北京"},{"name":"阿飛","age":"25","home":"深圳"}]

    以上述json作為例子,要用name作為x軸,age作為對應值。就需要對json遍歷兩次,將所有的name屬性值push為一個數組,同樣,將所有的age屬性值push為一個數組,再賦值給相對應的坐標。

success : function(result)
        data : (function(){
            var arr=[];
            $.ajax({
                type : "post",
                async : false, //同步執行
                url : "test1.php",
                data : {},
                dataType : "json", //返回數據形式為json
                success : function(result) {
                if (result) {
                console.log(result);
                 for(var i=0;i<result.length;i++){
                  console.log(result[i].name);
                     arr.push(result[i].name);
                        }
                    }
                },
                error : function(errorMsg) {
                        alert("圖表請求數據失敗啦!");
                            myChart.hideLoading();
                    }
                 })
           return arr;
            })()
            //控制台列印出ajax解析之後的結果:[Object, Object, Object, Object, Object, Object, Object, Object]

至此,重識JSON,前後端之相交脈絡亦瞭然一二。更覺前端道阻且長,唯上下八方求索,方不落人後。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • position的英文意思呢是位置,方位; 地位,職位; 態度; 狀態; 它有定位有四個值分別是絕對定位的兩個值absolute和fixed,相對定位的relative,還有一個預設的值static而它呢沒有定位。 下麵呢,我說先說一下: position的值,relative和absolute分別 ...
  • 在html中,改變佈局有兩種方式一種是float一種是position定位,今天解釋一下什麼position定位。 position是CSS中非常重要的一個屬性,通過position屬性,我們可以讓元素相對於其正常位置,父元素或者瀏覽器視窗進行偏移。 postion屬性我們成為定位,它有4個不同類型 ...
  • Position這個屬性定義建立元素佈局所用的定位機制。任何元素都是可以進行定位的,不過絕對或者固定一個元素會產生一個塊級框,不論該元素是什麼類型;相對定位元素會相對於它在正常文檔流中的預設位置偏移。 Position元素一般來說擁有五個屬性,分別有: 1.absolute(生成絕對定位的元素,相對 ...
  • 首先Position在字面講是位置的意思,在HTML中是定位的意思,它有四種屬性:分別是static是靜態的,也是預設的效果,沒有特別的設定,遵循基本的定位規定,不能通過z-index進行層次分級。 absolute(絕對定位) absolute(絕對定位)不光脫離了文本流,而且在文本流中也不會給這 ...
  • 本文簡單介紹下如何來使用 Bootstrap,通過引入 Bootstrap,來實現一個最基本的入門例子。 在前一篇博文【Bootstrap】1.初識Bootstrap 基礎之上,我們完全可以更加方便快捷的創建一個的簡單例子。 在Bootstrap的官方網站的下載頁面 http://getbootst ...
  • 作為Web前端開發框架,Bootstrap為大多數標準的UI設計常見提供了用戶友好、擴瀏覽器的解決方案。 1.下載Bootstrap 打開官方網址 http://getbootstrap.com/ 進行下載。 2.準備項目模板文件夾 接下來,我們為第一個項目創建一個文件夾以及一些基本的文件。謂詞我們 ...
  • 語法: 作用: 啟動調試器 備註: 1. 可以將debugger語句放在過程的任何地方以中止執行。2. 使用debugger語句類似於在代碼中設置斷點。 3. debugger語句中止執行,但它不關閉任何文件或清除任何變數。 【註】只有打開調試器,否則debugger語句不起作用 實例: ...
  • × 目錄 [1]CSSStyleSheet [2]CSSRule 前面的話 關於腳本化CSS,查詢樣式時,查詢的是計算樣式;設置單個樣式時,設置的是行間樣式;設置多個樣式時,設置的是CSS類名。腳本化樣式表當然也是一種腳本化CSS的技術,雖然不經常使用,但有時卻非常有用。下麵將詳細介紹腳本化樣式表的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...