日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

微信小程序之启动页的重要性

發布時間:2024/3/24 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 微信小程序之启动页的重要性 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

啟動頁在APP中是個很常見的需求,為什么對于小程序來說也非常重要呢?首先我描述一下我在開發過程中遇到的一些問題以及解決的步驟,到最后為什么要加啟動頁,看完你就明白了。

小程序的首頁需要展示用戶關注的小區信息,意味著一打開小程序我就得先執行登錄的邏輯,只有登錄了之后才能獲取用戶關注的小區信息。

在小程序啟動的時候自動登錄,目前沒獲取用戶信息,所以不需要用戶授權,這個邏輯放在根目錄下的app.js的onLaunch方法中。只要啟動小程序就會執行onLaunch方法。

做完之后發現了一個很嚴重的問題,就是app.js的onLaunch方法確實會在小程序啟動的時候執行,但是首頁也會是在app.json文件的pages中第一個頁面也會同時執行,它不是阻塞的。會導致一個問題就是首頁獲取關注信息執行完了,登錄的邏輯還沒完,獲取不到正確的數據。

于是把登錄的邏輯放到首頁的onLoad方法中執行,在登錄成功之后再去獲取關注的數據,這樣就能解決上面說的問題了。

后面又有一個需求,就是分享功能,分享出去的頁面中也需要用到用戶信息,這個就尷尬了,分享出去的頁面,用戶進入的時候還是進入的這個頁面,不會執行首頁的邏輯,是拿不到用戶信息的。

后面想了下,還是增加一個啟動頁來做中轉吧,登錄的邏輯還是放到app.js中,只要小程序啟動了就可以執行,無論是第一次進入還是通過分享的頁面進入,都可以自動登錄。

問題是如何實現阻塞功能,就是登錄之后再去跳轉到其它的頁面,思路就是通過定時器的方式去檢測登錄狀態,成功了之后再跳轉。

分享也是一樣,分享出去的地址不再是本頁面的地址,而是啟動頁的地址,帶一個參數,這個參數才是本頁面的地址,當用戶點擊分享的小程序進入之后會先進入啟動頁,啟動頁中獲取參數,等待登錄邏輯執行完成之后,再根據參數跳轉到分享的頁面。

啟動頁代碼:

onLoad: function (e) {var url = '/pages/index/index'// 分享頁面參數解碼if (e.page != undefined && e.page != "") {url = decodeURIComponent(e.page)}var count = 0; var inter = setInterval(() => {count++;if (count > 1000) {clearInterval(inter);wx.showToast({title: "網絡異常,請重啟小程序",icon: 'none',duration: 2000})return;}var token = wx.getStorageSync("login_token");if (token != null && token != "") {clearInterval(inter);// 跳轉到toolbarif (url == "/pages/index/index" || url == "/pages/city/cityAll/cityAll") {wx.switchTab({url: url})} else {// 跳轉到普通頁面wx.navigateTo({url: url,})}}},10);}

當檢查超過10秒鐘,登錄信息還獲取不到的時候就會給出提示,后續會加上一個讓用戶手動授權登錄的頁面。

這種方式勉強能實現需求,但不是最好的方式,問題一看就知道了,如果加了啟動頁,意味著所有的入口都變成了啟動頁,就沒有必要通過定時去檢測了,直接將登錄的邏輯放到啟動頁中來執行,在success中在做跳轉的邏輯,這樣的方式才是最好的,具體代碼我就不貼出來,大家明白就好。

具體的分享頁面代碼:

onShareAppMessage: function () {let that = thisvar page = encodeURIComponent('/pages/district/districtDetail/districtDetail?city=' + that.data.city + '&region=' + that.data.region + '&districtName=' + that.data.districtName + '&estateType=' + that.data.estateType + "&isshare=1")return {title: '小區詳情',path: '/pages/startPage/startPage?page='+page}}

重點關注isshare=1這個參數,當直接打開分享的頁面時,用戶點擊左上角的返回按鈕,基于現有的邏輯會退回到啟動頁,因為是從啟動頁中轉過來的,這是有問題的,要么就去掉這個返回按鈕,要么就返回到首頁。

所以對于分享的頁面帶了一個參數識別,當是從分享頁面進來的時候返回就到首頁面。具體邏輯在頁面的onUnload函數中,在頁面卸載的時候進行跳轉:

if (this.data.isshare == 1) {wx.switchTab({url: '/pages/index/index'}) }

以上就是啟動頁的作用以及需要啟動頁的一些背景,第一次開發小程序,總會碰到很多問題。

總結+分享=積累。

歡迎加入我的知識星球,一起交流技術,免費學習猿天地的課程(http://cxytiandi.com/course)

PS:目前星球中正在星主的帶領下組隊學習Sentinel,等你哦!

總結

以上是生活随笔為你收集整理的微信小程序之启动页的重要性的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日本一级大毛片a一 | 日韩久久免费视频 | 亚洲天堂一区在线观看 | 黄色小视频在线 | 天天综合天天综合 | av不卡一区二区三区 | 日韩专区在线 | 性欢交69国产精品 | 国产精品免费无码 | 91国内精品 | 男男黄网站 | 久久黄色小视频 | 中文字幕在线播放视频 | 亚洲综合在线网 | 久国产精品 | 人人爽人人爽人人片 | 我要看18毛片 | 欧美a级肉欲大片xxx | 国产毛茸茸| 三级免费观看 | 天天爽夜夜爽夜夜爽精品视频 | 欧美日韩一区不卡 | 久久免费视频一区 | 欧美黄色大全 | 91丨九色丨蝌蚪丨丝袜 | 亚洲精品综合久久 | 亚洲婷婷综合网 | jizz日本18 | 波多野结衣99 | 深夜av在线| 特黄三级又爽又粗又大 | 欧美韩一区| 免费在线性爱视频 | 国产青青草视频 | 午夜av不卡 | 欧美日韩一区二区在线观看 | 国产精品自拍视频一区 | 大尺度做爰床戏呻吟舒畅 | 在线电影一区二区三区 | 亚洲欧美日韩精品久久 | 日韩草逼视频 | 狠狠夜夜 | 久久久www | 黄色性网站 | 徐锦江一级淫片免费看 | 色噜噜噜 | 亚洲一区中文字幕在线观看 | 精品亚洲一区二区三区四区五区 | 干骚视频| 国产人人射| 欧美激情一级精品国产 | 亚洲国产aⅴ精品一区二区 日韩黄色在线视频 | 日韩欧美中文在线观看 | 韩国伦理片在线播放 | 日韩欧美大片在线观看 | 久久久99精品 | 卡通动漫精品一区二区三区 | 色小妹av | 产乳奶汁h文1v1 | 美女写真福利视频 | 色综合天天网 | 亚洲va在线∨a天堂va欧美va | 一区二区三区在线免费视频 | 国产资源av | 国产a级大片 | 亚洲欧美色图视频 | 精品国产一区二区三区四区阿崩 | 毛片久久久久久久 | 性毛片 | 黄色小视频免费看 | av男人的天堂网 | caoporn超碰97| 丰满秘书被猛烈进入高清播放在 | 蜜美杏av | 国内毛片毛片毛片毛片毛片 | 黄色永久视频 | 美女扒开尿口让男人爽 | 永久免费av无码网站性色av | 欧美日韩一区二区视频观看 | 国产剧情久久久 | 天天综合天天添夜夜添狠狠添 | 精品亚洲国产成av人片传媒 | 91成人国产| 在线黄网站| 激情总合网| 黄色免费视频网站 | 美女被娇喘流出白 | jizzjizz日本人| 久久精品99久久久久久久久 | 国产男女视频在线观看 | 五月婷婷综合久久 | 写真福利片hd在线播放 | 国产精品69久久 | 青青国产精品视频 | 一区二区不卡视频 | 国产91丝袜在线播放 | 久久婷婷综合国产 | 亚洲影视在线观看 | 欧美日韩极品 |