微信小程序公共方法封裝之全局分享實(shí)現(xiàn)拉新綁定(用戶關(guān)系綁定)

需求:在小程序多個(gè)頁面中,均存在點(diǎn)擊分享操作,需要在分享里加入當(dāng)前用戶信息,實(shí)現(xiàn)分享綁定

剛上手小程序的時(shí)候是在原有的架子上面新增功能,因?yàn)闀r(shí)間較緊,而且需求并不是同時(shí)提出的,就直接單獨(dú)寫的方法,但是當(dāng)新增加的頁面越來越多的時(shí)候每次的方法雖然大差不差,但是每次都多寫一遍也還是麻煩,就抽空整理一下封裝個(gè)公用的方法
我是直接把方法寫在App.js里面的,方便調(diào)用,方法中預(yù)留了判斷當(dāng)前分享是分享給單人還是分享到群組的判斷,因?yàn)槟壳绊?xiàng)目暫時(shí)沒有用到,但是不確定以后會(huì)不會(huì)需要,所以提前留了注釋,示例代碼如下:
App.js

share: function (title, path, imageUrl) {
        //設(shè)置一個(gè)默認(rèn)分享背景圖片
        let defaultImageUrl = '//upload.jianshu.io/admin_banners/web_images/4613/e96eece16a9e3ae1699dd4bd0002666c571c30f5.jpeg?imageMogr2/auto-orient/strip|imageView2/1/w/1250/h/540';
        this.globalData.userInfo && this.globalData.userInfo.IsReferral && (path += "&ReferralUserId=" + this.globalData.userInfo.UserId)
        return {
            title: title || '加入VIP,能省會(huì)賺,最高返40%!',
            path: path,
            imageUrl: imageUrl || defaultImageUrl,
            // success(res) {
            //     console.log("轉(zhuǎn)發(fā)成功!");
            //     if (!res.shareTickets) {
            //         //分享到個(gè)人
            //         api.shareFriend().then(() => {
            //             console.warn("shareFriendSuccess!");
            //             //執(zhí)行轉(zhuǎn)發(fā)成功以后的回調(diào)函數(shù)
            //             callback && callback();
            //         });
            //     } else {
            //         //分享到群
            //         let st = res.shareTickets[0];
            //         wx.getShareInfo({
            //             shareTicket: st,
            //             success(res) {
            //                 let iv = res.iv
            //                 let encryptedData = res.encryptedData;
            //                 api.groupShare(encryptedData, iv).then(() => {
            //                     console.warn("groupShareSuccess!");
            //                     //執(zhí)行轉(zhuǎn)發(fā)成功以后的回調(diào)函數(shù)
            //                     callback && callback();
            //                 });
            //             }
            //         });
            //     }
            // },
            // fail: function(res) {
            //     console.log("轉(zhuǎn)發(fā)失??!");
            // }
        };
    },

調(diào)用方法(ps:只有path是必傳項(xiàng),其他兩項(xiàng)可以在app.js中設(shè)置默認(rèn)值,因?yàn)檩^多地方可能使用的同樣的title或者同樣的默認(rèn)分享圖)

var title = tm.data.mainTitle;
var imageUrl = tm.data.brandRushInfo[0].goodsImages[0];
var brandId = tm.data.brandRushInfo[0].brandId;
var brandSource = tm.data.brandRushInfo[0].brandSource;
var lower = (tm.data.brandRushInfo[0].lowerDiscount / 10).toFixed(1)
var path = '/pages/brandInfo/brandInfo?brandId=' + brandId + "&brandSource=" + brandSource
title = '【品牌特賣】' + title + ' ' + lower + '折起'
app.share(title, path, imageUrl)

謹(jǐn)以此文獻(xiàn)給正在開發(fā)崗位上奮斗爬坑的有志青年! 共勉

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標(biāo)準(zhǔn)。 注意:講述HT...
    kismetajun閱讀 28,801評(píng)論 1 45
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,631評(píng)論 1 32
  • 因新工作主要負(fù)責(zé)微信小程序這一塊,最近的重心就移到這一塊,該博客是對(duì)微信小程序整體的整理歸納以及標(biāo)明一些細(xì)節(jié)點(diǎn),初...
    majun00閱讀 7,633評(píng)論 0 9
  • 1.小程序起步 (1)點(diǎn)擊https://mp.weixin.qq.com/wxopen/waregister?a...
    GXW_Lyon閱讀 3,596評(píng)論 0 0
  • 昨夜,學(xué)生作業(yè)之重,又至深夜十二時(shí),身體累之,精神倦之。作業(yè)之殤非學(xué)業(yè),填鴨之行為,循規(guī)蹈矩使之。月明星稀伴燈...
    圓又圓店閱讀 175評(píng)論 0 0

友情鏈接更多精彩內(nèi)容