首頁 >微信小程式 >小程式開發 >淺析如何從小程式跳到H5頁? (範例解析)

淺析如何從小程式跳到H5頁? (範例解析)

青灯夜游
青灯夜游轉載
2022-01-18 10:01:5614952瀏覽

如何從小程式跳到H5頁面?以下這篇文章跟大家介紹一下微信小程式跳到H5頁面的方法,希望對大家有幫助!

淺析如何從小程式跳到H5頁? (範例解析)

#微信小程式:雖然開發方法類似網頁,但實際上是一種只能運行在微信自己開發的瀏覽器中的特殊網頁,它所能夠使用的所有功能都必須由微信瀏覽器提供;

H5頁面:這是真正的網頁應用,運行在通用瀏覽器中,各種瀏覽器雖然在細微上有所差別,但總的來說是一致的,微信瀏覽器同時也是一種通用瀏覽器,能夠支援真正的網頁應用。

因此我們才有可能在微信小程式和H5頁面之間進行跳轉,但這種跳轉是受到微信瀏覽器的嚴格控制的,因此我們有必要了解這些控制包括哪些。

H5頁面所在的網域:假設你需要調轉的H5頁面URL為https://www.mysite.com/h5page,那麼這裡所說的網域就是www .mysite.com,另外你沒有看錯,這個URL必須是https,如果你還沒有為你的網站加上SSL,那麼就先去申請一個憑證吧(注意必須是公開申請的證書,不能是自簽名的,微信不認哦!)

好了,這些都準備好了,讓我們開始開發一個小例子。

由於web-view元件是一個全螢幕元件,不能和其它小程式元件合用,因此需要獨立佔據一個頁面,所以我們到例子就是在小程式的A頁加一個鏈接,跳到B頁面,然後在B頁面使用web-view元件來載入H5頁面。

A頁面

<view class="answerer flex-wrp" bindtap=&#39;jumpToH5&#39;>
        <view class="avatar flex-item">
            <image src="/images/logo-small.jpg"></image>
        </view>
        <view class="answerer-info flex-item">
            <text class="answerer-name">文章标题</text>
            <text class="answerer-des">文章摘要</text>
        </view>
        <view class="follow flex-item">
            <text>十 关注</text>
        </view>
</view>
jumpToH5: function () {
    wx.navigateTo({
      url: &#39;/pages/B&#39;
    })
  },

B頁面

<web-view src="{{link}}" bindmessage="getMessage"></web-view>
  data: {
    link: "https://www.mysite.com/h5page"
  },

這時候當你滿懷希望的點擊連結時,會出現第一個坎:未綁定網頁開發者

淺析如何從小程式跳到H5頁? (範例解析)

這是什麼鬼,原來使用web-view元件並不是啥人上來就允許使用的,這時候需要第一個授權,就是授權開發者使用該元件。這裡比較扯淡的是雖然這個元件是小程式使用的,但並不能在小程式開發號裡面設置,而必須在訂閱號服務號中進行設置,網絡上常常能夠查到的下面這個截圖只能登入訂閱號碼服務號碼才能看到。

淺析如何從小程式跳到H5頁? (範例解析)

在這裡設定綁定了開發者的微訊號以後,我們終於可以使用web-view元件了,不過這時候又出了新問題: 不支援開啟非業務網域名稱

淺析如何從小程式跳到H5頁? (範例解析)

原來不是什麼網址拿來就可以設定跳轉的,你的小程式中就無法直接跳到百度上去,小程式能夠跳轉的網域必須在業務網域中進行註冊,總算這次是在小程式開發號裡面設定了,但注意在服務號的設定裡也有業務網域這個設置,不要搞混了(話說微信起名也太沒有想像力了,簡直是一坨漿糊)。

設定好了這個業務域名,滿心歡喜地打開小程序,點擊鏈接,What!又來,這次的問題變成了:redirect_uri參數錯誤

淺析如何從小程式跳到H5頁? (範例解析)

這時候控制權已經從小程式轉移到了H5頁面,但微信頁面跳轉內部的機制比較複雜,牽涉到了OAuth認證之類的,所以這個錯誤已經是H5頁面報的了,這就需要到H5頁面關聯的服務號中去進行設置,這次設置的項目叫做網頁授權網域名稱,在公眾號設定的功能設定裡

淺析如何從小程式跳到H5頁? (範例解析)

加入好需要跳轉的網域之後,終於能夠看到H5頁出現在偵錯器上了!

最後普及一下微信公共平台三類帳號的區別

服務號碼:支援最多的Web開發接口和JS開發接口,是最常規的應用開發帳號;
訂閱號:發文章用的,開發介面比較少,很多功能都不支持,是最傻瓜的文章發布帳號;
小程式:小程式應用的專屬開發帳號,只支援對小程式的開發,有許多設定也必須到前兩類帳號去設定。

【相關學習推薦:小程式開發教學

以上是淺析如何從小程式跳到H5頁? (範例解析)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除