国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

微信小程序教學第四章第二節(含視頻):小程序中級實戰教程:詳情-視圖渲染

warnerwu / 3335人閱讀

摘要:詳情數據渲染本文配套視頻地址開始前請把分支中的目錄導入微信開發工具這一節中,我們開始詳情的接口調用數據加載和視圖渲染過程。

§ 詳情 - 數據渲染

本文配套視頻地址:
https://v.qq.com/x/page/x0555...


開始前請把 ch4-2 分支中的 code/ 目錄導入微信開發工具
這一節中,我們開始詳情的接口調用、數據加載和視圖渲染過程。

Step 1. 引入公用的一些工具庫,修改 detail.js
"use strict";

import util from "../../utils/index";
import config from "../../utils/config";

// WxParse HtmlFormater 用來解析 content 文本為小程序視圖
import WxParse from "../../lib/wxParse/wxParse";
// 把 html 轉為化標準安全的格式
import HtmlFormater from "../../lib/htmlFormater";

let app = getApp();
Page({

});
Step 2. 修改 detail.js 在頁面初始化時候,請求接口,加載詳情數據
Page({
  onLoad (option) {
    /*
    * 函數 `onLoad` 會在頁面初始化時候加載運行,其內部的 `option` 是路由跳轉過來后的參數對象。
    * 我們從 `option` 中解析出文章參數 `contendId`,然后通過調用 `util` 中封裝好的 `request` 函數來獲取 `mock` 數據。 
    */ 
    let id = option.contentId || 0;
    this.init(id);
  },
  init (contentId) {
    if (contentId) {
      this.requestDetail(contentId)
          .then(data => {
              util.log(data)
          })
    }
  },
  requestDetail(contentId){
    return util.request({
      url: "detail",
      mock: true,
      data: {
          source: 1
      }
    })
    .then(res => {
      return res
    })
  }
})

運行之后,我們查看下控制臺輸出的數據,是不是很清晰!

Step 3. 接著,把頁面頭部數據渲染出來

修改 requestDetail 函數,并增加日期格式化的方法,達到我們想要的效果,然后重新返回數據

Page({
  // 此處省略部分代碼

  requestDetail(contentId){
    return util.request({
      url: "detail",
      mock: true,
      data: {
          source: 1
      }
    })
    .then(res => {
      let formateUpdateTime = this.formateTime(res.data.lastUpdateTime)
      // 格式化后的時間
      res.data.formateUpdateTime = formateUpdateTime
      return res.data
    })
  },
  formateTime (timeStr = "") {
    let year = timeStr.slice(0, 4),
        month = timeStr.slice(5, 7),
        day = timeStr.slice(8, 10);
    return `${year}/${month}/${day}`;
  }
})

現在我們已經獲取到了后端返回的數據,并且已經把部分數據標準處理過。下一步,我們把返回的數據同步到 Model 層中(也就是 data 對象中)
我們增加 configPageData 函數,用它來處理數據同步到 data的邏輯:

Page({
  data: {
    detailData: {

    }
  },
  init (contentId) {
    if(contentId) {
      this.requestDetail(contentId)
          .then(data => {
              this.configPageData(data)
          })
    }
  },
  configPageData(data){
    if (data) {
        // 同步數據到 Model 層,Model 層數據發生變化的話,視圖層會自動渲染
        this.setData({
            detailData: data
        });
        //設置標題
        let title = this.data.detailData.title || config.defaultBarTitle
        wx.setNavigationBarTitle({
            title: title
        })
    }
  }
})

因為頁面的標題是隨著文章變化的,所以需要我們動態設置,這里我們調用了小程序自帶的方法來設計

wx.setNavigationBarTitle({
  title: "標題"
})

修改視圖 detail.wxml 的頭部 class="info" 內容:


    {{ detailData.title }}
    
        {{ detailData.author }}
        {{ detailData.formateUpdateTime}}
    
    
Step 4. 調用 parse 解析接口返回的 content 字段(文本內容)

當詳情數據返回后,我們已經對部分數據進行了過濾處理,現在修改 detail.js 中的 init 函數,增加對文章正文的處理:

    articleRevert () {
      // this.data.detailData 是之前我們通過 setData 設置的響應數據
      let htmlContent = this.data.detailData && this.data.detailData.content;
      WxParse.wxParse("article", "html", htmlContent, this, 0);
    },
    init (contentId) {
      if (contentId) {
        this.requestDetail(contentId)
          .then(data => {
            this.configPageData(data)
          })
          //調用wxparse
          .then(()=>{
            this.articleRevert()
          })
      }
    },

注意看上面的 articleRevert 函數,變量 htmlContent 指向文章的正文數據,當其傳入到組件 WxParse 后,同時帶入了 5 個參數

WxParse.wxParse("article", "html", htmlContent, this, 0);

第一個參數 article 很重要,在 WxParse 中,我們傳入了當前對象 this,當變量 htmlContent 解析之后,會把解析后的數據賦值給當前對象,并命名為 article

所以當文章數據解析后,當前環境上下文中已經存在了數據 article,可以直接在 detail.wxml 中引用:

this.data.article

修改 detail.wxml,引用我們的文章正文數據: