什么是json?
定義:
JSON(JavaScript Object Notation, JS 對象標記) 是一種輕量級的數據交換格式。 它基於 ECMAScript (w3c制定的js規范)的一個子集,采用完全獨立於編程語言的文本格式來存儲和表示數據。 簡潔和清晰的層次結構使得 JSON 成為理想的數據交換語言。 易於人閱讀和編寫,同時也易於機器解析和生成,並有效地提升網絡傳輸效率。
講json對象,不得不提到JS對象:
合格的json對象:
["one", "two", "three"] { "one": 1, "two": 2, "three": 3 } {"names": ["張三", "李四"] } [ { "name": "張三"}, {"name": "李四"} ]
不合格的json對象:
{ name: "張三", 'age': 32 } // 屬性名必須使用雙引號 [32, 64, 128, 0xFFF] // 不能使用十六進制值 { "name": "張三", "age": undefined } // 不能使用undefined { "name": "張三", "birthday": new Date('Fri, 26 Aug 2011 07:13:10 GMT'), "getName": function() {return this.name;} // 不能使用函數和日期對象 }
概括的的說JSON必須有雙引號。
stringify與parse方法
JSON.parse(): 用於將一個 JSON 字符串轉換為 JavaScript 對象 eg: console.log(JSON.parse('{"name":"Yuan"}')); console.log(JSON.parse('{name:"Yuan"}')) ; // 錯誤 console.log(JSON.parse('[12,undefined]')) ; // 錯誤 JSON.stringify(): 用於將 JavaScript 值轉換為 JSON 字符串。 eg: console.log(JSON.stringify({'name':"egon"})) ;
JSON的好處
JSON 格式於2001年由 Douglas Crockford 提出,目的就是取代繁瑣笨重的 XML 格式。
JSON 格式有兩個顯著的優點:書寫簡單,一目了然;符合 JavaScript 原生語法,可以由解釋引擎直接處理,不用另外添加解析代碼。所以,JSON迅速被接受,已經成為各大
網站交換數據的標准格式,並被寫入ECMAScript 5,成為標准的一部分。
AJAX簡介
AJAX(Asynchronous Javascript And XML)翻譯成中文就是“異步Javascript和XML”。即使用Javascript語言與服務器進行異步交互,傳輸的數據為XML(當然,傳輸的數據不只是XML)。
- 同步交互:客戶端發出一個請求后,需要等待服務器響應結束后,才能發出第二個請求;
- 異步交互:客戶端發出一個請求后,無需等待服務器響應結束,就可以發出第二個請求。
AJAX除了異步的特點外,還有一個就是:瀏覽器頁面局部刷新;(這一特點給用戶的感受是在不知不覺中完成請求和響應過程)
js實現的局部刷新:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .error{ color:red } </style> </head> <body> <form class="Form"> <p>姓名 <input class="v1" type="text" name="username" mark="用戶名"></p> <p>密碼 <input class="v1" type="text" name="email" mark="郵箱"></p> <p><input type="submit" value="submit"></p> </form> <script src="jquery-3.1.1.js"></script> <script> $(".Form :submit").click(function(){ flag=true; $("Form .v1").each(function(){ var value=$(this).val(); if (value.trim().length==0){ var mark=$(this).attr("mark"); var $span=$("<span>"); $span.html(mark+"不能為空!"); $span.prop("class","error"); $(this).after($span); setTimeout(function(){ $span.remove(); },800); flag=false; return flag; } }); return flag }); </script> </body> </html>
局部刷新相對於FORM表單的好處就是,減少刷新的數據,以至於減少流量和代寬。
AJAX常見應用情景
當我們在百度中輸入一個“老”字后,會馬上出現一個下拉列表!列表中顯示的是包含“傳”字的4個關鍵字。
其實這里就使用了AJAX技術!當文件框發生了輸入變化時,瀏覽器會使用AJAX技術向服務器發送一個請求,查詢包含“傳”字的前10個關鍵字,然后服務器會把查詢到的結果響應給瀏覽器,最后瀏覽器把這4個關鍵字顯示在下拉列表中。
- 整個過程中頁面沒有刷新,只是刷新頁面中的局部位置而已!
- 當請求發出后,瀏覽器還可以進行其他操作,無需等待服務器的響應!
當輸入用戶名后,把光標移動到其他表單項上時,瀏覽器會使用AJAX技術向服務器發出請求,服務器會查詢名為zhangSan的用戶是否存在,最終服務器返回true表示名為lemontree7777777的用戶已經存在了,瀏覽器在得到結果后顯示“用戶名已被注冊!”。
- 整個過程中頁面沒有刷新,只是局部刷新了;
- 在請求發出后,瀏覽器不用等待服務器響應結果就可以進行其他操作;
AJAX的優缺點
優點:
- AJAX使用Javascript技術向服務器發送異步請求;
- AJAX無須刷新整個頁面;
因為服務器響應內容不再是整個頁面,而是頁面中的局部,所以AJAX性能高;
下面直接上代碼,這是我在學習中遇到的一寫困惑
一下是一段簡單的ajax請求
這是我的Django目錄,紅框內是兩個html文件。
login.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <p>用戶名<input type="text" id="aa" > </p> <p>密碼<input type="password" id="bb"> </p> <p><input type="button" class="cc"> 提交</p> </body> <script src="/static/jquery-3.2.1.min.js"></script> #這里的ajax是在jquery里用的,所以導入jquery <script src = "/static/jquery.cookie.js"></script> <script> $(".cc").click(function () { $.ajax({ url: '/login/', #這里是視圖函數處理數據的路徑,是這個def login(request)函數在處理 type: 'POST', headers:{"X-CSRFToken":$.cookie('csrftoken')}, #發起的是post請求所以要加csrftoken,需要引入jquerycookie,目的就是聲明下,可以通過django中間件的驗證機制 data: { #這里的name,pwd是個key可以隨便寫,但是要有意義,后面的視圖函數里會調用這個key. name: $('#aa').val(), #這是獲取input框內的值,傳給后端,#aa是通過id取得
pwd: $('#bb').val(), },
#以上是AJAX發送的帶數據的post請求,將數據提交給后端函數處理。
success: function (data) { var dat = JSON.parse(data); console.log(dat) #以上是后端函數返回成功的信息 } }) }) </script> </html>
view.py
def login(request): if request.method == "GET": return render(request,"login.html") else: #下面的name,pwd,就是剛才的key username = request.POST.get('name') password = request.POST.get('pwd') response = {'flag': False} if username == 'huang' and password == '123': response["flag"] = True return HttpResponse(json.dumps(response))
首先說下代碼邏輯
我的login里有兩個input框,一個button按鈕,想要實現的功能就是賬號密碼后將數據提交給相應的視圖函數處理。
如圖:
那么重點來了我可不可以寫成以下形式呢
view.py
def login(request): username = request.POST.get('name') password = request.POST.get('pwd') response = {'flag': False} if username == 'huang' and password == '123': response["flag"] = True return HttpResponse(json.dumps(response))
這里我用的是GET請求的(和上面的區別只有視圖函數,區別就是我這里是GET請求)
這么寫顯然是不行的,原因就是,當你向后端函數發送請求的時候你只能選擇是讓函數處理的你請求中帶的數據還是讓函數返回一個頁面。
如果你的視圖函數就想這么寫,那么就需要改下你的url.py,view.py,loginl.html
url.py
from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^login/', views.login), url(r'^aa/', views.aa), ]
view.py
def login(request): return render(request,"login.html") def aa(request): username=request.GET.get("name") password=request.GET.get("pwd") response={"flag":False} if username=="yuan" and password=="123": response["flag"]=True import json import time time.sleep(10) return HttpResponse(json.dumps(response))
login.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <p>用戶名<input type="text" id="aa" > </p> <p>密碼<input type="password" id="bb"> </p> <p><input type="button" class="cc"> 提交</p> </body> <script src="/static/jquery-3.2.1.min.js"></script> #這里的ajax是在jquery里用的,所以導入jquery <script src = "/static/jquery.cookie.js"></script> <script> $(".cc").click(function () { $.ajax({ url: '/aa/', #這里是視圖函數處理數據的路徑,是這個def login(request)函數在處理,這里的路徑變了 type: 'POST', headers:{"X-CSRFToken":$.cookie('csrftoken')}, #發起的是post請求所以要加csrftoken,目的就是聲明下,可以通過django中間件的驗證機制 data: { #這里的name,pwd是個key可以隨便寫,但是要有意義,后面的視圖函數里會調用這個key. name: $('#aa').val(), #這是獲取input框內的值,傳給后端 pwd: $('#bb').val(), }, #以上是AJAX發送的帶數據的post請求,將數據提交給后端函數處理。 success: function (data) { var dat = JSON.parse(data); console.log(dat) #以上是后端函數返回成功的信息 } }) }) </script> </html>