이 글에서는 주로 Vue의 WeChat 공유 기능을 소개합니다. Vue는 현재 페이지에서 특정 참고 가치가 있는 다른 페이지를 공유할 수 있도록 하여 모든 사람에게 도움이 되기를 바랍니다.
이 글의 예시는 참고용으로 Vue WeChat 공유 화면의 특정 코드를 공유합니다. 구체적인 내용은 다음과 같습니다
먼저 친구와 공유하는 것을 예로 들어보세요
1. 먼저 공식 문서를 읽어보세요
wx.onMenuShareAppMessage({ title: '', // 分享标题 desc: '', // 分享描述 link: '', // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致 imgUrl: '', // 分享图标 type: '', // 分享类型,music、video或link,不填默认为link dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空 success: function () { // 用户确认分享后执行的回调函数 }, cancel: function () { // 用户取消分享后执行的回调函数 } });
2. vue 공유의 함정
* 1. WeChat 공유에서 동적 URL 얻기
* 2. WeChat 보조 공유 form=singlemessage에 의해 자동으로 추가되는 매개변수
* 3. Vue의 각 페이지는 공유를 호출할 수 있습니다
3. 직접 코드 분석
각 페이지에서 WeChat 공유를 활성화하려면 시계 모니터링
코드
watch: { // 监听 $route 变化调用分享链接 "$route"(to, from) { let currentRouter = this.$router.currentRoute.fullPath; if(currentRouter.indexOf('userShare') == -1){ //如果不是userShare分享页面,则分享另外一个接口 this.shareOut(); }else{ this.shareOutTwo(); //当前页面是userShare页面时分享调用另外一个接口 } } },
4, shareOut() 기능
let signStr = ''; //sha1加密字符串 let timestamp = 1473254558; //时间戳 let nonceStr = 'shupao'; var obj = { title:"", //标题 desc:"文字描述", //描述 link:"http://www.XXXXXX.com/wx/pub/sr/simpleRegister.do", imgUrl:"http://XXXXXXXXX.com/picactive.jpg" }; this.$ydkAjax({ SENTYPE: "GET", url: this.$domain + '/wx/pub/common/getJsApiTicket.json', //自己服务器获取jsapi_ticket接口 params: null, successFc: (response) => { //拼接sha1加密字符串 signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '×tamp=' + timestamp + '&url=' + window.location.href; var signature = SHA1(signStr); wx.config({ debug: false, appId: "wx6957b3a945a05e90", //appId timestamp: timestamp, //时间戳 nonceStr: nonceStr, //加密需要字符串(自己定义的) signature: signature, //sha1加密后字符串 jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage'] }); wx.ready(function () { //分享到朋友圈" wx.onMenuShareTimeline({ title: obj.title, link: obj.link, // 分享链接 imgUrl: obj.imgUrl, // 分享图标 success: function () { // console.log('分享到朋友圈成功') }, cancel: function () { // console.log('分享到朋友圈失败') } }); //分享给朋友 wx.onMenuShareAppMessage({ title: obj.title, // 分享标题 desc: obj.desc, // 分享描述 link: obj.link, // 分享链接 imgUrl: obj.imgUrl, // 分享图标 success: function () { // console.log('分享到朋友成功') }, cancel: function () { // console.log('分享到朋友失败') } }); }) }, isLayer: false })
5을 추가해야 합니다. vue 루트 구성 요소에서 참고할 사항
*1. URL은 window.location.href.split(“#”)[0]을 통하지 않고 window.location.href를 통해 직접 가져옵니다. 왜냐하면 내 vue 프로젝트가 해시 모드를 사용하기 때문입니다. 경로 점프를 수행하려면 window.location.href.split(“#”)[0]을 직접 사용하면 서명이 실패하게 됩니다
//拼接sha1加密字符串 signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '×tamp=' + timestamp + '&url=' + window.location.href
*2. 현재 페이지를 다른 사용자와 공유해야 합니다. .열면 현재 공유 페이지가 아닙니다. 다른 페이지에 연결하려면 shareOut() 함수의 obj 개체에서 링크 매개 변수를 조정해야 합니다.
암호화된 URL 및 공유 개체 위 5개 질문의 문자열 요약입니다. 원래 목적은 현재 페이지의 다른 페이지에 대한 링크를 공유하는 것이므로 링크의 페이지 링크는 동일하게 유지될 필요가 없습니다. 나는 인터넷에서 이 두 개가 동일하게 유지되어야 한다고 말하는 것을 보았습니다. 실제로 Vue 프로젝트의 페이지 중 하나를 공유한 다음 두 페이지의 일관성을 유지하기 위해 현재 페이지만 공유하지 않는 한 이는 필요하지 않습니다.
관련 권장 사항:
위 내용은 Vue는 현재 페이지에서 다른 페이지를 공유하는 방법을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!