微信公众号weixin-js-sdk使用方法总结

 更新时间:2022年12月09日 14:12:08   作者:sunly_  
最近做了一个活动页面,需要自定义微信分享的标题、详情、缩略图和url,使用到了jssdk,这篇文章主要给大家介绍了关于微信公众号weixin-js-sdk使用方法的相关资料,需要的朋友可以参考下

记录微信公众号开发过程中遇到的问题以及解决方案:

1、安装weixin-js-sdk

npm install weixin-js-sdk

2、封装wechat.js

import wx from 'weixin-js-sdk' // 引入微信js-sdk
import http from '@/utils/axios.js'; //接口请求封装

class AuthWechat {

	signLink() {
		if (typeof window.entryUrl === 'undefined' || window.entryUrl === '') {
			window.entryUrl = document.location.href
		}
		return /(Android)/i.test(navigator.userAgent) ? document.location.href : window.entryUrl;
	}
	
	// 当前是否是微信环境
	isWeixin() {
		return navigator.userAgent.toLowerCase().indexOf("micromessenger") !== -1;
	}

	/**
	 * 初始化wechat(分享配置)
	 */
	wechat() {
		return new Promise((resolve, reject) => {
			let url = this.signLink()
			http.post('Users/shareSign', {
				url: url
			}).then(res => {
				if (res.code == 200) {
					wx.config({
						debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
						appId: res.data.appId, // 必填,公众号的唯一标识
						timestamp: res.data.timestamp, // 必填,生成签名的时间戳
						nonceStr: res.data.nonceStr, // 必填,生成签名的随机串
						signature: res.data.signature, // 必填,签名
						jsApiList: [
							'updateAppMessageShareData', // 自定义“分享给朋友”及“分享到QQ”按钮的分享内容
							'updateTimelineShareData', // 自定义“分享到朋友圈”及“分享到QQ空间”按钮的分享内容(1.4.0)
							'scanQRCode', // 扫一扫
							'getLocation', // 获取地理位置
							'openLocation', // 使用微信内置地图查看位置接口
							'chooseImage', //拍照或从手机相册中选图接口
							'closeWindow', //关闭当前网页窗口接口
						]
					})
					wx.ready(res => {
						// 微信SDK准备就绪后执行的回调。
						resolve(wx, res)
					})
					wx.error(err => {
						reject(wx, err)
					})
				}
			})
		})
	}

	// 微信分享
	wxShare(shareObj) {
		this.wechat().then((wx, res) => {
			wx.ready(() => {
				wx.updateAppMessageShareData({
					title: shareObj.title, // 分享标题
					link: shareObj.link, // 分享链接
					desc: shareObj.desc, // 分享描述
					imgUrl: shareObj.imgUrl,
					success: function() {},
					cancel: function() {}
				});
				wx.updateTimelineShareData({
					title: shareObj.title, // 分享标题
					link: shareObj.link, // 分享链接
					desc: shareObj.desc, // 分享描述
					imgUrl: shareObj.imgUrl,
					success: function() {},
					cancel: function() {}
				});
			})
		})
	}

	// 扫一扫
	scanQRCode() {
		return new Promise((resolve, reject) => {
			this.wechat().then((wx, res) => {
				this.toPromise(wx.scanQRCode, {
					needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
					scanType: ["qrCode", "barCode"], // 可以指定扫二维码还是一维码,默认二者都有
				}).then(res => {
					resolve(res);
				}).catch(err => {
					reject(err);
				});
			})
		})
	}

	// 获取地理位置接口
	getLocation() {
		return new Promise((resolve, reject) => {
			this.wechat().then((wx, res) => {
				this.toPromise(wx.getLocation, {
					type: 'wgs84', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
				}).then(res => {
					resolve(res);
				}).catch(err => {
					reject(err);
				});
			})
		})
	}

	// 使用微信内置地图查看位置接口
	openLocation(data) {
		return new Promise((resolve, reject) => {
			this.wechat().then((wx, res) => {
				this.toPromise(wx.openLocation, {
					latitude: data.latitude, // 纬度,浮点数,范围为90 ~ -90
					longitude: data.longitude, // 经度,浮点数,范围为180 ~ -180。
					name: '', // 位置名
					address: '', // 地址详情说明
					scale: 1, // 地图缩放级别,整型值,范围从1~28。默认为最大
					infoUrl: '' // 在查看位置界面底部显示的超链接,可点击跳转
				}).then(res => {
					resolve(res);
				}).catch(err => {
					reject(err);
				});
			})
		})
	}
	
	// 拍照或从手机相册中选图接口
	chooseImage() {
		return new Promise((resolve, reject) => {
			this.wechat().then((wx, res) => {
				this.toPromise(wx.chooseImage, {
					count: 1, // 默认9
					sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
					sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
				}).then(res => {
					resolve(res);
				}).catch(err => {
					reject(err);
				});
			})
		})
	}
	
	// 关闭当前网页窗口接口
	closeWindow() {
		this.wechat().then((wx, res) => {
			wx.ready(() => {
				wx.closeWindow();
			})
		})
	}

	toPromise(fn, config = {}) {
		return new Promise((resolve, reject) => {
			fn({
				...config,
				success(res) {
					resolve(res);
				},
				fail(err) {
					reject(err);
				},
				complete(err) {
					reject(err);
				},
				cancel(err) {
					reject(err);
				}
			});
		});
	}
	// 如果你需要添加新的方法,请查下步骤5
}

export default new AuthWechat();

3、main.js

import wechat from '@/utils/wechat.js'
Object.assign(Vue.prototype, {
	'$wechat':wechat
})

4、页面调用方式

<template>
	<view class="message">
		<u-button type="primary" @click="scanQRCode">扫一扫</u-button>
		<u-button type="primary" @click="getLocation">获取地理位置</u-button>
		<u-button type="primary" @click="openLocation">使用微信内置地图查看位置</u-button>
		<u-button type="primary" @click="chooseImage">拍照或从手机相册中选图</u-button>
		<u-button type="primary" @click="closeWindow">关闭当前网页窗口</u-button>
	</view>
</template>
<script>
	export default {
		components: {},
		data() {
			return {
				latitude: '',
				longitude: '',
			}
		},
		onShow() {
			if(this.$wechat.isWeixin()){
				let shareObj = {
					title: '测试2', // 分享标题
					link: 'https://mpm.yoronglife.com/pages/mall/goodsDetail?id=1', // 分享链接
					desc: '描述2', // 分享描述
					imgUrl: 'https://mpweb.yoronglife.com/uploads/default/logo.png',
				}
				this.$wechat.wxShare(shareObj)
			}
		},
		methods: {
			scanQRCode(){
				this.$wechat.scanQRCode().then(res=>{
					alert(JSON.stringify(res))
				})
			},
			getLocation(){
				this.$wechat.getLocation().then(res=>{
					this.latitude = res.latitude;
					this.longitude = res.longitude;
					alert(JSON.stringify(res))
				})
			},
			openLocation(){
				let data = {
					'latitude' : this.latitude,
					'longitude' : this.longitude,
				}
				this.$wechat.openLocation(data).then(res=>{
					alert(JSON.stringify(res))
				})
			},
			chooseImage(){
				this.$wechat.chooseImage().then(res=>{
					alert(JSON.stringify(res.localIds))// 返回选定照片的本地ID列表,localId可以作为img标签的src属性显示图片
				})
			},
			closeWindow(){
				this.$wechat.closeWindow()
			},
		},
	}
</script>

上边内容仅记录了一部分API的使用方式。如果你需要其他功能,如预览图片,可直接用下面这种方式复制到

5、如果你需要用到其他功能,在这里按照这种方式接着定义新的方法:

示例预览图片:this.toPromis(wx.方法名,参数)

记得在config中添加jsApiList:[‘previewImage’]

previewImage(images) {
	// 1.如果需要有返回值,就封装一层Promise,
	return new Promise((resolve, reject) => {
		this.wechat().then((wx, res) => {
			this.toPromise(wx.previewImage, {
				current: '', // 当前显示图片的http链接
				urls: [] // 需要预览的图片http链接列表
			}).then(res => {
				resolve(res);
			}).catch(err => {
				reject(err);
			});
		})
	})
	
	// 2.如果不需要返回值,这里直接在wx.ready中实现具体的功能
	this.wechat().then((wx, res) => {
		wx.ready(() => {
			wx.previewImage(images);
		})
	})
}

页面中调用预览图片
let images = {
	current:'http://****',
	urls:[
		:'http://****',
		:'http://****'
	]
}
this.$wechat.previewImage(images)

以上内容及代码均经过测试,可直接复用!!!

总结

到此这篇关于微信公众号weixin-js-sdk使用方法的文章就介绍到这了,更多相关微信公众号weixin-js-sdk使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 原生JS实现瀑布流插件

    原生JS实现瀑布流插件

    本篇文章给大家详细分析了一个原生JS实现瀑布流插件以及代码相关讲解,对此有兴趣的读者们参考学习下吧。
    2018-02-02
  • 快速上手uni-simple-router

    快速上手uni-simple-router

    这篇文章主要介绍了uni-simple-router,本文通过实例代码给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-11-11
  • js中小数转换整数的方法

    js中小数转换整数的方法

    js中小数转换整数的方法有很多,有下退、上进、四舍五入等等,需要的朋友可以了解下本文
    2014-01-01
  • Kettle中使用JavaScrip调用jar包对文件内容进行MD5加密的操作方法

    Kettle中使用JavaScrip调用jar包对文件内容进行MD5加密的操作方法

    这篇文章主要介绍了Kettle中使用JavaScrip调用jar包对文件内容进行MD5加密的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 微信小程序点击滚动到指定位置的实现

    微信小程序点击滚动到指定位置的实现

    这篇文章主要介绍了微信小程序点击滚动到指定位置的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • JS中toFixed()方法引起的问题如何解决

    JS中toFixed()方法引起的问题如何解决

    最近发现JS当中toFixed()方法存在一些问题,采用原生的Number对象的原型对象上的toFixed()方法时,规则并不是所谓的“四舍五入”或者是四舍六入五成双
    2012-11-11
  • 详解js的事件代理(委托)

    详解js的事件代理(委托)

    JavaScript事件代理(委托)一般用于以下情况:1. 事件注册在祖先级元素上,代理其子级元素。可以减少事件注册数量,节约内存开销,提高性能。2. 对js动态添加的子元素可自动绑定事件。本文主要介绍用原生 js 实现该功能。下面跟着小编一起来看下吧
    2016-12-12
  • JavaScript ES6中CLASS的使用详解

    JavaScript ES6中CLASS的使用详解

    class是es6引入的最重要特性之一。在没有class之前,我们只能通过原型链来模拟类。这篇文章我们将详细的介绍关于ES6中CLASS的使用,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11
  • js脚本加载失败问题解决办法

    js脚本加载失败问题解决办法

    在项目中经常会用到动态加载js,下面这篇文章主要给大家介绍了关于js脚本加载失败问题的解决办法,文中通过实例代码介绍的非常详细,对大家学习或者使用js具有一定的参考学习价值,需要的朋友可以参考下
    2023-06-06
  • layer页面跳转,获取html子节点元素的值方法

    layer页面跳转,获取html子节点元素的值方法

    今天小编就为大家分享一篇layer页面跳转,获取html子节点元素的值方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09

最新评论