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

資訊專欄INFORMATION COLUMN

用小程序·云開(kāi)發(fā)打造功能全面的博客小程序丨實(shí)戰(zhàn)

flybywind / 3681人閱讀

摘要:用小程序云開(kāi)發(fā)將博客小程序常用功能一網(wǎng)打盡本文介紹博客小程序的詳情頁(yè)的功能按鈕如何實(shí)現(xiàn),具體包括評(píng)論點(diǎn)贊收藏和海報(bào)功能,這里記錄下整個(gè)實(shí)現(xiàn)過(guò)程和實(shí)際編碼中的一些坑。考慮到小程序本身的大小限制,使用的方式是最佳的。

用小程序·云開(kāi)發(fā)將博客小程序常用功能“一網(wǎng)打盡”

本文介紹mini博客小程序的詳情頁(yè)的功能按鈕如何實(shí)現(xiàn),具體包括評(píng)論、點(diǎn)贊、收藏和海報(bào)功能,這里記錄下整個(gè)實(shí)現(xiàn)過(guò)程和實(shí)際編碼中的一些坑。
評(píng)論、點(diǎn)贊、收藏功能 實(shí)現(xiàn)思路

實(shí)現(xiàn)文章的一些操作功能,最主要的還是評(píng)論,這是作者和讀者之間溝通的橋梁,評(píng)論功能的衍生無(wú)非是細(xì)化作者和讀者之間的互動(dòng),或者增加文章的傳播,所以在動(dòng)手開(kāi)發(fā)時(shí)需要思考下你期望實(shí)現(xiàn)哪些功能,并對(duì)應(yīng)功能進(jìn)行細(xì)化。

我一般的經(jīng)驗(yàn)是,先在腦子里過(guò)一遍需要的功能和大致流程,然后在筆記稍微畫(huà)下「最最基礎(chǔ)的原型,相當(dāng)于產(chǎn)品的角色」。

然后就開(kāi)始直接開(kāi)始搭建頁(yè)面和簡(jiǎn)單的交互「使用假數(shù)據(jù),優(yōu)先完成頁(yè)面」,在構(gòu)造頁(yè)面的時(shí)候其實(shí)也能夠補(bǔ)充最初想法上一些流程上的缺陷,這樣在設(shè)計(jì)后端和數(shù)據(jù)庫(kù)結(jié)構(gòu)的時(shí)候可以補(bǔ)上,整體下來(lái)也基本比較完善了。

回頭看我的小程序的需求,首先肯定是操作,在文章底部需要有個(gè)操作欄,用于發(fā)送點(diǎn)評(píng)和其他一些操作,在參考了一些同類型的小程序之后,逐步實(shí)現(xiàn)自己的一套風(fēng)格,樣式截圖如下:

在有了功能之后,點(diǎn)評(píng)的數(shù)據(jù)需要有地方展示「通常是文章底部」,然后就有了文章底部的評(píng)論列表,樣式如下:

既然有點(diǎn)贊收藏的功能按鈕,是否用戶需要看下我點(diǎn)贊和收藏的文章列表呢,所以在「我的」中就有相應(yīng)的列表,樣式如下:

到這里,最最基礎(chǔ)的功能基本差不多,接下來(lái)就要看后端是否能支持這些頁(yè)面了「主要就是數(shù)據(jù)的保存和展示了」

對(duì)于評(píng)論來(lái)說(shuō),肯定需要一個(gè)集合用于保存用戶的評(píng)論,而對(duì)于用戶的喜歡和收藏也需要一個(gè)集合來(lái)進(jìn)行保存。

所以根據(jù)頁(yè)面我們就可以設(shè)計(jì)mini_commentsmini_posts_related兩個(gè)集合。前者用于保存評(píng)論數(shù)據(jù),后者用戶保存用戶操作與文章之間的關(guān)聯(lián)。

剩下的工作就是變現(xiàn)了,無(wú)非就是頁(yè)面交互和數(shù)據(jù)的增刪改查了。

細(xì)節(jié)點(diǎn)解析 關(guān)于評(píng)論數(shù)量

目前在文章的集合中有個(gè)totalComments這個(gè)屬性,當(dāng)這篇文章每新增一個(gè)評(píng)論時(shí),需要加1。

最初在寫(xiě)這個(gè)的時(shí)候,每次都是先查再更新,兩段式,原代碼如下:

let count=post.totalComments+1;

let result =await db.collection("mini_posts").doc(event.commentContent.postId).update({

?    data: {

?      totalComments: count

?    }

  });

后來(lái)看文檔發(fā)現(xiàn),可以使用db.command.inc這個(gè)指令,無(wú)需再查一遍,直接可對(duì)原字段加1,還能保證原子性。代碼如下:

const _ = db.command

let result = db.collection("mini_posts").doc(event.commentContent.postId).update({

?    data: {

?      totalComments: _.inc(1)

?    }

  });
關(guān)于新增子評(píng)論

需要實(shí)現(xiàn)在某個(gè)評(píng)論下進(jìn)行回復(fù)。

在交互上,點(diǎn)擊評(píng)論者的昵稱或頭像時(shí),觸發(fā)相應(yīng)的點(diǎn)擊事件,在事件中去記錄相應(yīng)的評(píng)論ID及必要數(shù)據(jù),同時(shí)去設(shè)置焦點(diǎn)到評(píng)論框內(nèi):

 /**

  * 點(diǎn)擊評(píng)論內(nèi)容回復(fù)

  */

  focusComment: function (e) {

?    let that = this;

?    let name = e.currentTarget.dataset.name;

?    let commentId = e.currentTarget.dataset.id;

?    let openId = e.currentTarget.dataset.openid;



?    that.setData({

?      commentId: commentId,

?      placeholder: "回復(fù)" + name + ":",

?      focus: true,

?      toName: name,

?      toOpenId: openId

?    });

  },

利用云開(kāi)發(fā)新增子評(píng)論時(shí)可以使用db.command.push來(lái)進(jìn)行操作「更新指令,對(duì)一個(gè)值為數(shù)組的字段,往數(shù)組尾部添加一個(gè)或多個(gè)值」,往子評(píng)論集合中新增:

/**

 * 新增子評(píng)論

 * @param {} event 

 */

async function addPostChildComment(event) {



  let task = db.collection("mini_posts").doc(event.postId).update({

?    data: {

?      totalComments: _.inc(1)

?    }

  });

  await db.collection("mini_comments").doc(event.id).update({

?    data: {

?      childComment: _.push(event.comments)

?    }

  })

  await task;

}
關(guān)于判斷是否已收藏

在文章第一次加載時(shí),我們需要判斷下該用戶是否有對(duì)該文章有相關(guān)操作,如果有相應(yīng)的收藏和點(diǎn)贊操作,在初始化時(shí)需要更新相應(yīng)的功能圖標(biāo),核心代碼如下:

  /**

   * 獲取收藏和喜歡的狀態(tài)

   */

  getPostRelated: async function (blogId) {

?    let where = {

?      postId: blogId,

?      openId: app.globalData.openid

?    }

?    let postRelated = await api.getPostRelated(where, 1);

?    let that = this;

?    for (var item of postRelated.data) {

?      if (config.postRelatedType.COLLECTION === item.type) {

?        that.setData({

?          collection: { status: true, text: "已收藏", icon: "favorfill" }

?        })

?        continue;

?      }

?      if (config.postRelatedType.ZAN === item.type) {

?        that.setData({

?          zan: { status: true, text: "已贊", icon: "appreciatefill" }

?        })

?        continue;

?      }

?    }

  },

至于其他一些交互細(xì)節(jié)和代碼細(xì)節(jié),可以自行閱讀源碼去體會(huì),如果有任何疑問(wèn)或者有更好的實(shí)現(xiàn)方式,也可以與我溝通。

海報(bào)功能 交代些背景

其實(shí)在最早之前的小程序中已經(jīng)實(shí)現(xiàn)了一次,具體可以參考利用云開(kāi)發(fā)優(yōu)化博客小程序(三)——生成海報(bào)功能,主要還是使用原生的cavans進(jìn)行組裝,原本想代碼copy過(guò)來(lái)改改就行了,但總覺(jué)得原來(lái)的代碼寫(xiě)的不是特別好。

于是想看看是否有現(xiàn)成的輪子可以利用,果然發(fā)現(xiàn)了wxa-plugin-canvas這款組件,通過(guò)非常簡(jiǎn)單的配置就可以生成精美的海報(bào)。

小程序使用npm

在總結(jié)生成海報(bào)功能之前還是有必要記錄下小程序npm的使用,避免一些不必要的坑。

考慮到小程序本身的大小限制,使用npm的方式是最佳的。

原因是根據(jù)官方文檔介紹,小程序 npm 包里只有構(gòu)建文件生成目錄會(huì)被算入小程序包的占用空間,上傳小程序代碼時(shí)也只會(huì)上傳該目錄的代碼。這樣大大減少了上傳的代碼體積。

下面簡(jiǎn)單介紹下小程序端如何使用npm的「其實(shí)根據(jù)官方文檔按照步驟就可以了」。

以我目前小程序的路徑為例,在/miniprogram新增文件夾node_modules,在命令行指向到/miniprogram目錄下:

通過(guò)命令進(jìn)行安裝:

npm install wxa-plugin-canvas --production  

安裝成功后,即可在小程序開(kāi)發(fā)工具中進(jìn)行構(gòu)建,構(gòu)建前需要勾選使用 npm 模塊

然后點(diǎn)擊開(kāi)發(fā)者工具中的菜單欄:工具 --> 構(gòu)建 npm即可:

構(gòu)建完成后會(huì)生成miniprogram_npm目錄,到這里,項(xiàng)目端基本就調(diào)通了。

wxa-plugin-canvas

在構(gòu)建完之后,就可以正常使用wxa-plugin-canvas這個(gè)自定義組件,使用方式還是比較簡(jiǎn)單的。

首先在你需要的頁(yè)面引入該組件:

{

  "usingComponents": {"poster": "wxa-plugin-canvas/poster"}

}

然后就可以在wsml中使用了:


由于我們?cè)谏珊?bào)前,需要異步獲取一些用于海報(bào)的數(shù)據(jù),所以我們采用異步生成的海報(bào)方式。

需要引入該組件的poster/poster.js文件,然后在代碼中調(diào)用即可:

import Poster from "../../utils/poster";

Page({

?    /**

?     * 異步生成海報(bào)

?     */

?    onCreatePoster() {

?        // setData配置數(shù)據(jù)

?        this.setData({ posterConfig: {...} }, () => {

?            Poster.create(); 

?        });

?    }

})
核心代碼解析 海報(bào)需要的數(shù)據(jù)

先來(lái)看看分享海報(bào)的整體結(jié)構(gòu):

首先需要確認(rèn)海報(bào)的構(gòu)成需要哪些數(shù)據(jù),在調(diào)用組件前先獲取好相應(yīng)的數(shù)據(jù)。

在我設(shè)計(jì)的海報(bào)中主要包含三塊內(nèi)容,用戶的信息(頭像和昵稱),文章信息(首圖,標(biāo)題,簡(jiǎn)介)和最重要的文章的小程序碼。

用戶信息和文章信息其實(shí)比較簡(jiǎn)單,在小程序的詳情頁(yè)兩者數(shù)據(jù)都有,但這里有兩個(gè)問(wèn)題點(diǎn)需要注意下。

第一個(gè)是域名問(wèn)題,在畫(huà)布中使用到的圖片都需要配置域名,頭像的域名和公眾號(hào)文章首圖的域名

https://mmbiz.qpic.cn

https://wx.qlogo.cn

第二個(gè)是公眾號(hào)首圖的問(wèn)題,公眾號(hào)素材列表返回的圖片url其實(shí)是http的,但小程序規(guī)定綁定的域名必須是https的,當(dāng)時(shí)比較無(wú)奈,后來(lái)嘗試改用https訪問(wèn)首圖的url也可以,不幸中的萬(wàn)幸,所以在使用首圖地址時(shí)進(jìn)行替換下:

imageUrl = imageUrl.replace("http://", "https://")

最后就是文章的小程序碼了,需要利用小程序的getUnlimited的api,具體可以參考官方文檔,目前已經(jīng)提供了云調(diào)用的方式「無(wú)需獲取access_token」,調(diào)用起來(lái)還是比較簡(jiǎn)單的。

原本打算在文章同步的時(shí)候「adminService」直接生成對(duì)應(yīng)文章的小程序碼,代碼寫(xiě)完后本地調(diào)試可以,但上傳至云端后測(cè)試發(fā)現(xiàn)一直報(bào)錯(cuò),逛了輪胎才知道原來(lái)不支持,同時(shí)觸發(fā)器也不支持云調(diào)用,所以這個(gè)計(jì)劃泡湯了,我在代碼中打了TODO。

既然這樣,那就在生成海報(bào)的時(shí)候進(jìn)行生成,同時(shí)生成后直接上傳至云存儲(chǔ),將對(duì)應(yīng)的FileID保存至文章集合中,這樣只用生成一次就可以一直使用了,具體代碼如下:

/**

 * 新增文章二維碼

 * @param {} event 

 */

async function addPostQrCode(event)

{

  let scene = "timestamp=" + event.timestamp;

  let result = await cloud.openapi.wxacode.getUnlimited({

?    scene: scene,

?    page: "pages/detail/detail"

  })



  if (result.errCode === 0) {

?    let upload = await cloud.uploadFile({

?      cloudPath: event.postId + ".png",

?      fileContent: result.buffer,

?    })



?    await db.collection("mini_posts").doc(event.postId).update({

?      data: {

?        qrCode: upload.fileID

?      }

?    });



?    let fileList = [upload.fileID]

?    let resultUrl = await cloud.getTempFileURL({

?      fileList,

?    })

?    return resultUrl.fileList

  }



  return []



}

但這里有個(gè)尷尬的地方是,生成小程序碼的api中的scene參數(shù)最大長(zhǎng)度是32,而文章id的長(zhǎng)度已經(jīng)是32了,無(wú)法根據(jù)文章id進(jìn)行拼接跳轉(zhuǎn)頁(yè)面的路徑了,所以這里暫時(shí)用了mini_posts集合中timestamp字段「理論上也是唯一的」。

所以在詳情頁(yè)中也需要兼容timestamp這個(gè)字段。

海報(bào)圖片展示

海報(bào)圖片展示就比較簡(jiǎn)單了,使用個(gè)彈窗,將生成好的海報(bào)圖片進(jìn)行展示即可:

  /**

   * 生成海報(bào)成功-回調(diào)

   * @param {} e 

   */

  onPosterSuccess(e) {

?    const { detail } = e;

?    this.setData({

?      posterImageUrl: detail,

?      isShowPosterModal: true

?    })

?    console.info(detail)

  },
保存海報(bào)圖片

保存圖片使用wx.saveImageToPhotosAlbum調(diào)用用戶相冊(cè),這里主要需要兼容用戶拒絕相冊(cè)授權(quán)的一些列操作,具體代碼如下:

  /**

  * 保存海報(bào)圖片

  */

  savePosterImage: function () {

?    let that = this

?    wx.saveImageToPhotosAlbum({

?      filePath: that.data.posterImageUrl,

?      success(result) {

?        console.log(result)

?        wx.showModal({

?          title: "提示",

?          content: "二維碼海報(bào)已存入手機(jī)相冊(cè),趕快分享到朋友圈吧",

?          showCancel: false,

?          success: function (res) {

?            that.setData({

?              isShowPosterModal: false,

?              isShow: false

?            })

?          }

?        })

?      },

?      fail: function (err) {

?        console.log(err);

?        if (err.errMsg === "saveImageToPhotosAlbum:fail auth deny") {

?          console.log("再次發(fā)起授權(quán)");

?          wx.showModal({

?            title: "用戶未授權(quán)",

?            content: "如需保存海報(bào)圖片到相冊(cè),需獲取授權(quán).是否在授權(quán)管理中選中“保存到相冊(cè)”?",

?            showCancel: true,

?            success: function (res) {

?              if (res.confirm) {

?                console.log("用戶點(diǎn)擊確定")

?                wx.openSetting({

?                  success: function success(res) {

?                    console.log("打開(kāi)設(shè)置", res.authSetting);

?                    wx.openSetting({

?                      success(settingdata) {

?                        console.log(settingdata)

?                        if (settingdata.authSetting["scope.writePhotosAlbum"]) {

?                          console.log("獲取保存到相冊(cè)權(quán)限成功");

?                        } else {

?                          console.log("獲取保存到相冊(cè)權(quán)限失敗");

?                        }

?                      }

?                    })



?                  }

?                });

?              }

?            }

?          })

?        }

?      }

?    });

  },
體驗(yàn)總結(jié)

有好的開(kāi)源組件可以充分利用,避免重復(fù)造輪子,有機(jī)會(huì)也可以學(xué)習(xí)下別人的實(shí)現(xiàn)方式。

多看看文檔,其實(shí)小程序的文檔真的挺詳細(xì)的。

這里主要想分享實(shí)現(xiàn)一個(gè)功能實(shí)現(xiàn)的過(guò)程,有想法的時(shí)候如何一步步去成功實(shí)現(xiàn)。

小程序本身不難,相應(yīng)的文檔也很詳細(xì),但是組裝的過(guò)程和邏輯的實(shí)現(xiàn)需要自身去思考和體會(huì)。多看看文檔,其實(shí)小程序的文檔真的挺詳細(xì)的。

如果你的想法和流程都非常清晰,但還是沒(méi)辦法實(shí)現(xiàn)你的預(yù)期功能,那我建議你先放放,先把html,css,javascript熟悉下,再看幾遍小程序的文檔,也許你當(dāng)時(shí)面臨的問(wèn)題就不再是問(wèn)題了。

源碼鏈接

https://github.com/TencentCloudBase/Good-practice-tutorial-recommended

如果你有關(guān)于使用云開(kāi)發(fā)CloudBase相關(guān)的技術(shù)故事/技術(shù)實(shí)戰(zhàn)經(jīng)驗(yàn)想要跟大家分享,歡迎留言聯(lián)系我們哦~比心!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/106975.html

相關(guān)文章

  • 程序·開(kāi)發(fā)打造功能全面博客程序實(shí)戰(zhàn)

    摘要:用小程序云開(kāi)發(fā)將博客小程序常用功能一網(wǎng)打盡本文介紹博客小程序的詳情頁(yè)的功能按鈕如何實(shí)現(xiàn),具體包括評(píng)論點(diǎn)贊收藏和海報(bào)功能,這里記錄下整個(gè)實(shí)現(xiàn)過(guò)程和實(shí)際編碼中的一些坑。考慮到小程序本身的大小限制,使用的方式是最佳的。 用小程序·云開(kāi)發(fā)將博客小程序常用功能一網(wǎng)打盡 本文介紹mini博客小程序的詳情頁(yè)的功能按鈕如何實(shí)現(xiàn),具體包括評(píng)論、點(diǎn)贊、收藏和海報(bào)功能,這里記錄下整個(gè)實(shí)現(xiàn)過(guò)程和實(shí)際編碼中的一...

    cc17 評(píng)論0 收藏0
  • 程序·開(kāi)發(fā)實(shí)現(xiàn)郵件發(fā)送功能實(shí)戰(zhàn)

    摘要:七調(diào)用云函數(shù)發(fā)送郵件我們?cè)谖募飳?xiě)一個(gè)按鈕,當(dāng)點(diǎn)擊這個(gè)按鈕時(shí)就發(fā)送郵件。到這里我們就完整的實(shí)現(xiàn)了微信小程序云開(kāi)發(fā)使用云函數(shù)發(fā)送郵件的功能了。 先看效果圖: showImg(https://segmentfault.com/img/remote/1460000020151412); 通過(guò)上面的日志,可以看出我們是158開(kāi)頭的郵箱給250開(kāi)頭的郵箱發(fā)送郵件,下面是成功接收到的郵件。 sho...

    sixgo 評(píng)論0 收藏0
  • 程序·開(kāi)發(fā)兩天搭建mini論壇實(shí)戰(zhàn)

    摘要:筆者最近涉獵了小程序相關(guān)的知識(shí),于是利用周末時(shí)間開(kāi)發(fā)了一款類似于同事的小程序,深度體驗(yàn)了小程序云開(kāi)發(fā)模式提供的云函數(shù)數(shù)據(jù)庫(kù)存儲(chǔ)三大能力。 筆者最近涉獵了小程序相關(guān)的知識(shí),于是利用周末時(shí)間開(kāi)發(fā)了一款類似于同事的小程序,深度體驗(yàn)了小程序云開(kāi)發(fā)模式提供的云函數(shù)、數(shù)據(jù)庫(kù)、存儲(chǔ)三大能力。關(guān)于云開(kāi)發(fā),可參考文檔:小程序·云開(kāi)發(fā)。 個(gè)人感覺(jué)云開(kāi)發(fā)帶來(lái)的最大好處是鑒權(quán)流程的簡(jiǎn)化和對(duì)后端的弱化,所以像筆...

    沈建明 評(píng)論0 收藏0
  • 工具推薦推薦又拍web版API管理工具,一款輔助使用又拍輕量工具

    摘要:沒(méi)想到會(huì)找到其他開(kāi)發(fā)者針對(duì)又拍云開(kāi)發(fā)又拍云管理工具這樣的工具,我個(gè)人覺(jué)得也算是又拍云在接口方面比較開(kāi)放的一個(gè)的案例吧。 今年上半年,我通過(guò)又拍云搭建了一個(gè)獨(dú)立博客,不久之后就遇到了很多實(shí)際問(wèn)題:網(wǎng)上看到圖片想收藏到空間,YouTube上的MV想放到自己的博客,想對(duì)一段音視頻進(jìn)行在線預(yù)覽和編輯……當(dāng)時(shí)我查了下,必須要通過(guò)API接口編寫(xiě)一段程序才能完成(不是程序猿,搭建獨(dú)立博客已經(jīng)要了我半...

    adam1q84 評(píng)論0 收藏0
  • 10行代碼實(shí)現(xiàn)程序支付功能實(shí)戰(zhàn)

    摘要:前面給大家講過(guò)一個(gè)借助小程序云開(kāi)發(fā)實(shí)現(xiàn)微信支付的,但是那個(gè)操作稍微有點(diǎn)繁瑣,并且還會(huì)經(jīng)常出現(xiàn)問(wèn)題,今天就給大家講一個(gè)簡(jiǎn)單的,并且借助官方支付實(shí)現(xiàn)小程序支付功能。只需要一個(gè)簡(jiǎn)單的云函數(shù),就可以輕松的實(shí)現(xiàn)微信小程序支付功能。 前面給大家講過(guò)一個(gè)借助小程序云開(kāi)發(fā)實(shí)現(xiàn)微信支付的,但是那個(gè)操作稍微有點(diǎn)繁瑣,并且還會(huì)經(jīng)常出現(xiàn)問(wèn)題,今天就給大家講一個(gè)簡(jiǎn)單的,并且借助官方支付api實(shí)現(xiàn)小程序支付功能。...

    SimpleTriangle 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<