轉發的意義
官方轉發示例
onShareAppMessage(Object)
監聽用戶點擊頁面內轉發按鈕(<button> 組件 open-type="share")或右上角菜單“轉發”按鈕的行為,并自定義轉發內容。注意:只有定義了此事件處理函數,右上角菜單才會顯示“轉發”按鈕
Object 參數說明:
此事件需要 return 一個 Object,用于自定義轉發內容,返回內容如下:
自定義轉發內容
Page({ onShareAppMessage(res) { if (res.from === 'button') { // 來自頁面內轉發按鈕 console.log(res.target) } return { title: '自定義轉發標題', path: '/page/user?id=123' } }})
常規轉發,只需上面示例即可
根據場景值區分
App({ onShow(res) { console.log('app---onShow'); console.log(res.scene); //1044是群聊,1007是私聊 }})
wx.onAppShow(function callback)
基礎庫 2.1.2 開始支持,低版本需做兼容處理
監聽小程序切前臺事件。該事件與 App.onShow 的回調參數一致
Object res
referrerInfo 的結構
返回有效 referrerInfo 的場景
注意
部分版本在無referrerInfo的時候會返回 undefined,建議使用 options.referrerInfo && options.referrerInfo.appId 進行判斷
小程序分享票據shareTickets
通常開發者希望轉發出去的小程序被二次打開的時候能夠獲取到一些信息,例如群的標識?,F在通過調用 wx.showShareMenu 并且設置 withShareTicket 為 true ,當用戶將小程序轉發到任一群聊之后,此轉發卡片在群聊中被其他用戶打開時,可以在 App.onLaunch 或 App.onShow 獲取到一個 shareTicket。通過調用 wx.getShareInfo() 接口傳入此 shareTicket 可以獲取到轉發信息。
//分享前share.jsPage({ onLoad: function () { wx.showShareMenu({ withShareTicket: true }) }})//分享后app.jsApp({ onShow(res) { console.log('app---onShow'); console.log(res.shareTicket); }})
注意:注意:注意
鑒于官方“分享監聽”能力調整,網上90%的滯后代碼,誤人子弟,在此必須給自己一個小要求,定期復讀自己的文章,根據當時能力水平,提高文章質量,修正錯誤和滯后信息(吐槽一下度娘已死,沒人打我吧?打我就刪除)
類似如下代碼,現在已不支持回調
此次調整可能影響到三種分享功能的用法
第一種:判斷用戶是否分享成功,進而給予用戶獎勵。
例如:小程序提示用戶“分享到5個群,可以獲得一張20元的優惠券”。
這類誘導用戶分享的行為是我們平臺所不倡導的,后續將沒有辦法實現。
第二種:分享完成后變更當前的頁面狀態
例如:贈送禮品場景下,用戶點擊“贈送”按鈕,將禮品分享出去,分享成功后,界面展示“等待領取”。
這類場景,我們建議可以適當調整交互方案。例如在分享后繼續保留“贈送”按鈕,但在頁面上提示用戶一個禮品只能被一人領取,重復贈送無效。
第三種:通過用戶分享之后的 shareTicket 獲取群唯一標識 openGId ,以顯示對應群的相關信息。
例如:通過分享小程序到某個群里,可以查看該群內成員的排行榜。
此次調整后,用戶分享完成后無法立刻顯示該群的排行榜信息,但仍可在用戶從群消息點擊進入小程序時顯示該群的排行榜信息。
詳情請查看分享監聽能力調整
轉發動態消息
從基礎庫 2.4.0 開始,支持轉發動態消息。動態消息對比普通消息,有以下特點:
簡要步驟如下
像拼團這樣的活動,可以考慮優化成動態消息,需要后端配合,實戰的時再補充
總結
分享監聽能力調整后,對于分享的騷操作基本在App.onShow中進行,相當于授權那樣,必須打開轉發消息才能獲取轉發詳情,這也是符合設計準則的
可以看出,不管是從設計準則,還是用戶隱私,微信都在向著IOS看齊,黑暗法則已過去,我們也該注重規范和隱私了
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答