vue中使用WX-JSSDK的兩種方法(推薦)
公司最近有微信公眾號(hào)的需求,那么微信登錄授權(quán)和如何使用WX-JSSDk實(shí)現(xiàn)分享等等肯定是最頭疼的問題。本人也是第一次開發(fā)微信公眾號(hào),在網(wǎng)上看了很多篇博客,最終選定了兩種方法,并且親測(cè)有效。
一、通過全局,在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' // 全局注冊(cè)微信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需要你自己跟后端約定請(qǐng)求簽名時(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) }) } }
上面方法雖然全局可以使用,但是會(huì)遇到一個(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),而且還會(huì)有微信接口異步的問題,需要用到微信中的debu:true調(diào)試。第二種方法使用和定義起來比較簡單。
以上所述是小編給大家介紹的vue中使用WX-JSSDK的兩種方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue中使用pdfjs-dist?+?turnjs實(shí)現(xiàn)頁面的翻書瀏覽功能
這篇文章主要介紹了vue中使用pdfjs-dist?+?turnjs實(shí)現(xiàn)頁面的翻書瀏覽,通過本文學(xué)習(xí)我們知道了pdfjs-dist 的工作原理是把獲取到的 pbf 的文件的數(shù)據(jù)流, 利用 canvas轉(zhuǎn)換成圖片,本文通過實(shí)例代碼詳解講解,需要的朋友可以參考下2022-10-10vue項(xiàng)目base64字符串轉(zhuǎn)圖片的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue項(xiàng)目base64字符串轉(zhuǎn)圖片的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07vue基于echarts實(shí)現(xiàn)立體柱形圖
這篇文章主要為大家詳細(xì)介紹了vue基于echarts實(shí)現(xiàn)立體柱形圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09vue3+vue-cli4中使用svg的方式詳解(親測(cè)可用)
最近在做個(gè)vue的項(xiàng)目,從各種github上的開源庫上借鑒開發(fā)方法,給大家分享下,這篇文章主要給大家介紹了關(guān)于vue3+vue-cli4中使用svg的相關(guān)資料,需要的朋友可以參考下2022-08-08基于vue-cli配置lib-flexible + rem實(shí)現(xiàn)移動(dòng)端自適應(yīng)
這篇文章主要介紹了基于vue-cli配置lib-flexible + rem實(shí)現(xiàn)移動(dòng)端自適應(yīng),需要的朋友可以參考下2017-12-12前端實(shí)現(xiàn)不同角色登入展示不同頁面效果實(shí)例
要實(shí)現(xiàn)不同角色登錄跳轉(zhuǎn)不同的前端頁面,可以在登錄成功后,根據(jù)用戶的角色信息,使用路由跳轉(zhuǎn)到不同的頁面,這篇文章主要給大家介紹了關(guān)于前端實(shí)現(xiàn)不同角色登入展示不同頁面效果的相關(guān)資料,需要的朋友可以參考下2024-08-08