主頁 > 移動端開發 > 小程式用webview內嵌h5頁面,實作分享、微信支付功能 , h5傳參跳轉web-view 微信小程式

小程式用webview內嵌h5頁面,實作分享、微信支付功能 , h5傳參跳轉web-view 微信小程式

2020-12-03 10:13:24 移動端開發

小程式用webview內嵌h5頁面,實作分享、微信支付功能 ,h5傳參跳轉web-view 微信小程式

前幾天公司頭目給了我個任務 ,用小程式的web view組件來嵌入h5頁面 還要實作小程式右上角的分享功能 ,最重要的是呼叫微信支付(小程式中不能使用之前在瀏覽器中配置的支付功能,只能呼叫小程式專屬的api進行支付,) 接到到這個任務,內心還是很開心的,因為…我愛學習啊啊啊,話不多說,進入正題,

web-view:承載網頁的容器,會自動鋪滿整個小程式頁面,個人型別的小程式暫不支持使用 它有三個比較重要的屬性 src bindmessage bindload ,
web view詳情鏈接
先說說整體思路吧 小程式只要有三個頁面就夠了
1.小程式啟動時默認打開的頁面
2.小程式點擊右上角分享 的頁面
3.webview嵌入的h5頁面 當發起支付時會跳轉到wxpay頁面 ,呼叫微信支付在這里插入圖片描述

乍一看挺簡單的 實際也不是太難,只是當時爬的坑比較多 結尾的時候會總結坑點,

實作步驟:

  1. 先在web view里引入H5頁面 此步驟比較簡單
  2. 引入頁面后實作右上角點擊分享功能 (提示:web view 不支持分享朋友圈)

具體實作步驟:

1.利用web view 將h5嵌入小程式

	//index.vue頁面  
	// 注意: @message 事件是uniapp中的web-viwe 小程式用的是 bindmessage  
	<web-view src="https://www.baidu.com/" @message="handlePostMessage"></web-view>
  • 這個步驟比較簡單 @message/ bindmessage 屬性的是用來接收h5傳遞過來的引數 分享時候會用到 下面會講

2.小程式點擊右上角分享

要實作分享功能需先了解 以下內容

  • onShareAppMessage(Object object)
    監聽用戶點擊頁面內轉發按鈕(button 組件 open-type=“share”)或右上角選單“轉發”按鈕的行為,并自定義轉發內容,
    注意:只有定義了此事件處理函式,右上角選單才會顯示“轉發”按鈕
  • web-view 是一個 web 瀏覽器組件,可以用來承載網頁的容器,會自動鋪滿整個頁面 里面有個屬性
    @message 網頁向應用 postMessage 時,會在特定時機(后退、組件銷毀、分享)觸發并收到訊息,
    注意:@message 是uniapp中web-viwe的屬性 小程式用的是 bindmessage (當時沒注意在這卡了一個小時)

在index.vue里面加如下代碼


	// 用戶點擊右上角分享  res.webViewUrl是跳轉時攜帶的引數 
	onShareAppMessage: function(res) {
		//console.log(res)里面會有個  res.webViewUrl 指的是當前所在頁面的網址
		return {
			//  path --必打開分享時跳轉到的頁面  默認是當前頁面,必須是以‘/’開頭的完整路徑
			//  title -- 設定轉發時的標題  默認是小程式的名稱
			//  imageUrl -- 設定轉發時的圖片   不傳入 imageUrl 則使用默認截圖,
			path: '/pages/share/share?url=' + encodeURIComponent(res.webViewUrl) 
		};
	},		
		

在share.vue中添加如下代碼


	<web-view :src="h5url" @message="handlePostMessage"></web-view>

script添加以下代碼

	//接收引數 onShareAppMessage 中path 傳過來的引數
	onLoad: function(e) {
		this.h5url = decodeURIComponent(e.url) 
	}

以上步驟解釋:
說白了就是小程式需要從index頁面 跳到了share頁面 , index用到了 onShareAppMessage 來進行頁面的跳轉 , share用onLond 接收引數并賦值給自己頁面的web-view

  • index中的web view是打開小程式首次引入的頁面,用戶點擊右上角分享 后通過onShareAppMessage里面的 path路徑跳入到 share.vue頁面,
  • share.vue 用onLond 接收引數 把接收到的引數(網址)放入到 share.vue 里web-viw組件中的 src屬性下 然后點擊右上角分享功能就實作了,
  • 用到了encodeURIComponent /decodeURIComponent 是防止傳參時遇見特殊字符會亂碼問題

以上步驟未用到H5 給小程式傳參 如需使用H5傳遞引數實作分享還需在H5添加以下代碼


		//思路:先判斷環境 再執行 wx.miniProgram.postMessage();
	    var ua = navigator.userAgent.toLowerCase();
		if(ua.match(/MicroMessenger/i)=="micromessenger") {
			//ios的ua中無miniProgram,但都有MicroMessenger(表示是微信瀏覽器)
			wx.miniProgram.getEnv((res)=>{   
			if (res.miniprogram) {
        wx.miniProgram.postMessage({ data: data });
			}else{
			alert('在微信內,但是不在小程式內')
			return false;
			}
		})
		}else{
			console.log('在微信外')
		}    
		

3.在小程式中呼叫微信支付功能

呼叫微信支付原因上面已經做過解釋 想要實作功能之前的先搞懂小程式支付流程 小程式支付流程

H5調起微信支付時 用wx.miniProgram.navigateTo 設定跳到 wxpay頁面

wxpay.vue頁面


<template>
	//h5調起微信支付時會跳到 wxpay頁面 
</template>

<script>
export default {
	data() {
		return {};
	},
	created() {},
	methods: {
	
		// 生命周期函式--監聽頁面卸載
		onUnload :function() {} //支付完成后 手機左滑時會出現很尷尬的事 相信你會用到這個生命周期 原理不解釋了 寫了幾個小時沒精力了
		
		//生命周期函式--監聽頁面加載 
		onLoad: function(option) {
			if (option) {
			//option 有H5頁面傳遞過來的資料
				this.setLoading(option);
			} else {
				wx.navigateBack();
			}
			// console.log(option);
		},

		setLoading: function(option) {
			var that = this;
			// 呼叫登錄介面獲取openid
			wx.login({
				success: function(res) {
					// 成功會回傳: {errMsg: "login:ok", code: " 獲取用戶OpenID的ticket"}
					that.getOpenId(res.code, option);
					// console.log(res);
				}
			});
		},
		
		getOpenId: function(jsCode, option) {
			var that = this;
			var params = {};  //這里就是調介面拼湊要給后端提供的引數 
			params.key = option.key,
				params.pay_sn = option.pay_sn,
				params.password = option.password,
				params.rcd_pay = option.rcb_pay,
				params.pd_pay = option.pd_pay,
				params.integral = option.integral,
				params.payment_code = option.payment_code,
				params.payment_jscode = jsCode,  //把獲取到的code傳給后端 (必須)到時候退款也會涉及到 
			wx.request({ 
				url: 'https://www.xxx.com/mobile' + '/index.php?act=member_payment&op=wxa_pay', //引入的https地址
				method: 'post',
				header: {
					'content-type': 'application/x-www-form-urlencoded' // 默認值
				},
				data: params,  //傳遞的引數 后端會回傳一部分 你這里只需要吧 獲取用戶OpenID的ticket"
				success: function(res) {
					that.getPrePayId(res.data.datas);
				},
				fail: function(res) {
					console.log(res);
					wx.showModal({ title: '網路超時', content: '重繪重試', showCancel: !1 });
				}
			});
		},

		getPrePayId: function(res) {
			var that = this;
			wx.requestPayment({
				//成功之后,呼叫小程式微信支付
				timeStamp: res.timeStamp,
				nonceStr: res.nonceStr,
				package: res.package,
				signType: res.signType,
				paySign: res.paySign,
				success: function(res) {
					wx.showToast({
						title: '支付成功',
						icon: 'success',
						duration: 1650
					}),
					console.log('支付成功');
				},
				fail: function() {
					wx.showToast({
						title: '支付失敗',
						icon: 'clear',
						duration: 1650
					}),
					console.log('支付失敗');
				}
			});
		}
	}
};
</script>

H5代碼


    // 小程式支付函式
	mini_program_pay  =  function (queryParam ) {
	
	  var ua = navigator.userAgent.toLowerCase();
	  if(ua.match(/MicroMessenger/i)=="micromessenger") {
	     //ios的ua中無miniProgram,但都有MicroMessenger(表示是微信瀏覽器)
	    wx.miniProgram.getEnv((res)=>{   
	      if (res.miniprogram) {
	        console.log('在小程式內')
	        wx.miniProgram.navigateTo({                                
	          url: "/pages/wxpay/wxpay?"+queryParam       //小程式的支付地址,queryParam是需要傳遞的商品id等資料
	        });
	        return false;
	     }else{
	       console.log('在微信內,但是不在小程式內')
	       return false;
	     }
	   })
	  }else{
	    console.log('在微信外')
	    return false;
	  }    
	};
	

寫的時間太長了 有些暈 簡短的說下重點步驟吧 ! 注釋其實說的挺多的,比較詳細

H5要在使用wx.miniProgram.navigateTo 攜帶引數 跳轉到小程式的wxpay頁面 跳轉需要引入js-sdk才可以跳轉 去官網查下最新版本 不然可能會不成功

  • H5傳遞過來的引數 wxpay還是用onload接收 (后端需要什么資料 在H5頁面搜集好 直接傳遞過去就行了)
  • 然后wx.login() 獲取的code 一定要傳遞給后端 , 會涉支付及退款問題

其實支付這塊稍微復雜一些 但前端做的事情比較少 , 后端復雜一些.,前端只需要去H5搜集引數傳給小程式,小程式在wx.login()獲取到code 然后再調介面拼接資料,最后wx.requestPayment 直接拉起微信支付就好了

寫到這微信支付也就告一段落了 ~~~

在總結一下 遇到的各種問題吧 !

  • 微信開發者工具會有快取 除錯的時候多清清!有時候實作不了功能可能是快取問題
  • 微信開發者工具除錯時可以出現跳轉, 而真機除錯不能實作時 也可嘗試清快取, 也可以嘗試運行在瀏覽器端 如果 瀏覽器出現頁面無限跳轉 一定是H5D端 判斷是否是微信環境出了問題 ,我清快取用的是url后邊加時間戳
  • 如果在掃描體驗版進入小程式時 頁面不加載 點擊左上角的小房子圖示會重繪 說明體驗版二維碼不對 仔細查看指定路徑
  • 如果頁面不跳轉或者是接受不到引數 仔細耐心多看檔案.
  • index中的 src末尾得加.html 不然體驗版會出現一些小問題.
  • wx.requestPayment 拼接引數時得按一定的順序
  • 還有些想起來在補充吧 我該去吃飯了 ~~

就這三個功能折磨我的時間挺長的 ! 爬了無數的坑 終于實作了 (我引入的H5頁面還是用JQuery+template模板寫的 )所以當時遇到的問題比較多 快自閉了 希望你們能順利一些吧!
如果后期有精力后期再補充爬過的坑,我也是站在了巨人的肩膀上 所以再次感謝一下 大佬的文章
以上有很多地方都是借鑒 這位大佬的 再次感謝 ~~
初識前端 ,希望能與各位同仁多多交流討論,

https://www.cnblogs.com/wangvv/p/13646057.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/229240.html

標籤:其他

上一篇:2020 1212 TM 雙十二自動獲取喵幣腳本

下一篇:NDK&JNI開發總結

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more