wechat.js 7.2 KB
// import request from './request'; //笔者自己封装的网络请求类,也可以直接使用uni.request
var jweixin = require('jweixin-module');

export default {
    //判断是否在微信中
    isWechat: function() {
        var ua = window.navigator.userAgent.toLowerCase();
        if (ua.match(/micromessenger/i) == 'micromessenger') {
            return true;
        } else {
            return false;
        }
    },
	//初始化微信支付
	initJssdkWxPay:function(callback){
		uni.request({
			url:'http://obituaries.t.brotop.cn/api/Common/getJsSdkConfig',
			method:'post',
			data:{
				url:window.location.href.split('#')[0],
				api:'chooseWXPay'
			},
			success: (res) => {
				if(res.data){
				    jweixin.config({
				        debug: false,
				        appId: res.data.data.config.appId,
				        timestamp: res.data.data.config.timestamp,
				        nonceStr: res.data.data.config.nonceStr,
				        signature: res.data.data.config.signature,
				        jsApiList: [
				            'checkJsApi',
				            'chooseWXPay'
				        ]
				    });
				    //配置完成后,再执行分享等功能
				    if (callback) {
				        callback(res.data.data.config);
				    }
				}
			}
		})
	},
    //初始化sdk配置
    initJssdkShare: function(callback, url) {
        //服务端进行签名 ,可使用uni.request替换。 签名算法请看文档
		uni.request({
			url:'http://obituaries.t.brotop.cn/api/Common/getJsSdkConfig',
			method:'post',
			data:{
                url: url,
				api:'updateTimelineShareData,updateAppMessageShareData,getLocation'
            },
			success: (res) => {
				if (res.data) {
				    jweixin.config({
				        debug: false,
						appId: res.data.data.config.appId,
						timestamp: res.data.data.config.timestamp,
						nonceStr: res.data.data.config.nonceStr,
						signature: res.data.data.config.signature,
				        jsApiList: [
				            'checkJsApi',
				            'updateTimelineShareData',
				            'updateAppMessageShareData',
				            'getLocation'
				        ]
				    });
				    //配置完成后,再执行分享等功能
				    if (callback) {
				        callback(res.data.data.config);
				    }
				}
			}
		})
    },
    initJssdk:function(callback){
		uni.request({
			url:'http://obituaries.t.brotop.cn/api/Common/getJsSdkConfig',
			method:'post',
			data:{
				url:window.location.href.split('#')[0],
				api:'checkJsApi,getLocation'
			},
			success: (res) => {
				if(res.data){
				    jweixin.config({
				        debug: false,
				        appId: res.data.data.config.appId,
				        timestamp: res.data.data.config.timestamp,
				        nonceStr: res.data.data.config.nonceStr,
				        signature: res.data.data.config.signature,
				        jsApiList: [
				            'checkJsApi',
				            'getLocation'
				        ]
				    });
				    //配置完成后,再执行分享等功能
				    if (callback) {
				        callback(res.data.data.config);
				    }
				}
			}
		})
    },
	//打开地图
	initJssdkGetLocation:function(callback){
		uni.request({
			url:'http://obituaries.t.brotop.cn/api/Common/getJsSdkConfig',
			method:'post',
			data:{
				url:window.location.href.split('#')[0],
				api:'openLocation,getLocation'
			},
			success: (res) => {
				if(res.data){
				    jweixin.config({
				        debug: false,
				        appId: res.data.data.config.appId,
				        timestamp: res.data.data.config.timestamp,
				        nonceStr: res.data.data.config.nonceStr,
				        signature: res.data.data.config.signature,
				        jsApiList: [
				            'checkJsApi',
				            'openLocation',
							'getLocation'
				        ]
				    });
				    //配置完成后,再执行查看地图
				    if (callback) {
				        callback(res.data.data.config);
				    }
				}
			}
		})
	},
    //在需要自定义分享的页面中调用
    share: function(callback,data, url) {
		let configUrl = url.split('#')[0]
        if (!this.isWechat()) {
            return;
        }
        //每次都需要重新初始化配置,才可以进行分享
        this.initJssdkShare(function(signData) {
            jweixin.ready(function() {
                var shareData = {
                    title: data && data.title ? data.title : signData.site_name,
                    desc: data && data.desc ? data.desc : signData.site_description,
                    link: url,
                    imgUrl: data && data.img ? data.img : signData.site_logo,
					//设置成功
                    success: function(res) {
						callback(res)
                    }
                };
                //分享给朋友接口
                jweixin.updateAppMessageShareData(shareData);
                //分享到朋友圈接口
                // jweixin.updateTimelineShareData(shareData);
            });
        }, configUrl);
    },
    //在需要定位页面调用
    location: function(callback) {
        if (!this.isWechat()) {
		uni.showToast({
			title:'请在微信内置浏览器中打开',
			icon:'none'
		})
            return;
        }
        this.initJssdk(function(res) {
            jweixin.ready(function() {
                jweixin.getLocation({
                    type: 'gcj02', // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
                    success: function (res) {
                        callback(res)
                    },
                    fail:function(res){
                        console.log(res)
                    }
                });
            });
        });
    },
	//在需要支付的页面调用
	wxPay: function(callback,payInfo) {
	    if (!this.isWechat()) {
			uni.showToast({
				title:'请在微信内置浏览器中打开',
				icon:'none'
			})
	        return;
	    }
	    this.initJssdkWxPay(function(res) {
	        jweixin.ready(function() {
	            jweixin.chooseWXPay({
					timestamp: payInfo.timeStamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
					nonceStr: payInfo.nonceStr, // 支付签名随机串,不长于 32 位
					package: payInfo.package, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
					signType: payInfo.signType, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
					paySign: payInfo.paySign, // 支付签名
					success: function (res) {
						// 支付成功后的回调函数
						callback(res)
					}
	            });
	        });
	    });
	},
	openLocation: function(data) {
	    if (!this.isWechat()) {
		uni.showToast({
			title:'请在微信内置浏览器中打开',
			icon:'none'
		})
	        return;
	    }
	    this.initJssdkGetLocation(function() {
	        jweixin.ready(function() {
				jweixin.openLocation({
					latitude: data.latitude, // 纬度,浮点数,范围为90 ~ -90
					longitude: data.longitude, // 经度,浮点数,范围为180 ~ -180。
					name: data.name, // 位置名
					address: data.address, // 地址详情说明
					scale: 16, // 地图缩放级别,整形值,范围从1~28。默认为最大
					infoUrl: '' // 在查看位置界面底部显示的超链接,可点击跳转
				});
	        });
	    });
	}
}