微信小程序與內(nèi)嵌網(wǎng)頁交互實(shí)現(xiàn)支付功能

上個月尤勋,小程序開放了新功能,支持內(nèi)嵌網(wǎng)頁规伐,所以我就開始了小程序內(nèi)嵌網(wǎng)頁之路蟹倾,之前我只是個小安卓。

小程序webview.PNG

內(nèi)嵌網(wǎng)頁中可使用JSSDK 1.3.0提供的接口猖闪,可坑就來了鲜棠,居然不支持支付接口的調(diào)用,經(jīng)過一番研究培慌,總算打通了兩邊的交互

大概流程

  1. 先說明涉及到的文件豁陆,下面會用到
    1.1 app.js:小程序的app.js文件,在globalData里定義一個全局變量paySuccessUrl: '',用來保存支付成功跳轉(zhuǎn)url
    1.2 wxmini_webview.js:小程序中放web-view的界面
    1.3 wxmini_pay.js:小程序原生支付界面
    1.4 web_pay.vue:內(nèi)嵌網(wǎng)頁會調(diào)起支付的路由組件界面,由于我是用vue+vue-router寫的吵护,所以你最好了解下vue和vue-router盒音,記得引入微信jssdk1.3.0,最新版本才包含小程序相對應(yīng)方法。很遺憾馅而,微信并沒提供npm包祥诽,github有人提供的commonjs引入方式的微信jssdk版本也只有1.2.0,所以就只能這樣引入了
<script src="./static/jweixin-1.3.0.js"></script>
  1. 首先我們像官網(wǎng)那樣正常嵌入一個內(nèi)嵌網(wǎng)頁,url是wxmini_webview.js中data中定義的變量,webview加載的就是網(wǎng)頁就是這個url
<web-view src="{{url}}"></web-view>
  1. 在內(nèi)嵌網(wǎng)頁web_pay.vue里判斷當(dāng)前是否是微信環(huán)境
window.wx.ready(function () {
    isWxMini = window.__wxjs_environment === 'miniprogram'
})
  1. 在內(nèi)嵌網(wǎng)頁web_pay.vue調(diào)用支付時把支付金額瓮恭,支付說明雄坪,支付成功跳轉(zhuǎn)url...(任何你想要的參數(shù),記得encodeURIComponent)偎血,傳給小程序原生頁面
if (isWxMini) {
    let jumpUrl = encodeURIComponent(window.location)
    let path = `/page/pay/pay?amount=${amount}&title=${desc}&jumpUrl=${jumpUrl}`
    window.wx.miniProgram.navigateTo({
        url: path
    })
 }
  1. 在小程序支付界面wxmini_pay.js里獲取到內(nèi)嵌網(wǎng)頁傳過來的值,這里演示方便,實(shí)際上是在page的data里存儲這些會顯示在界面的值好些
onLoad: function (options) {
    console.log(options)
    // 獲取網(wǎng)頁傳過來的值
    // TODO 用es6解構(gòu)來獲取值TODO
    jumpUrl = options.jumpUrl
    amount = options.amount
    title = options.title
    ...
  },
  1. 支付成功后,把跳轉(zhuǎn)url附帶支付結(jié)果及當(dāng)前時間保存到全局變量
paySuccess () {
    let currentTime = new Date().getTime()
    //這是為了防止wxmini_webview.js文件里調(diào)用setData時前后兩個url一致導(dǎo)致路由不觸發(fā)刷新的bug诸衔,不理解可繼續(xù)往下看,會解釋
    jumpUrl = options.jumpUrl+encodeURIComponent(`?payResult=1&time=${currentTime}`) 
    //payResult=1表示支付成功颇玷,這里我偷懶了直接在url后面補(bǔ)?,實(shí)際情況應(yīng)該考慮是否已經(jīng)有笨农?
    //為了實(shí)現(xiàn)支付成功返回后的無刷新加載,這里的參數(shù)應(yīng)該是屬于路由web_pay.vue的,而不是屬于window.location.search
    getApp().globalData.paySuccessUrl=jumpUrl //保存跳轉(zhuǎn)url到小程序全局變量里
    wx.navigateBack() //返回會上個頁面,也就是承載網(wǎng)頁的容器頁面wxmini_pay.js
}
  1. 回到小程序wxmini_webview.js,會觸發(fā)onshow,在里面進(jìn)行界面無刷新加載
onShow: function () {
    console.log('on show')
    let paySuccessUrl = getApp().globalData.paySuccessUrl
    getApp().globalData.paySuccessUrl="" //清空支付成功url帖渠,防止一些操作觸發(fā)onShow事件
    if (paySuccessUrl) {
      let url = decodeURIComponent(paySuccessUrl)
      this.setData({
      //這里在次說明下步驟6中的&time=${currentTime},就是因?yàn)椴患舆@個當(dāng)你第一次支付成功回來這里
      //這個url跟你第二次支付成功回來這里是一樣的谒亦,會導(dǎo)致第二次支付開始,這里的setData方法失效
        url 
      })
    }
  },
  1. 步驟7中的setData會觸發(fā)webview中的網(wǎng)頁加載空郊,由于我采用的是vue-router,而且前后兩個url只有路由的參數(shù)query不一樣份招,所以并不會觸發(fā)界面刷新,也不會觸發(fā)路由的重新加載狞甚,而是只會觸發(fā)beforeRouteUpdate 這個方法锁摔,舉個例子,現(xiàn)在支付前界面是https://host/#/pay,然后支付成功后跳轉(zhuǎn)https://host/#/pay?payResult=1&time=123456,此時界面不會刷新哼审,pay路由也不會重新加載谐腰,而是觸發(fā)beforeRouteUpdate (to, from, next),你要做的只是在這里界面解析to.query里的數(shù)據(jù)孕豹,然后該干嘛干嘛
beforeRouteUpdate (to, from, next) {
      console.log('路由發(fā)生改變,很有可能是小程序的支付成功回調(diào)')
      let payResult = to.query.payResult
      if (payResult) { // 小程序支付成功
        if (payResult === '1') {
          console.log('支付成功,下班打卡走人')
        }
      }
      next()
    },

這么晚了十气,先睡了励背,如果有空我再整理個demo,如果文章對你有幫助麻煩點(diǎn)個贊

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末砸西,一起剝皮案震驚了整個濱河市叶眉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌芹枷,老刑警劉巖衅疙,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異杖狼,居然都是意外死亡炼蛤,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進(jìn)店門蝶涩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來理朋,“玉大人,你說我怎么就攤上這事绿聘∷陨希” “怎么了?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵熄攘,是天一觀的道長兽愤。 經(jīng)常有香客問我,道長挪圾,這世上最難降的妖魔是什么浅萧? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮哲思,結(jié)果婚禮上洼畅,老公的妹妹穿的比我還像新娘。我一直安慰自己棚赔,他們只是感情好帝簇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著靠益,像睡著了一般丧肴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胧后,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天芋浮,我揣著相機(jī)與錄音,去河邊找鬼壳快。 笑死纸巷,一個胖子當(dāng)著我的面吹牛江醇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播何暇,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼凛驮!你這毒婦竟也來了裆站?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤黔夭,失蹤者是張志新(化名)和其女友劉穎宏胯,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體本姥,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡肩袍,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了婚惫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氛赐。...
    茶點(diǎn)故事閱讀 39,953評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖先舷,靈堂內(nèi)的尸體忽然破棺而出艰管,到底是詐尸還是另有隱情,我是刑警寧澤蒋川,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布牲芋,位于F島的核電站,受9級特大地震影響捺球,放射性物質(zhì)發(fā)生泄漏缸浦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一氮兵、第九天 我趴在偏房一處隱蔽的房頂上張望裂逐。 院中可真熱鬧,春花似錦胆剧、人聲如沸絮姆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽篙悯。三九已至,卻和暖如春铃绒,著一層夾襖步出監(jiān)牢的瞬間鸽照,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工颠悬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留矮燎,地道東北人定血。 一個月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像诞外,于是被迫代替她去往敵國和親澜沟。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評論 2 355