首页 技术 正文
技术 2022年11月15日
0 收藏 552 点赞 3,537 浏览 7357 个字

转自:http://www.cuiyongzhi.com/post/63.html

在前面的文章中有介绍到我们在微信web开发过程中常常用到的 【微信JSSDK中Config配置】 ,但是我们在真正的使用中我们不仅仅只是为了配置Config而已,而是要在我们的项目中真正去使用微信JS-SDK给我们带来便捷,那么这里我们就简述如何在微信web开发中使用必要的方法!微信的JS-SDk中为我们提供的方法很多,这里我有一个简单截图如下:

Java微信公众平台开发(十五)–微信JSSDK的使用

在上图的提供的所有口中我们可以按照接口实现的难易程度分成两个部分:

  • 较易实现:基础接口、分享接口、设备信息接口、地理位置接口、界面操作接口、微信扫一扫接口;

  • 较难实现:图像接口、音频接口、智能接口、微信小店接口、微信卡券接口、微信支付接口;(注:这里说较难是因为需要后端和本地文件配合接口,这些接口后面会一篇篇文章具体详解)

在这里我们将讲述所有较易实现的接口的具体实现方法,在文章 http://www.cuiyongzhi.com/index.php/post/57.html  中讲述过了如何配置和引入需要的js,通过这些配置之后我们就可以开始使用js的方法了!

①基础接口-判断当前浏览器是否支持某些js接口

1234567891011121314151617 /* * 注意: *  所有的JS接口只能在公众号绑定的域名下调用,公众号开发者需要先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。 */wx.ready(function () {  //1. 判断当前版本是否支持指定 JS 接口,支持批量判断,只需要将需要判断的接口放入到jsApiList中即可 checkJsApifunction () {    wx.checkJsApi({      jsApiList: [        'getNetworkType',        'previewImage'      ],      success: function (res) {        alert(JSON.stringify(res));      }    });  };

②分享接口,这里包含:分享给朋友、分享到朋友圈、分享到qq、分享到微博、分享到qq空间(但是这里要提醒要注意不要有诱导分享等违规行为,对于诱导分享行为将永久回收公众号接口权限)

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125  // 2. 分享接口  // 2.1 监听“分享给朋友”,按钮点击、自定义分享内容及分享结果接口  onMenuShareAppMessagefunction () {    wx.onMenuShareAppMessage({      title: '菜鸟程序员成长之路!',      desc: '关注java平台开发,前后端框架技术,分享前后端开发资源,服务端教程技术,菜鸟程序员!',      link: 'http://www.cuiyongzhi.com/',      imgUrl: 'http://res.cuiyongzhi.com/2016/03/201603201591_339.png',      trigger: function (res) {        // 不要尝试在trigger中使用ajax异步请求修改本次分享的内容,因为客户端分享操作是一个同步操作,这时候使用ajax的回包会还没有返回        alert('用户点击发送给朋友');      },      success: function (res) {        alert('已分享');      },      cancel: function (res) {        alert('已取消');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });    alert('已注册获取“发送给朋友”状态事件');  };   // 2.2 监听“分享到朋友圈”按钮点击、自定义分享内容及分享结果接口  onMenuShareTimelinefunction () {    wx.onMenuShareTimeline({      title: '菜鸟程序员成长之路!',      link: 'http://www.cuiyongzhi.com/',      imgUrl: 'http://res.cuiyongzhi.com/2016/03/201603201591_339.png',      trigger: function (res) {        // 不要尝试在trigger中使用ajax异步请求修改本次分享的内容,因为客户端分享操作是一个同步操作,这时候使用ajax的回包会还没有返回        alert('用户点击分享到朋友圈');      },      success: function (res) {        alert('已分享');      },      cancel: function (res) {        alert('已取消');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });    alert('已注册获取“分享到朋友圈”状态事件');  };   // 2.3 监听“分享到QQ”按钮点击、自定义分享内容及分享结果接口  onMenuShareQQfunction () {    wx.onMenuShareQQ({      title: '菜鸟程序员成长之路!',      desc: '关注java平台开发,前后端框架技术,分享前后端开发资源,服务端教程技术,菜鸟程序员!',      link: 'http://www.cuiyongzhi.com/',      imgUrl: 'http://res.cuiyongzhi.com/2016/03/201603201591_339.png',      trigger: function (res) {        alert('用户点击分享到QQ');      },      complete: function (res) {        alert(JSON.stringify(res));      },      success: function (res) {        alert('已分享');      },      cancel: function (res) {        alert('已取消');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });    alert('已注册获取“分享到 QQ”状态事件');  };     // 2.4 监听“分享到微博”按钮点击、自定义分享内容及分享结果接口  onMenuShareWeibofunction () {    wx.onMenuShareWeibo({     title: '菜鸟程序员成长之路!',      desc: '关注java平台开发,前后端框架技术,分享前后端开发资源,服务端教程技术,菜鸟程序员!',      link: 'http://www.cuiyongzhi.com/',      imgUrl: 'http://res.cuiyongzhi.com/2016/03/201603201591_339.png',      trigger: function (res) {        alert('用户点击分享到微博');      },      complete: function (res) {        alert(JSON.stringify(res));      },      success: function (res) {        alert('已分享');      },      cancel: function (res) {        alert('已取消');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });    alert('已注册获取“分享到微博”状态事件');  };   // 2.5 监听“分享到QZone”按钮点击、自定义分享内容及分享接口  onMenuShareQZonefunction () {    wx.onMenuShareQZone({      title: '菜鸟程序员成长之路!',      desc: '关注java平台开发,前后端框架技术,分享前后端开发资源,服务端教程技术,菜鸟程序员!',      link: 'http://www.cuiyongzhi.com/',      imgUrl: 'http://res.cuiyongzhi.com/2016/03/201603201591_339.png',      trigger: function (res) {        alert('用户点击分享到QZone');      },      complete: function (res) {        alert(JSON.stringify(res));      },      success: function (res) {        alert('已分享');      },      cancel: function (res) {        alert('已取消');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });    alert('已注册获取“分享到QZone”状态事件');  };

③设备信息接口–这里是获取设备网络状态,以防在页面中存在视频或者大流量文件播放的时候对用户给出友好提示!

12345678910111213141516   // 3 设备信息接口  // 3.1 获取当前网络状态  getNetworkTypefunction () {    wx.getNetworkType({      success: function (res) {        alert(res.networkType);        var networkType = res.networkType; // 返回网络类型2g,3g,4g,wifi        if(networkType=='3g'){            alert("您好,您的网络状态是3g网络,这里将播放视频文件会产生大流程!");        }      },      fail: function (res) {        alert(JSON.stringify(res));      }    });  };

④地理位置接口,这里包含查看经纬度对应的地图位置和获取当前位置的经纬度,可用做地图位置展示的第一步!

123456789101112131415161718192021222324   // 4 地理位置接口  // 4.1 查看地理位置  openLocationfunction () {    wx.openLocation({      latitude: 23.099994,      longitude: 113.324520,      name: 'TIT 创意园',      address: '广州市海珠区新港中路 397 号',      scale: 14,      infoUrl: 'http://weixin.qq.com'    });  };   // 4.2 获取当前地理位置  getLocationfunction () {    wx.getLocation({      success: function (res) {        alert(JSON.stringify(res));      },      cancel: function (res) {        alert('用户拒绝授权获取地理位置');      }    });  };

⑤界面操作接口,这里说的界面操作其实就是在微信浏览器中操作和改名的那右上角的【三个点】,对这里隐藏的菜单进行操作和关闭微信浏览器!

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667   // 5 界面操作接口  // 5.1 隐藏右上角菜单  hideOptionMenufunction () {    wx.hideOptionMenu();  };   // 5.2 显示右上角菜单  showOptionMenufunction () {    wx.showOptionMenu();  };   // 5.3 批量隐藏菜单项  hideMenuItemsfunction () {    wx.hideMenuItems({      menuList: [        'menuItem:readMode'// 阅读模式        'menuItem:share:timeline'// 分享到朋友圈        'menuItem:copyUrl' // 复制链接      ],      success: function (res) {        alert('已隐藏“阅读模式”,“分享到朋友圈”,“复制链接”等按钮');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });  };   // 5.4 批量显示菜单项  showMenuItemsfunction () {    wx.showMenuItems({      menuList: [        'menuItem:readMode'// 阅读模式        'menuItem:share:timeline'// 分享到朋友圈        'menuItem:copyUrl' // 复制链接      ],      success: function (res) {        alert('已显示“阅读模式”,“分享到朋友圈”,“复制链接”等按钮');      },      fail: function (res) {        alert(JSON.stringify(res));      }    });  };   // 5.5 隐藏所有非基本菜单项  hideAllNonBaseMenuItemfunction () {    wx.hideAllNonBaseMenuItem({      success: function () {        alert('已隐藏所有非基本菜单项');      }    });  };   // 5.6 显示所有被隐藏的非基本菜单项  showAllNonBaseMenuItemfunction () {    wx.showAllNonBaseMenuItem({      success: function () {        alert('已显示所有非基本菜单项');      }    });  };   // 5.7 关闭当前窗口  closeWindowfunction () {    wx.closeWindow();  };

⑥微信扫一扫接口,这个接口可以在页面调用微信的扫一扫功能,其中参数needResult可以设置扫描之后的处理方式;

12345678   // 6 微信原生接口 wx.scanQRCode({    needResult: 0, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,    scanType: ["qrCode","barCode"], // 可以指定扫二维码还是一维码,默认二者都有    success: function (res) {    var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果}});
上一篇: What is SCons?
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,104
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,580
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,428
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,200
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,835
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,918