原生js實(shí)現(xiàn)ajax

1. 簡單實(shí)現(xiàn)

// 實(shí)例化
let xhr = new XMLHttpRequest()
// 初始化
xhr.open(method, url, async)
// 發(fā)送請求
xhr.send(data)
// 設(shè)置狀態(tài)變化回調(diào)處理請求結(jié)果
xhr.onreadystatechange = () => {
  if (xhr.readyStatus === 4 && xhr.status === 200) {
    console.log(xhr.responseText)
  }
}

2. 基于promise實(shí)現(xiàn)

function ajax (options) {
  // 請求地址
  const url = options.url
  // 請求方法
  const method = options.method.toLocaleLowerCase() || 'get'
  // 默認(rèn)為異步true
  const async = options.async
  // 請求參數(shù)
  const data = options.data
  // 實(shí)例化
  const xhr = new XMLHttpRequest()
  // 請求超時(shí)
  if (options.timeout && options.timeout > 0) {
    xhr.timeout = options.timeout
  }
  // 返回一個(gè)Promise實(shí)例
  return new Promise ((resolve, reject) => {
    xhr.ontimeout = () => reject && reject('請求超時(shí)')
    // 監(jiān)聽狀態(tài)變化回調(diào)
    xhr.onreadystatechange = () => {
      if (xhr.readyState == 4) {
        // 200-300 之間表示請求成功扮宠,304資源未變麸祷,取緩存
        if (xhr.status >= 200 && xhr.status < 300 || xhr.status == 304) {
          resolve && resolve(xhr.responseText)
        } else {
          reject && reject()
        }
      }
    }
    // 錯(cuò)誤回調(diào)
    xhr.onerror = err => reject && reject(err)
    let paramArr = []
    let encodeData
    // 處理請求參數(shù)
    if (data instanceof Object) {
      for (let key in data) {
        // 參數(shù)拼接需要通過 encodeURIComponent 進(jìn)行編碼
        paramArr.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key]))
      }
      encodeData = paramArr.join('&')
    }
    // get請求拼接參數(shù)
    if (method === 'get') {
      // 檢測url中是否已存在 ? 及其位置
      const index = url.indexOf('?')
      if (index === -1) url += '?'
      else if (index !== url.length -1) url += '&'
      // 拼接url
      url += encodeData
    }
    // 初始化
    xhr.open(method, url, async)
    // 發(fā)送請求
    if (method === 'get') xhr.send(null)
    else {
      // post 方式需要設(shè)置請求頭
      xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded;charset=UTF-8')
      xhr.send(encodeData)
    }
  })
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子使套,更是在濱河造成了極大的恐慌,老刑警劉巖裆馒,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霜第,死亡現(xiàn)場離奇詭異,居然都是意外死亡技羔,警方通過查閱死者的電腦和手機(jī)僵闯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來藤滥,“玉大人鳖粟,你說我怎么就攤上這事∽景恚” “怎么了向图?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵泳秀,是天一觀的道長。 經(jīng)常有香客問我榄攀,道長晶默,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任航攒,我火速辦了婚禮磺陡,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘漠畜。我一直安慰自己币他,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布憔狞。 她就那樣靜靜地躺著蝴悉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瘾敢。 梳的紋絲不亂的頭發(fā)上拍冠,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天,我揣著相機(jī)與錄音簇抵,去河邊找鬼庆杜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛碟摆,可吹牛的內(nèi)容都是我干的晃财。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼典蜕,長吁一口氣:“原來是場噩夢啊……” “哼断盛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起愉舔,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤钢猛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后轩缤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體命迈,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年典奉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了躺翻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片丧叽。...
    茶點(diǎn)故事閱讀 38,617評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡卫玖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出踊淳,到底是詐尸還是另有隱情假瞬,我是刑警寧澤陕靠,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站脱茉,受9級特大地震影響剪芥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜琴许,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一税肪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧榜田,春花似錦益兄、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至辩块,卻和暖如春蛔六,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背废亭。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工国章, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人豆村。 一個(gè)月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓捉腥,卻偏偏與公主長得像,于是被迫代替她去往敵國和親你画。 傳聞我的和親對象是個(gè)殘疾皇子抵碟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容