重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
這篇文章將為大家詳細講解有關微信小程序間怎么使用navigator跳轉傳值,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
站在用戶的角度思考問題,與客戶深入溝通,找到瀘州網站設計與瀘州網站推廣的解決方案,憑借多年的經驗,讓設計與互聯網技術結合,創造個性化、用戶體驗好的作品,建站類型包括:成都網站設計、成都做網站、企業官網、英文網站、手機端網站、網站推廣、國際域名空間、雅安服務器托管、企業郵箱。業務覆蓋瀘州地區。
前言
這次講一下我用 navigator 組件實現從一個小程序跳轉到另一個小程序的過程中遇到的問題。
extra-data 如何構建
由于上網查資料得知 extra-data 是 json 格式。那么就不能在 HTML 屬性中直接寫。
那么剩下只有在 JS 里構建了。
首先在 HTML 里,綁定 extra-data的值到 extra 變量
然后在 JS 里構建這個變量
Page({ data: { extra: { "color": '', // 動態獲取 "partnerUsername": '99', }, }, })
這里有個問題,就是如果 extra 里的 color 等變量是動態從遠程 api 獲取到的,那么應該怎么賦值。
我憑直覺寫 extra.color = 'xx' ,嘗試了下不行。查閱資料發現,應該這么寫:
wx.request({ url: url, data: { color: '', }, header: { 'content-type': 'application/json' }, success: function (res) { that.setData({ "extra.color": app.globalData.color, }); } });
還可以在 path 屬性值后面跟參數來向目標小程序傳值
通過搜索發現[這篇文章](https://cloud.tencent.com/developer/article/1157552),我試了他給出的解決方案,是可行的,現在記錄在下面:
// 源小程序 this.setData({ colorSet: app.globalData.color, partner: app.globalData.partnerUsername, });
// 目標小程序 onShow: function (options) { console.log(options.query.color + options.query.partner); }
奇怪的問題(可能是bug):打開調試時,目標小程序能獲取到動態的 extra-data,關閉后無法獲取到
原因是我沒配合法域名,所以動態從 api 獲取的數據獲取不到。
關于“微信小程序間怎么使用navigator跳轉傳值”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。