热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信民众号页面(VUE)中怎样设置微信JSSDK和高德舆图,以及碰到的一些问题纪录

1.装置并引入JS-SDK依靠包这里是JS-SDK申明文档1.1npm下载依靠包npminstallweixin-js-sdk--save1.2.在须要用到jssdk的模块引入im

1.装置并引入JS-SDK依靠包

这里是JS-SDK申明文档

1.1 npm 下载依靠包

npm install weixin-js-sdk --save

1.2.在须要用到jssdk的模块引入

import wx from 'weixin-js-sdk';

1.3.搜检是不是引入胜利,能够在引入的模块mounted中实行

console.log(wx)

{config: ƒ, ready: ƒ, error: ƒ, checkJsApi: ƒ, onMenuShareTimeline: ƒ, …}

addCard: ƒ (e)

checkJsApi: ƒ (e)

chooseCard: ƒ (e)

chooseImage: ƒ (e)

chooseWXPay: ƒ (e)

…

控制台显现以上代码示意引入胜利.

2.设置微信JS-SDK

一切须要运用JS-SDK的页面必须先注入设置信息,否则将没法挪用

wx.config({
debug: true, // 开启调试形式,挪用的一切api的返回值会在客户端alert出来,若要检察传入的参数,能够在pc端翻开,参数信息会经由过程log打出,仅在pc端时才会打印。
appId: '', // 必填,民众号的唯一标识,治理民众号页面能够猎取
timestamp: '', // 必填,天生署名的时刻戳,背景返回
nonceStr: '', // 必填,天生署名的随机串,背景返回
signature: '',// 必填,署名,背景返回
jsApiList: ['openLocation','getLocation'] // 必填,须要运用的JS接口列表,写入本身用到的接口称号
});

然后守候设置完成后,在ready中运用微信供应的API

wx.ready(function(){
wx.getLocation({
type: 'wgs84', // 默以为wgs84的gps坐标,假如要返回直接给openLocation用的火星坐标,可传入'gcj02'
success: function (res) {
var latitude = res.latitude; // 纬度,浮点数,局限为90 ~ -90
var lOngitude= res.longitude; // 经度,浮点数,局限为180 ~ -180。
var speed = res.speed; // 速率,以米/每秒计
var accuracy = res.accuracy; // 位置精度

}
});
})

坑1: config:invalid signature 设置报错;

起首我们不能用chorme来调试这个config,没有任何回响反映
然后网上种种搜基础能够确实是URL的题目

微信划定 署名的URL要与当前页面URL一致!

处理方案看这个题目,将此页面的URL 动态送给背景,天生署名.

坑2 安卓和IOS猎取URL的差别致使注册报错

安卓能够直接在网页中这么猎取当前URL:

location.href.split('#')[0]

IOS就不可,你只能猎取到你刚进入页面的URL;
处理的思绪大概是
1.起首要推断是不是是IOS体系
2.假如是IOS 我们缓存一个进口URL然后注册,假如不是IOS直接运用location.href.split(‘#’)[0]URL举行注册

---config.js 全局定义一个变量
global.entryUrl = location.href.split('#')[0];

伪代码以下:

mounted(){
let url;
if (publicFun.isIOS()) {//推断是不是是IOS
url = this.PUBLICCONFIG.entryUrl;
} else {
url = location.href.split('#')[0];
}
//传参给背景 猎取 appId/timestamp/nonceStr/signature
api.getJsConfig({
"url":url
},{
success:function (res) {
//猎取参数胜利后设置
wx.config({
debug: true,
appId: res.data.appId,
timestamp:res.data.timestamp ,
nonceStr:res.data.nonceStr,
signature: res.data.signature,
jsApiList: ['openLocation','getLocation']
});
}
})
//微信设置胜利
wx.ready(function(){
console.log("设置胜利")
wx.getLocation({
type: 'wgs84',
success: function (res) {
var latitude = res.latitude; // 纬度,浮点数,局限为90 ~ -90
var lOngitude= res.longitude; // 经度,浮点数,局限为180 ~ -180。
var speed = res.speed; // 速率,以米/每秒计
var accuracy = res.accuracy; // 位置精度
console.log(latitude);
this.latitude = latitude
}
});
})
// config信息考证失利会实行error函数,如署名逾期致使考证失利,详细毛病信息能够翻开config的debug形式检察,也能够在返回的res参数中检察,关于SPA能够在这里更新署名。
wx.error(function(res){

});

}

坑3:须要定时挪用微信的API接口,设置定时无效(这个题目能够很傻)

一切接口挪用都必须在config接口取得效果以后,config是一个客户端的异步操纵

因而我们须要将定时 写在wx.ready 要领内里,而不须要每次挪用微信API的时刻 wx.config一次.

wx.config({
//设置
})
wx.ready({
//放到这里 是能够滴
setInterval(timer,5000)
})

3.运用高德舆图

高德舆图API文档

3.1注册高德并请求Key

  1. 起首,注册开发者账号,成为高德开放平台开发者
  2. 上岸以后,在进入「运用治理」 页面「建立新运用」
  3. 为运用增加 Key,「效劳平台」一项请挑选「 Web 端 ( JSAPI ) 」

3.2 在项目index.html中引入高德剧本标签

3.3建立一个高德舆图的实例

建立一个容器,给一个ID名字

给容器加一个款式

.page-location-map{
width: 100%;
height: 100%;
}

在组将mounted要领中建立舆图实例

let Map = new AMap.Map('map', {
zoom: 11,//级别
center: [116.397428, 39.90923],//中心点坐标
viewMode: '3D' //运用3D视图
})

运转项目后,你就会看到一个北京天安门的舆图了.接下来你应当晓得怎样做了 对吧?

参考

1.
vue-router的history形式在IOS微信分享下url稳定的坑以及处理办法

2.
微信民众平台, config:invalid signature一向爆这个毛病,讨教怎样处理?


推荐阅读
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • 微信小程序中实现位置获取的全面指南
    本文详细介绍了如何在微信小程序中实现地理位置的获取,包括通过微信官方API和腾讯地图API两种方式。文中不仅涵盖了必要的准备工作,如申请开发者密钥、下载并配置SDK等,还提供了处理用户授权及位置信息获取的具体代码示例。 ... [详细]
  • 本文详细介绍了如何在现有的Android Studio项目中集成JNI(Java Native Interface),包括下载必要的NDK和构建工具,配置CMakeLists.txt文件,以及编写和调用JNI函数的具体步骤。 ... [详细]
  • Flowable系列教程:运用ProcessEngineConfigurator实现高级流程引擎配置
    本文探讨了通过ProcessEngineConfigurator接口实现对Flowable流程引擎的高级配置方法。这种方法允许开发者通过自定义配置器来增强或修改流程引擎的行为。 ... [详细]
  • 任务,栈, ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • 本文详细探讨了如何通过分析单个或多个线程在瓶颈情况下的表现,来了解处理器资源的消耗。无论是单进程还是多进程环境,监控关键指标如线程数量、占用时间及调度优先级等,有助于揭示潜在的性能问题。 ... [详细]
  • 黑马头条项目:Vue 文章详情模块与交互功能实现
    本文详细介绍了如何在黑马头条项目中配置文章详情模块的路由、获取和展示文章详情数据,以及实现关注、点赞、不喜欢和评论功能。通过这些步骤,您可以全面了解如何开发一个完整的前端文章详情页面。 ... [详细]
  • 本文详细介绍了如何在Kendo UI for jQuery的数据管理组件中,将行标题字段呈现为锚点(即可点击链接),帮助开发人员更高效地实现这一功能。通过具体的代码示例和解释,即使是新手也能轻松掌握。 ... [详细]
  • 为了解决不同服务器间共享图片的需求,我们最初考虑建立一个FTP图片服务器。然而,考虑到项目是一个简单的CMS系统,为了简化流程,团队决定探索七牛云存储的解决方案。本文将详细介绍使用七牛云存储的过程和心得。 ... [详细]
  • 最新计算机专业原创毕业设计参考选题都有源码+数据库是近期作品ling取参考你的选题刚好在下面有,有时间看到机会给您发1ssm资源循环利用2springboot校园考勤系统3ssm防 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • Vue 3.0 翻牌数字组件使用指南
    本文详细介绍了如何在 Vue 3.0 中使用翻牌数字组件,包括其基本设置和高级配置,旨在帮助开发者快速掌握并应用这一动态视觉效果。 ... [详细]
  • Vue 项目构建与部署指南
    本文将指导您完成Vue项目的构建和部署过程,包括环境搭建、项目初始化及配置、以及最终的部署步骤。 ... [详细]
author-avatar
377926138_b741aa
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有