Ajax — 第五天

Ajax-05

xhr(level-2)新特性

responseType屬性和response屬性

responseType: 表示預期服務器返回的數據的類型

  • “” ,默認空
  • text,和空一樣,表示服務器返回的數據是字符串格式
  • json,表示服務器返回的是json格式
  • document,表示服務器返回的是xml格式
    <script>let xhr = new XMLHttpRequest();xhr.onreadystatechange = function () {if (this.readyState === 4 && this.status === 200) {console.log(this.response);}};xhr.responseType = 'json'; // 指定,服務器返回的數據是json類型xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks');xhr.send();</script>

response:響應

  • 用于接收服務器返回的結果
  • response可以接收任何類型的結果
  • 會根據responseType指定的值,自動處理服務器返回的結果(自動將JSON轉成JS

onload事件

onloadend事件

onloadstart事件

    <script>// window.onload = function () {// }let xhr = new XMLHttpRequest();// ajax請求完畢(成功),當readyState===4的時候,會觸發xhr.onload事件xhr.onload = function () {// ? 能不能在這里接收到服務器返回的結果// ? 要不要加判斷,然后在接收結果console.log(this.response);};xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks');xhr.send();/*相關的其他事件:- onload          ajax請求成功之后觸發- onloadstart     ajax請求之前觸發- onloadend       ajax請求完成之后觸發(無論成功或失敗都會觸發)*/</script>

jQuery其他方法

$.ajax()其他選項

$.ajax({type: 'GET',url: 'xxxxx',data: {},success: function (res) {},contentType: false, // 默認值  application/x-www-form-urlencodedprocessData: false,/*下面的選項大家知道,了解即可*/timeout: 10, // 設置請求超時事件ontimeout: function () {}, // 請求超時之后的處理函數beforeSend: function () {}, // 發送請求之前觸發的函數complete: function () {}, // 表示請求響應結束之后觸發的函數(無論成功失敗)dataType: 'json', // 預期服務器返回數據的類型,相當于responseTypeheaders: {}, // 用于設置請求頭xhr: function () {let xhr = new XMLH........return xhr; // 必須return  xhr對象}, // 允許我們自定義xhr對象來完成一些jQuery做不到的事
});

$.ajaxSetup();

全局配置ajax選項:

$.ajaxSetup({// 對象里面的內容,和$.ajax里面的對象的內容格式一樣timeout: 100, // 全局配置請求超時時間為100毫秒type: 'POST', // 全局配置請求方式為POST
});

$(document).ajaxStart();

  • ajax請求開始,觸發的事件

$(document).ajaxStop();

  • ajax請求終止后觸發的事件

例如:NProgress.start() 和 NProgress.done() 的作用相同
在這里插入圖片描述

$.ajaxPrefilter();

在每個ajax請求發送之前,自定義ajax的選項或修改ajax的選項

$.ajaxPrefilter(function (options) {// options是當前ajax請求的所有選項// 得到ajax請求的所有選項之后,可以對他進行修改
});

axios簡介

  • 它是別人封裝的一個能夠實現ajax請求的庫。

  • 體積小,文件大小官方說6kb。

  • 專門用于處理ajax請求,比jQuery還要強大,沒有其他功能

// 有沒有類似  $.get的方法
axios.get('http://www.liulongbin.top:3006/api/getbooks').then(function (res) {console.log(res);});

https://github.com/axios/axios

跨域(理解)

同源策略

  • 同源指的是,兩個url的 協議、域名、端口都相同,那么這兩個url就是同源的
  • 如果兩個url的 協議、域名、端口只要要一個不一樣,叫做非同源
  • 如果非同源,以下三種行為會受到限制
    • DOM無法操作
    • cookie無法獲取 (了解)
    • Ajax請求無效

兩個url,指的是打開頁面的url,和ajax請求的地址

跨域Ajax請求

打開頁面的url 和 接口地址的url 如果非同源,就是跨域請求。

我們之前練習的所有案例,都是跨域請求,之所以能夠成功,是因為 liulongbin 老師的接口做了處理。

如何實現跨域請求:

  • JSONP
    • 出現的比較早,瀏覽器都支持。
  • CORS
    • 出現的完,但是是w3c的標準,是標準的解決ajax跨域問題的方法。

JSONP方案實現跨域請求

原生代碼實現JSONP:

  • 前端(準備一個函數,比如叫做abc。并且設置好形參,準備接收結果)
  • 前端(使用script標簽src屬性,去請求jsonp接口,必須指定callback參數,值就是abc)

細節問題:

  • 請求,可以通過network查看,但是注意它不是ajax請求
  • 通過network查看到,服務器返回一個字符串,這個字符串會被瀏覽器當做js代碼解釋
  • 正規的JSONP接口,都必須傳遞callback參數,值是我們準備好的函數名。

jQuery方法實現JSONP

// 方法一:
$.getJSON('url?callback=?', data, callback);// 方法二:
$.ajax({url: '',data: {},success: function (res) {},dataType: 'jsonp' // 必須指定的一項
});

淘寶搜索建議案例

接口

淘寶搜索建議接口:'https://suggest.taobao.com/sug

請求參數: q – 我們輸入的值

步驟:

  • 注冊輸入框的鍵盤彈起事件
  • 判斷輸入框的值是否為空
  • 使用JSONP請求接口,獲取搜索建議
  • 將搜索建議渲染到頁面中(需要自定義ul和css樣式)
#sousuo, #sousuo li {list-style: none;padding: 0;margin: 0;
}
#sousuo li {height: 25px;line-height: 25px;padding-left: 5px;color: gray;
}
<!-- 下面的ul放到搜索區的后面 -->
<!-- 搜索建議區 -->
<ul id="sousuo"></ul>
// 注冊輸入框的keyup事件,當鍵盤彈起的時候,完成搜索
$('.ipt').keyup(function () {// 判斷輸入框的值是否為空let val = $(this).val().trim();if (val === '') {// 清空搜索建議列表$('#sousuo').empty();return;}// 發送JSONP請求,獲取搜索建議$.ajax({url: 'https://suggest.taobao.com/sug',data: {q: val},success: function (res) {// console.log(res);let str = '';res.result.forEach(item => {str += '<li>' + item[0] + '</li>';});// 把拼接好的li,放到ul中$('#sousuo').html(str);},dataType: 'jsonp' // 必須指定的});
});

CORS方案實現跨域請求

CORS翻譯過來,跨域資源共享。
在這里插入圖片描述

CORS實現跨域,和前端沒有關系。前端還是正常的寫代碼,完成ajax請求即可。

CORS響應頭:https://developer.mozilla.org/zh-CN/docs/Glossary/CORS

CORS介紹:https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Access_control_CORS

防抖和節流(掌握)

防抖

在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述

節流

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/248053.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/248053.shtml
英文地址,請注明出處:http://en.pswp.cn/news/248053.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 根據身份證號碼獲取出生日期、性別、年齡

1.情景展示 如何根據身份證號&#xff0c;計算出出生日期、性別、年齡? 2.解決方案 從網上找的別人的&#xff0c;因為并沒有實際用到&#xff0c;所以并未對其優化&#xff01; /*** 通過身份證號碼獲取出生日期、性別、年齡* param certificateNo* return 返回的出生日期格式…

Swift傻傻分不清楚系列(十)枚舉

本頁內容包含&#xff1a; 枚舉語法&#xff08;Enumeration Syntax&#xff09;使用 Switch 語句匹配枚舉值&#xff08;Matching Enumeration Values with a Switch Statement&#xff09;關聯值&#xff08;Associated Values&#xff09;原始值&#xff08;Raw Values&…

數據庫系統原理(第四章:SQL與關系數據庫基本操作 )

一、SQL概述 sql是結構化查詢語言&#xff08;Structured Query Language&#xff0c;SQL&#xff09;是專門用來與數 據庫通信的語言&#xff0c;它可以幫助用戶操作關系數據庫。 SQL的特點&#xff1a; SQL不是某個特定數據庫供應商專有的語言&#xff1b; SQL簡單易學 &…

selenium操作瀏覽器窗口最大化和刷新

實際測試過程中經常遇到打開一個頁面并不是全屏顯示&#xff0c;但是卻希望它能夠全屏顯示或者新增一條記錄后需要刷新一下看能不能再列表中正常顯示。 于是就有了今天的關于對瀏覽器窗口的最大化和刷新頁面。需要說明的一點&#xff1a;所有和python相關的記錄都是基于3.6版本…

Git安裝步驟+Mac終端配置

Git安裝步驟 其實可以直接略過。因為安裝的時候&#xff0c;一路 next 即可。 注意&#xff0c;安裝路徑中不能出現中文。安裝完成后&#xff0c;不得更改安裝路徑。 檢查Git是否安裝成功 在任何文件夾&#xff0c;空白處&#xff0c;右鍵。如果看到 “Git Bash Here”&#xf…

Swift傻傻分不清楚系列(十一)類和結構體

本頁包含內容&#xff1a; 類和結構體對比結構體和枚舉是值類型類是引用類型類和結構體的選擇字符串(String)、數組(Array)、和字典(Dictionary)類型的賦值與復制行為 類和結構體是人們構建代碼所用的一種通用且靈活的構造體。我們可以使用完全相同的語法規則來為類和結構體定義…

數據庫系統原理(第5章:數據庫編程)

一、存儲過程 概念&#xff1a;存儲過程是一組為了完成某項特定功能的SQL語句集&#xff0c; 其實質就是一段存儲在數據庫中的代碼。 它可以由聲明式的sql語句和過程式sql語句組成。 特點&#xff1a; 可增強SQL語言的功能和靈活性良好的封裝性高性能可減少網絡流量可作為一種安…

科學-中醫:儒醫

ylbtech-科學-中醫&#xff1a;儒醫"儒醫"是一種歷史悠久的社會文化現象。闡釋了"儒醫"的三重境界,即良醫、大醫、圣醫。"良醫"注重技,屬于知識論,追求的是"真";"大醫"注重德,屬于道德論,追求的是"善";"圣醫…

Ajax — 第六天

Ajax-06 GET和POST的區別 字面意思不同 GET 是獲取意思。想從服務器獲取數據&#xff0c;用GET方式的請求POST是郵遞、郵寄意思。如果提交數據到服務器&#xff0c;用POST方式 請求參數位置不同 GET 請求參數會和url拼接到一起&#xff0c;形如 api/getbooks?id2&age3PO…

iOS Tips 模擬器屏幕截圖

當我們發布app到AppStore的時候&#xff0c;在itunes connect里面&#xff0c;蘋果官方要求我們提供各種尺寸的屏幕截圖。由于受到硬件條件的限制&#xff0c;我們不可能在每個真實的物理機器上測試并截圖&#xff0c;相反如果我們能直接在模擬器上進行屏幕截圖的話&#xff0c…

數據庫系統原理(第6章:數據庫安全與保護)

一、數據庫完整性 數據庫完整性是指數據庫中數據的正確性和相容性。 完整性約束條件的作用對象 列級約束&#xff1a; 包括對列的類型、取值范圍、精度等的約束元組約束&#xff1a; 指元組中各個字段之間的相互約束表級約束&#xff1a; 指若干元組、關系之間的聯系的約束定義…

.net core WebApi 使用Swagger生成API文檔

關于 Swagger Swagger能成為最受歡迎的REST APIs文檔生成工具之一&#xff0c;有以下幾個原因&#xff1a; Swagger 可以生成一個具有互動性的API控制臺&#xff0c;開發者可以用來快速學習和嘗試API。Swagger 可以生成客戶端SDK代碼用于各種不同的平臺上的實現。Swagger 文件可…

Git — 初體驗

準備工作 版本管理軟件 作用 記錄代碼的版本實現多人協作 分類 集中式&#xff0c;典型代表 SVN分布式&#xff0c;典型代表 Git 注冊遠程倉庫賬號 遠程倉庫相當于中央服務器我們需要在github上或碼云上注冊一個賬號&#xff0c;用于創建遠程倉庫使用注冊的時候&#xff0…

iOS CoreTelephony框架介紹與使用案列

昨晚看一篇文章時看到了私有API這個詞&#xff0c;貌似開發者對私有API的使用很反感于是果斷百度谷歌&#xff0c;以下是Stackoverflow中關于Private Frameworks的一個解釋&#xff1a; Private frameworks are frameworks which you are not allowed to use. They are not exp…

JS數組的迭代器方法

迭代器forEachevery一、迭代器方法 迭代器方法&#xff0c; 這些方法對數組中的每一個元素應用一個函數&#xff0c;可以返回一個值&#xff0c;一組值或一個新數組。 不生成新數組的迭代器方法 1.forEach() forEach()輸出 forEach輸出結果2.every() 該方法按接受一個返回值為布…

Git 筆記

三個區域 下面三個區域&#xff0c;是Git虛擬的區域&#xff0c;看不到&#xff0c;摸不著。 工作區 工作區&#xff0c;指的是使用Git管理后的文件&#xff0c;這些文件顯示在磁盤上&#xff0c;供我們使用或修改的區域。所以&#xff0c;粗略的說&#xff0c;項目文件夾就是…

C# webapi 上傳下載圖片

客戶端上傳文件 string url url "webUploadFile";Uri server new Uri(url);HttpClient httpClient new HttpClient();MultipartFormDataContent multipartFormDataContent new MultipartFormDataContent();StreamContent streamConent new StreamContent(new F…

OC-@dynamic 關鍵字

dynamic這個關鍵詞&#xff0c;通常是用不到的。 它與synthesize的區別在于&#xff1a; 使用synthesize編譯器會確實的產生getter和setter方法&#xff0c;而dynamic僅僅是告訴編譯器這兩個方法在運行期會有的&#xff0c;無需產生警告。 假設有這么個場景&#xff0c;B類&…

git -- 練習的筆記

gitgitee.com:my_exercises/my_exercises.githttps://gitee.com/my_exercises/my_exercises/invite_link?invite3ab56c724a0aed34ae2bd193ce87e741e67fe05ee029cc01b7993663152babc57d76203fdafbbb42e766b0d826817bc91.在任意位置右鍵打開 2.初始化設置 3.添加遠程倉庫地址 4.…

Swift傻傻分不清楚系列(十二) 屬性

本頁包含內容&#xff1a; 存儲屬性&#xff08;Stored Properties&#xff09;計算屬性&#xff08;Computed Properties&#xff09;屬性觀察器&#xff08;Property Observers&#xff09;全局變量和局部變量&#xff08;Global and Local Variables&#xff09;類型屬性&a…