亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況

 更新時間:2020年11月09日 10:40:44   作者:一只前端小菜鳥  
這篇文章主要介紹了vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

我的思路大概是這樣的

1. 驗證是否是在微信內(nèi)置瀏覽器中調(diào)用支付寶

2.給支付頁面的url加上調(diào)用接口所需的參數(shù)(因為在微信里是不能直接調(diào)用支付寶的需要調(diào)用外部瀏覽器)

3.在外部瀏覽器中完成支付跳轉(zhuǎn)頁面

第一步:

payment: 是選擇支付頁面,pay-mask是用于在微信內(nèi)置瀏覽器中調(diào)用支付寶的中間頁

payment主要代碼:

let ua = window.navigator.userAgent.toLowerCase()

ua.match(/MicroMessenger/i) == "micromessenger"

這兩句代碼就是判斷用戶是否是用微信內(nèi)置瀏覽器打開的頁面

如果是的話我們就需要把調(diào)用支付接口所需要的接口參數(shù)傳給另一個頁面(你也可以就在當前頁做處理,我這樣做是因為我想加一個提示頁)

pay-mask代碼如下:

<template> 
<div class="mask"> 
<!-- 提示在瀏覽器打開彈框 --> 
<div class="pay-mask" v-show="isWeiXi"> 
</div>
 
<div class="payform"></div> 
</div>
</template>
<script type="text/ecmascript-6">
 
/*
解決在微信瀏覽器中無法調(diào)用支付寶支付:
1.拿到從支付頁傳遞過來的參數(shù)重組成自己需要的數(shù)據(jù)
2.清除舊的緩存數(shù)據(jù)(防止出現(xiàn)意外bug)
3.驗證是否是微信瀏覽器(不是就把拿到的key和token存進本地緩存中,用于其他接口調(diào)用)
4.請求數(shù)據(jù)接口拿到支付寶的支付表單裝進頁面中完成支付
*/
 
export default { 
name: 'payMask', 
data () { 
return { 
isWeiXi: true, 
theRequest: {} 
} 
},
 
methods: {
 
// 獲取當前微信瀏覽器url地址參數(shù)
 
getUrlParams() {
 
// 清除舊的緩存數(shù)據(jù)
 
// window.localStorage.clear() 
let theRequest = new Object(); 
let url = location.href; //獲取url中"?"符后的字串 
let strs = []; 
if (url.indexOf("?") != -1) {
var str = url.substr(parseInt(url.indexOf("?")+1)); 
strs = str.split("&"); 
for (var i = 0; i < strs.length; i++) { 
theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]); 
} 
}
 
this.theRequest = theRequest; 
},
 
// 監(jiān)控微信瀏覽器
 
isWeiXin() { 
let ua = window.navigator.userAgent.toLowerCase(); 
if (ua.match(/MicroMessenger/i) != "micromessenger") { 
this.isWeiXi = false
 
// 重新存儲新的token(在外部瀏覽器打開支付完成后是沒有token這些數(shù)據(jù)的所以需要在瀏覽器一打開的時候就去存一次數(shù)據(jù))
 
window.localStorage.setItem("channelId", this.theRequest.channelId); 
window.localStorage.setItem("userKey",JSON.stringify(this.theRequest.userKey)); 
window.localStorage.setItem("userToken",JSON.stringify(this.theRequest.userToken)); 
if(this.theRequest.memberTypeName){
 
// 調(diào)用支付寶支付
 
this.zfbPayBuy(this.theRequest) 
} else { 
this.zfbPayBuySocial(this.theRequest) 
}
 
} else { 
this.isWeiXi = true
 
} 
},
 
// 支付寶支付(會員)
 
zfbPayBuy(data){
 
// 請求接口拿到接口返回的支付表單(接口直接返回的,我們直接裝進頁面就可以了)
 
this.axios.payBuy(data).then(res => { 
if (res.status == 0) { 
let payHtml = document.querySelector(".payform"); 
payHtml.innerHTML = res.result;
let paySub = payHtml.getElementsByTagName("input")[1]; 
paySub.click()
 
} 
}) 
},
 
//支付寶支付(社保)
 
zfbPayBuySocial(data) { 
this.axios.buySocial(data).then(res => { 
if (res.status == 0) { 
let payHtml = document.querySelector(".payform") 
payHtml.innerHTML = res.result 
let paySub = payHtml.getElementsByTagName("input")[1] 
paySub.click() 
} 
}) 
}, 
}, 
created() {
 
// 拿去當前地址參數(shù) 

this.getUrlParams() 
if(JSON.stringify(this.theRequest) != '{}'){ 
this.isWeiXin() 
} 
},
 
mounted(){
 
// 更新一下當前瀏覽器地址(防止在微信里調(diào)用外部瀏覽器的時候出現(xiàn)意外bug) 

window.location.href = window.location.href 
} 
} 
</script>
<style scoped lang="less"> 

.pay-mask { 
width: 100%; 
min-height: 100%; 
position:fixed; 
z-index: 99; 
background-color: rgba(0, 0, 0,.6); 
background-image: url('../../image/icon/confirm.png'); 
background-repeat: no-repeat; 
} 

</style>

補充知識:vue 移動端H5非內(nèi)置瀏覽器發(fā)起微信、支付寶支付

該貼只說前端部分,后端人員繞路哈。

先調(diào)用統(tǒng)一下單接口后

1、微信部分,后端會返回一個url給你,

"mweb_url":https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx********************&package=162****

直接跳轉(zhuǎn)就行了。(最后提醒句:提示服務商參數(shù)缺失的話就讓服務商開通H5支付)

window.location.href = res.data.mweb_url

2、支付寶方面就有點麻煩,因為它返回的是一個form

所以嘛,需要創(chuàng)建個div然后innerHTML插入HTML代碼

const div = document.createElement('div') // 創(chuàng)建div
div.innerHTML = res.data.aliHtml // 將返回的form 放入div
document.body.appendChild(div) // 將上面創(chuàng)建的元素加入到BODY的尾部
document.forms[0].submit() // 表示獲取當前頁面的第一個表單

這樣就OK了

如果想問支付成功后的跳轉(zhuǎn)呢,你則需要給一個鏈接給到后端,后端傳給阿里或者微信,成功后自己跳的。

以上這篇vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue-cli3+echarts實現(xiàn)漸變色儀表盤組件封裝

    vue-cli3+echarts實現(xiàn)漸變色儀表盤組件封裝

    這篇文章主要為大家詳細介紹了vue-cli3+echarts實現(xiàn)漸變色儀表盤組件封裝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue如何添加jest測試

    vue如何添加jest測試

    這篇文章主要介紹了vue如何添加jest測試問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue+element下日期組件momentjs轉(zhuǎn)換賦值問題解決

    vue+element下日期組件momentjs轉(zhuǎn)換賦值問題解決

    這篇文章主要介紹了vue+element下日期組件momentjs轉(zhuǎn)換賦值問題,記錄下使用momentjs轉(zhuǎn)換日期字符串賦值給element的日期組件報錯問題,需要的朋友可以參考下
    2024-02-02
  • Vue自定義指令深入探討實現(xiàn)

    Vue自定義指令深入探討實現(xiàn)

    這篇文章主要介紹了Vue自定義指令的實現(xiàn),Vue支持自定義指令,開發(fā)者可以根據(jù)自己的需求,創(chuàng)建自己的指令來擴展Vue的功能,需要詳細了解可以參考下文
    2023-05-05
  • vue2中使用sass并配置全局的sass樣式變量的方法

    vue2中使用sass并配置全局的sass樣式變量的方法

    這篇文章主要介紹了vue2中使用sass并配置全局的sass樣式變量的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • Vue中的reactive函數(shù)操作代碼

    Vue中的reactive函數(shù)操作代碼

    這篇文章主要介紹了Vue中的reactive函數(shù),本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • vue的簡介及@vue/cli?腳手架的使用示例

    vue的簡介及@vue/cli?腳手架的使用示例

    vue 是一個 漸進式的javascript框架,腳手架是一個通用概念,幫助搭建項目的工具,本文以vue2為例結合實例代碼給大家詳細講解,感興趣的朋友跟隨小編一起看看吧
    2022-12-12
  • vue循環(huán)中點擊選中再點擊取消(單選)的實現(xiàn)

    vue循環(huán)中點擊選中再點擊取消(單選)的實現(xiàn)

    這篇文章主要介紹了vue循環(huán)中點擊選中再點擊取消(單選)的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 解決Ant Design Modal內(nèi)嵌Form表單initialValue值不動態(tài)更新問題

    解決Ant Design Modal內(nèi)嵌Form表單initialValue值不動態(tài)更新問題

    這篇文章主要介紹了解決Ant Design Modal內(nèi)嵌Form表單initialValue值不動態(tài)更新問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • element-ui中el-cascader動態(tài)加載和默認值詳解

    element-ui中el-cascader動態(tài)加載和默認值詳解

    vue+elementUI項目中el-cascader級聯(lián)選擇器使用頻率非常高,下面這篇文章主要給大家介紹了關于element-ui中el-cascader動態(tài)加載和默認值的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05

最新評論