鍍金池/ 問答/HTML/ 微信小程序獲取后臺(tái)數(shù)據(jù)的傳參問題

微信小程序獲取后臺(tái)數(shù)據(jù)的傳參問題

各位大佬,我是個(gè)新手,剛上手小程序開發(fā),我想通過動(dòng)態(tài)綁定,使后臺(tái)可以改URL來隨時(shí)可改頁面輪播圖片。寫的時(shí)候遇到一個(gè)問題,以下是小程序的JS文件,我按以下寫法,imageLink在then()里能獲得res.data.image_url的值,而且打印點(diǎn)1也能打出來正確URL地址。但是在then()外面imageLink又為空了,打印點(diǎn)2也顯示undefined,所以image也拿不到URL。

//獲取應(yīng)用實(shí)例
const app = getApp();

Page({
  data: {
    image: ''
  },
  //監(jiān)聽頁面初次渲染完成
  onReady: function () {
    let tableID = 11111
    let recordID = '6be0ad376ef5e65b4967718e'
    var imageLink =''

    let Product =  new wx.BaaS.TableObject(tableID)
    Product.get(recordID).then(res => {
      // success
      imageLink = res.data.image_url
      console.log(imageLink)  //打印點(diǎn)1
    }, err => {
      // err
    })
    console.log(imageLink) //打印點(diǎn)2
    this.setData({
      image: imageLink
    })
  },
})

所以我改成以下這樣,在then()里setData(),image就能正常拿到URL值了,打印點(diǎn)3也能正常打印,但是打印點(diǎn)4卻是空值。為什么image在then()里面拿到了URL值,在外面卻又變成空的了?難道是兩個(gè)不同的對(duì)象嗎?如果是不同的對(duì)象,按理說WXML中動(dòng)態(tài)綁定的標(biāo)簽應(yīng)該拿不到URL,那為什么WXML中動(dòng)態(tài)綁定的標(biāo)簽又能正常顯示圖片了呢?

//獲取應(yīng)用實(shí)例
const app = getApp();

Page({
  data: {
    image: ''
  },
  //監(jiān)聽頁面初次渲染完成
  onReady: function () {
    let tableID = 11111
    let recordID = '6be0ad376ef5e65b4967718e'

    let Product =  new wx.BaaS.TableObject(tableID)
    Product.get(recordID).then(res => {
      // success
      this.setData({
        image: res.data.image_url
      })
      console.log(this.data.image) //打印點(diǎn)3
    }, err => {
      // err
    })
    console.log(this.data.image) //打印點(diǎn)4
  },
})

我學(xué)藝不精,雖然最近學(xué)了小程序開發(fā)和JavaScript,但是沒有搞懂上面這是為什么,希望有大佬能解答一下我的疑惑,我也能知道自己是哪里學(xué)漏了,謝謝大家!

回答
編輯回答
拽很帥

打印點(diǎn)3跟打印點(diǎn)4是異步的,打印點(diǎn)4先打印,那時(shí)候還沒拿到數(shù)據(jù),打印點(diǎn)3后來拿到數(shù)據(jù)了,就渲染到頁面上了。。。可以看看promise的運(yùn)行順序,可參考這個(gè)鏈接描述

2018年1月2日 11:24