在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

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

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

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

//獲取應(yīng)用實例
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)  //打印點1
    }, err => {
      // err
    })
    console.log(imageLink) //打印點2
    this.setData({
      image: imageLink
    })
  },
})

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

//獲取應(yīng)用實例
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) //打印點3
    }, err => {
      // err
    })
    console.log(this.data.image) //打印點4
  },
})

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

回答
編輯回答
拽很帥

打印點3跟打印點4是異步的,打印點4先打印,那時候還沒拿到數(shù)據(jù),打印點3后來拿到數(shù)據(jù)了,就渲染到頁面上了。。??梢钥纯磒romise的運行順序,可參考這個鏈接描述

2018年1月2日 11:24