主頁 >  其他 > 前端筆記JavaScript JSON

前端筆記JavaScript JSON

2020-10-01 14:56:45 其他

JSON叫做JavaScript Object Notation, JavaScript物件表示法,由JS大牛Douglas發明,
JSON 是存盤和交換文本資訊的語法,類似 XML,
JSON 比 XML 更小、更快,更易決議,

JSON與 XML 異同之處

相同之處

  • JSON 是純文本
  • JSON 具有"自我描述性"(人類可讀)
  • JSON 具有層級結構(值中存在值)
  • JSON 可通過 JavaScript 進行決議
  • JSON 資料可使用 AJAX 進行傳輸

不同之處

  • 沒有結束標簽
  • 更短
  • 讀寫的速度更快
  • 能夠使用內建的 JavaScript eval() 方法進行決議
  • 使用陣列
  • 不使用保留字

JSON語法

JSON 語法規則
JSON 語法是 JavaScript 物件表示語法的子集,

  • 資料在名稱/值對中
  • 資料由逗號分隔
  • 大括號 {} 保存物件
  • 中括號 [] 保存陣列,陣列可以包含多個物件
    JSON 資料的書寫格式是:,
	key : value

名稱/值對包括欄位名稱(在雙引號中),后面寫一個冒號,然后是值:

"name" : "林江濤"

這很容易理解,等價于這條 JavaScript 陳述句:

name = "菜鳥教程"

JSON與物件實體示例

	//物件
	var obj={
		name:"ret",
		age:18,
		sex:"男"
	}
	//JSON
	var jon={
			"name":"ret",
			"age":18,
			"sex":"男"
	}

JSON 值

JSON 值可以是:

-數字(整數或浮點數)
-字串(在雙引號中)
-邏輯值(true 或 false)
-陣列(在中括號中)
-物件(在大括號中)
-null

JSON數字

JSON 數字可以是整型或者浮點型:
示例

	var jon={
		"age":30,
		"height":18.5
	}
	console.log(jon.age);
	console.log(jon.height);

在這里插入圖片描述

JSON物件

JSON物件語法

  • JSON 物件在大括號 {} 中書寫:
  • 物件可以包含多個 key/value(鍵/值)對,
  • key 必須是字串,value 可以是合法的 JSON 資料型別(字串, 數字, 物件, 陣列, 布林值或 null),
  • key 和 value 中使用冒號(:)分割,
  • 每個 key/value 對使用逗號(,)分割,

語法:{key1 : value1, key2 : value2, … keyN : valueN }

物件可以包含多個名稱/值對:

{ "name":"林江濤" , "sex":"男" }

這一點也容易理解,與這條 JavaScript 陳述句等價:

name = "林江濤",
sex= "男"

訪問物件值

可以使用點號(.)來訪問物件的值:也可以使用中括號([])來訪問物件的值:

示例

	var jon={
		"name":"林江濤" , 
		"sex":"男",
		"kungfu":mykungfu,
		"無線影分身術":this
	}
	function mykungfu(){
		console.log("發射了一枚飛鏢");
	}
	console.log(jon.name);
	console.log(jon["sex"])

在這里插入圖片描述


==注意== json 在進行通過鍵名來獲取值時,需要特別注意一下, 把鍵名賦值給另外一個變數,然后通過.方式去獲取值,這種方式是行不通的,
	var my, x;
		my = { "name":"林江濤", "年齡":10000, "性別":null };
	x = "name";
	console.log(my.x) // 結果是 undefined

只能通過 [] 方式去訪問:

	var my, x;
	my = { "name":"林江濤", "年齡":10000, "性別":null };
	x = "name";
	console.log(my[x]) // 結果是 林江濤

### 回圈物件 以使用 for-in 來回圈物件的屬性: 示例
	var jon={
		"name":"林江濤" , 
		"sex":"男",
		"kungfu":mykungfu,
		"無線影分身術":this
	}
	function mykungfu(){
		console.log("發射了一枚飛鏢");
	}
	for(x in jon){
		console.log(jon[x]);
	}

在這里插入圖片描述

JSON物件的新增,修改,洗掉

JSON新增

	var	my = { "name":"林江濤", "年齡":10000, "性別":null };
	my.我是新增的="哈哈哈哈";
	console.log(my);

在這里插入圖片描述

JSON修改

示例

	var	my = { "name":"林江濤", "年齡":10000, "性別":null };
	my.name="天王老子";
	console.log(my);

效果

在這里插入圖片描述

JSON洗掉

示例

	var	my = { "name":"林江濤", "年齡":10000, "性別":null };
	delete	my.name
	console.log(my);

效果
在這里插入圖片描述

偷個懶

其實物件就已經包含的其他所有的了因為物件是所有參考型別的基類
所以null 和bool什么的就不一一列舉了
如下,包含JSON和function
在這里插入圖片描述

JSON 陣列

JSON 陣列在中括號 [] 中書寫:

陣列可包含多個物件:
語法

[
{ key1 : value1-1 , key2:value1-2 },
{ key1 : value2-1 , key2:value2-2 },
{ key1 : value3-1 , key2:value3-2 },

{ keyN : valueN-1 , keyN:valueN-2 }
]

示例

	var={
		"師門":[
				{"關系":"師傅","年紀":40,"身高":175},
				{"關系":"徒弟","年紀":10,"身高":260},
				{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	console.log();

在這里插入圖片描述
因為 JSON 使用 JavaScript 語法所以我們可以象訪問陣列一樣訪問里面的資料

	console.log(.師門[0].關系)

在這里插入圖片描述
也可以像這樣修改資料:

.師門[0].關系="老頭子"

回圈陣列

for-in回圈
代碼示例

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
		}
	for(i in.師門){
		console.log(.師門[i]);
	}

效果
在這里插入圖片描述
也可以回圈出陣列里的鍵值對

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	for(i in.師門){
		for(j in.師門[i]){
			console.log(.師門[i][j])
		}
	
	}

for回圈

代碼示例

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	
	for(i=0 ;i <.師門.length ; i++){
		console.log(.師門[i])
	}

效果

在這里插入圖片描述

但從陣列中回圈出來的是物件所以我們不能再使用for回圈遍歷里面的每一個元素了
代碼示例

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	
	for(i=0 ;i <.師門.length ; i++){
		for(j=0;j<.師門[i].length;j++){
			console.log(.師門[i][j]);
		}
	}

效果,出錯誤了啥也沒有
在這里插入圖片描述

JOSN陣列的新增修改洗掉

因為josn使用的就是JavaScript的語法,所以josn陣列的新增修改和JavaScript的一模一樣,
那么我這里就寫一下奇奇怪怪的新增修改
新增示例

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}.師門[.師門.length]={"HHHH":"HHHH","我是新增的":"對的,他是新來的"};
	console.log()

效果示例.可以看到,師門下面多出了一個陣列
在這里插入圖片描述
修改洗掉同上

JSON陣列中的洗掉

洗掉數值的元素,陣列的大小不變,代碼如下:

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	console.log("洗掉前陣列長度:"+.師門.length);
	delete.師門[1];
	console.log("洗掉后陣列長度:"+.師門.length)
	console.log("查看被洗掉的陣列:"+.師門[1])
	console.log("for in遍歷陣列")
	for(i in.師門){
		console.log("陣列下標:"+i);
		console.log(.師門[i]);
	}

在這里插入圖片描述

delete 運算子并不是徹底洗掉元素,而是洗掉它的值,但仍會保留空間,

運算子 delete 只是將該值置為 undefined,而不會影響陣列長度,即將其變為稀疏陣列(《JS權威指南》7.5節)

JS 中徹底洗掉 JSON 物件組成的陣列中的元素

在 JS 中,對于某個由 JSON 物件組成的陣列,例如:

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}

如果我們想要洗掉其中的第二個json物件,應該怎么做呢?方法和操作陣列完全相同,

但在上面使用delete運算子洗掉陣列的程序中,我們發現這種方法并不是徹底洗掉元素,而是洗掉它的值,但仍會保留空間,
在這里插入圖片描述

查詢運算子 delete 我們知道它只是將該值置為 undefined,而不會影響陣列長度,即將其變為稀疏陣列

了解及此,也許想著可以將洗掉點之后的元素各往前移動1個單位,實作徹底剔除該元素,但在JS方法中我們可以查到一種更加簡便的方式:splice() 方法

	var={
		"師門":[
			{"關系":"師傅","年紀":40,"身高":175},
			{"關系":"徒弟","年紀":10,"身高":260},
			{"關系":"小徒弟","年紀":3,"身高":170}
		],
		"name":"林江濤",
		"age":100
	}
	console.log("洗掉前陣列長度:"+.師門.length);
	delete.師門.splice(1,1);
	console.log("洗掉后陣列長度:"+.師門.length)
	console.log("查看被洗掉的陣列:"+.師門[1])
	console.log("for in遍歷陣列")
	for(i in.師門){
		console.log("陣列下標:"+i);
		console.log(.師門[i]);
	}

效果
在這里插入圖片描述
如上圖,洗掉后,我.師門長度為二這正是我想要的結果

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/145475.html

標籤:其他

上一篇:各種計算機語言簡短簡介

下一篇:小程式canvas生成海報

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more