vue中使用WX-JSSDK的兩種方法(推薦)
公司最近有微信公眾號的需求,那么微信登錄授權(quán)和如何使用WX-JSSDk實(shí)現(xiàn)分享等等肯定是最頭疼的問題。本人也是第一次開發(fā)微信公眾號,在網(wǎng)上看了很多篇博客,最終選定了兩種方法,并且親測有效。
一、通過全局,在router.afterEach中定義
1.首先通過yarn add weixin-js-sdk/ npm i weixin-js-sdk
2.將微信jsdk掛載到全局上
在utils目錄下新建WechatPlugin.js
WechatPlugin.js
import wx from 'weixin-js-sdk'
const plugin = {
install(Vue) {
Vue.prototype.$wechat = wx
Vue.wechat = wx
},
$wechat: wx
}
export default plugin
export const install = plugin.install
main.js中
import WechatPlugin from './utils/WechatPlugin' // 全局注冊微信jsdk Vue.use(WechatPlugin)
3.router.afterEach中
import wechatUtil from '@/utils/wechatUtil' // 在此文件中定義微信的一些方法
router.afterEach((to, from) => {
let path = to.fullPath.slice(1) // 去除'/'
let url
const jsApiList = [
'onMenuShareAppMessage',
'onMenuShareTimeline',
'chooseWXPay',
'showOptionMenu',
"updateAppMessageShareData",
"hideMenuItems",
"showMenuItems"
]
if (!sessionStorage.getItem('initLink')) {
// 解決ios微信下,分享簽名不成功的問題,將第一次的進(jìn)入的url緩存起來。
sessionStorage.setItem('initLink', document.URL)
}
if (!!window.__wxjs_is_wkwebview) {
// ios
url = sessionStorage.getItem('initLink')
wechatUtil.setWeChatConfig(url, jsApiList)
} else {
// 安卓
url = location.origin + process.env.BASE_URL + path
// setTimeout(() => {
wechatUtil.setWeChatConfig(url, jsApiList)
// }, 0)
}
})
3.wechatUtil.js中
import Vue from 'vue'
export default {
appid: process.env.VUE_APP_WECHAT_APPID, // 可以在根據(jù)不同環(huán)境配置appid
setWeChatConfig(url, jsApiList) {
getSignature(decodeURIComponent(url)) // getSignature需要你自己跟后端約定請求簽名時(shí)的接口
.then(data => {
Vue.wechat.config({
debug: false,
signature: data.signature,
nonceStr: data.nonceStr,
timestamp: data.timestamp,
appId: data.appId,
jsApiList
})
})
.catch(err => {
console.log(err)
})
}
}
上面方法雖然全局可以使用,但是會遇到一個(gè)問題,在單個(gè)頁面調(diào)用微信jsddk中的updateAppMessageShareData方法
或者其他方法時(shí),有時(shí)成功有時(shí)失敗,這可能是微信jsdk異步的問題,因此,需要你在單個(gè)頁面中使用的時(shí)候加上setTimeout(()=>{ “這里調(diào)取微信的接口” },500)。
下面的第二種方法我覺得是最方便也是最自定義能力最好的,在需要的頁面的調(diào)取。
二、方法二通過new promise封裝成統(tǒng)一的入口,在單個(gè)頁面中調(diào)用
我們還是要在router.afterEach中將進(jìn)入的url記錄下來,我是放在vuex上的(這里要特別注意蘋果手機(jī)和安卓手機(jī)的區(qū)別,這里我就不多做講解,原因是蘋果瀏覽器中的url是第一次進(jìn)來的url)
1.在router.afterEach中
import store from '@/store'
router.afterEach((to, from) => {
let path = to.fullPath.slice(1) // 去除'/'
if (!sessionStorage.getItem('initLink')) {
// 解決ios微信下,分享簽名不成功的問題,將第一次的進(jìn)入的url緩存起來。
sessionStorage.setItem('initLink', document.URL)
}
let url
if (!!window.__wxjs_is_wkwebview) {
// ios
url = sessionStorage.getItem('initLink')
} else {
// 安卓 process.env.BASE_URL 自己定義各個(gè)環(huán)境下域名變量
url = location.origin + process.env.BASE_URL + path
}
store.commit('page/setInitLink', url)
})
2.在store/page.js中
const state = {
initLink: ''
}
const mutations = {
setInitLink (state, initLink) {
state.initLink = initLink
}
}
export default {
namespaced: true,
state,
mutations
}
3.在utils/wechatUtil.js定義初始化方法
import wx from 'weixin-js-sdk'
import store from '@/store'
export default {
/* 初始化wxjsdk各種接口 */
init(apiList = [], url) {
//需要使用的api列表
return new Promise((resolve, reject) => {
getSignature(store.state.page.initLink).then(res => {
if (res.appId) {
wx.config({
// debug: true,
appId: res.appId,
timestamp: res.timestamp,
nonceStr: res.nonceStr,
signature: res.signature,
jsApiList: apiList
})
wx.ready(res => {
// 微信SDK準(zhǔn)備就緒后執(zhí)行的回調(diào)。
resolve(wx, res)
})
} else {
reject(res)
}
})
})
}
}
4.在頁面中的使用
import wechatUtil from '@/utils/wechatUtil'
wechatUtil
.init([
'updateAppMessageShareData',
'onMenuShareAppMessage',
'onMenuShareTimeline',
'updateTimelineShareData'
])
.then((wx, res) => {
// 這里寫微信的接口
})
總結(jié):最后我個(gè)人推薦第二種方法,第一種方法雖然很方便,但是每次路由跳轉(zhuǎn)都調(diào)取了微信獲取簽名初始化的方法,而且自定義的擴(kuò)展性不是很強(qiáng),而且還會有微信接口異步的問題,需要用到微信中的debu:true調(diào)試。第二種方法使用和定義起來比較簡單。
以上所述是小編給大家介紹的vue中使用WX-JSSDK的兩種方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue+vant實(shí)現(xiàn)購物車全選和反選功能
這篇文章主要為大家詳細(xì)介紹了vue+vant實(shí)現(xiàn)購物車全選和反選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
html+vue實(shí)現(xiàn)分頁功能的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何使用html+vue實(shí)現(xiàn)簡單的分頁功能,文中的示例代碼簡潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
vue如何使用pdf.js實(shí)現(xiàn)在線查看pdf文件功能
PDF.js是一個(gè)開源的JavaScript庫,用于在網(wǎng)頁上渲染和顯示PDF文件,在Vue中使用PDF.js來預(yù)覽PDF文件是很常見的需求,這篇文章主要給大家介紹了關(guān)于vue如何使用pdf.js實(shí)現(xiàn)在線查看pdf文件功能的相關(guān)資料,需要的朋友可以參考下2024-03-03
使用Pinia Persistedstate插件實(shí)現(xiàn)狀態(tài)持久化的操作方法
Pinia 作為 Vue 的新一代狀態(tài)管理工具,以其輕量化和易用性受到開發(fā)者的喜愛,然而,Pinia 默認(rèn)使用內(nèi)存存儲狀態(tài),為了解決這個(gè)問題,我們可以借助 Pinia Persistedstate 插件來實(shí)現(xiàn)狀態(tài)的持久化存儲,本文將詳細(xì)介紹該插件的使用方法,需要的朋友可以參考下2024-11-11

