微信小程序request

request簡介

wx.request用于發(fā)起HTTPS網(wǎng)絡(luò)請求默刚,其常用的參數(shù)有url(接口地址)翻具、data(請求的參數(shù))轨奄、header(設(shè)置請求的header)裳仆、method(http請求方法)溉箕、success(接口調(diào)用成功的回調(diào)函數(shù))晦墙、fail(接口調(diào)用失敗的回調(diào)函數(shù))、complete(接口調(diào)用結(jié)束的回調(diào)函數(shù)肴茄,調(diào)用成功或失敗都會執(zhí)行)晌畅。

request事例

    wx.request({
url: 'https://........' ,
data: {
  pageindex: that.data.pageindex//當(dāng)前頁
},
header: {
  "content-type": "application/x-www-form-urlencoded"
},
method: 'POST',
success: function (res) {
  console.log("success:" + res);
  try {
    if (res.data) {
      //定義一個臨時數(shù)據(jù)字典存儲訪問的網(wǎng)頁數(shù)據(jù)
      var tempResult = res.data.NEWS[1];
      console.log("ssss" + tempResult);
      var tempArrayInfo;
      if (that.data.pageindex == 1) { //如果是重新從第一頁開始請求,則清空之前保存的數(shù)據(jù)
      tempArrayInfo = [];
      } else {
        tempArrayInfo = that.data.ArrNews; //沒有更改篩選條件寡痰,即不是從第一頁開始請求抗楔,則將之前已經(jīng)獲取到的數(shù)據(jù)賦值給tempArrayInfo,以便解析后將新的數(shù)據(jù)加到tempArrayInfo中(后)拦坠。
      }
      if (tempResult.length < 10) {
        that.setData({
          isLastPage: true
        });
      }
      for (var i = 0; i < tempResult.length; i++) {
        var infoDict = tempResult[i]; //每一條紀(jì)錄
        var Title = infoDict.title;
        var SourceName = infoDict.source;
        var DataTime = infoDict.time;
        var Content = infoDict.article.content;
        var tempDict = {};
        tempDict["Title"] = Title; //定義左邊鍵名连躏,右邊對應(yīng)的鍵值
        tempDict["SourceName"] = SourceName;
        tempDict["DataTime"] = DataTime;
        tempDict["Content"] = Content;
        tempArrayInfo.push(tempDict);
      }
      that.setData({
        ArrNews: tempArrayInfo, //將臨時數(shù)組賦給這個arrNews空數(shù)組,則可以進行“item.鍵名”的使用
        pageindex: that.data.pageindex + 1, //加載完一頁數(shù)據(jù)下拉自動加載下一頁數(shù)據(jù)
      })
      var arrContent = that.data.ArrNews;
      wx.setStorageSync('content', arrContent); //設(shè)置緩存
    } else { }
  }
  catch (e) {
  }
  wx.hideLoading();
},
fail: function (err) {
  console.log("error:" + err);
  wx.hideLoading();
}
  });
}

代碼解釋:

url: 'https://........' ,
data: {
  pageindex: that.data.pageindex//當(dāng)前頁
}

第一步是獲取數(shù)據(jù)
使用url獲取接口中返回的數(shù)據(jù)贞滨,同時將小程序js文件中定義的pageindex作為參數(shù)添加在url中入热。獲取的數(shù)據(jù),在success:function(res)
第二步是解析數(shù)據(jù)
這里需要兩個數(shù)據(jù)字典tempResult晓铆、 tempDict和兩個數(shù)組ArrNews定義在data中的全局變量)和 tempArrayInfo勺良。
其中tempResult的作用是將success:function(res)中的數(shù)據(jù)暫時存儲起來,并進行解析骄噪,代碼如下:var tempResult = res.data.NEWS[1]; 尚困。
tempArrayInfo的作用是存儲已經(jīng)加載進去的數(shù)據(jù),相當(dāng)于一個中間存儲變量链蕊,同時頁面下拉刷新時事甜,將之前加載的數(shù)據(jù)谬泌,繼續(xù)加載到頁面中。代碼如下:

var tempArrayInfo;
          if (that.data.pageindex == 1) { //如果是重新從第一頁開始請求逻谦,則清空之前保存的數(shù)據(jù)
          tempArrayInfo = [];
          } else {
            tempArrayInfo = that.data.ArrNews; //沒有更改篩選條件掌实,即不是從第一頁開始請求,則將之前已經(jīng)獲取到的數(shù)據(jù)賦值給tempArrayInfo跨跨,以便解析后將新的數(shù)據(jù)加到tempArrayInfo中(后)潮峦。
          }

tempDict的作用是將tempResult中解析出的每一個對象的屬性,進行鍵名和鍵值的設(shè)置勇婴,設(shè)置之后忱嘹,我們可以通過item.鍵名,來獲取鍵值耕渴,然后將這些處理好的數(shù)據(jù)拘悦,放入tempArrayInfo中。代碼如下:

var tempDict = {};
            tempDict["Title"] = Title; //定義左邊鍵名橱脸,右邊對應(yīng)的鍵值
            tempDict["SourceName"] = SourceName;
            tempDict["DataTime"] = DataTime;
            tempDict["Content"] = Content;
            tempArrayInfo.push(tempDict);

ArrNews是一個全局變量础米,是最早存儲我們解析好的數(shù)據(jù)的數(shù)組,代碼如下:

 that.setData({
            ArrNews: tempArrayInfo, //將臨時數(shù)組賦給這個arrNews空數(shù)組添诉,則可以進行“item.鍵名”的使用
            pageindex: that.data.pageindex + 1, //加載完一頁數(shù)據(jù)下拉自動加載下一頁數(shù)據(jù)
          })

通過以上兩個步驟屁桑,就實現(xiàn)了將接口中的數(shù)據(jù),讀取栏赴、解析出來蘑斧。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市须眷,隨后出現(xiàn)的幾起案子竖瘾,更是在濱河造成了極大的恐慌,老刑警劉巖花颗,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件捕传,死亡現(xiàn)場離奇詭異,居然都是意外死亡扩劝,警方通過查閱死者的電腦和手機庸论,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來棒呛,“玉大人葡公,你說我怎么就攤上這事√跛” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵涵亏,是天一觀的道長宰睡。 經(jīng)常有香客問我蒲凶,道長,這世上最難降的妖魔是什么拆内? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任旋圆,我火速辦了婚禮,結(jié)果婚禮上麸恍,老公的妹妹穿的比我還像新娘灵巧。我一直安慰自己,他們只是感情好抹沪,可當(dāng)我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布刻肄。 她就那樣靜靜地躺著,像睡著了一般融欧。 火紅的嫁衣襯著肌膚如雪敏弃。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天噪馏,我揣著相機與錄音麦到,去河邊找鬼。 笑死欠肾,一個胖子當(dāng)著我的面吹牛瓶颠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播刺桃,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼粹淋,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了虏肾?” 一聲冷哼從身側(cè)響起廓啊,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎封豪,沒想到半個月后谴轮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡吹埠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年第步,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缘琅。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡粘都,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出刷袍,到底是詐尸還是另有隱情翩隧,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布呻纹,位于F島的核電站堆生,受9級特大地震影響专缠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜淑仆,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一涝婉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蔗怠,春花似錦墩弯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至怠惶,卻和暖如春涨缚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背策治。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工脓魏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人通惫。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓茂翔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親履腋。 傳聞我的和親對象是個殘疾皇子珊燎,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,901評論 2 345

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

  • 文學(xué),就是讓我們太堅硬的生活虛化遵湖。有了這個虛化悔政,生活就變得富有彈性,你的內(nèi)心也會變得更加溫暖延旧、豐富谋国、生動,比身外的...
    靜默_0a13閱讀 187評論 0 0
  • 這劇好像這兩天很火 于是乎我也就好奇了下迁沫。目前追到第二集芦瘾,說說自己的感(bu)受(man)。 整個劇情設(shè)置太滿: ...
    Chris的另一個世界閱讀 395評論 0 2
  • 鋼八連的名字來自于我們的微信群集畅,新學(xué)期的開始家長微信群組建后班主任將群名改為“鋼八連”近弟,這個名字寄托了他對這屆學(xué)生...
    林雅閱讀 945評論 0 3
  • 看很多文章都教我們買買買祷愉,說什么不會花錢怎么會掙錢呢?我們盲目的買買買真的好嗎?為什么月光族越來越多谣辞?因為花錢的速...
    ICE蟈蟈閱讀 513評論 0 1