この記事では主に Vue の WeChat 共有機能について詳しく紹介します。Vue は現在のページを他のページに共有することができます。興味のある方はぜひ参考にしてください。
この記事の例では、参考のために Vue WeChat 共有表示の具体的なコードを共有します。具体的な内容は次のとおりです
まず、友達との共有を例に挙げます
まず、公式ドキュメントをお読みください
。
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. 私の vue プロジェクトはハッシュモードを使用しているため、URL は window.location.href.split(“#”)[0] ではなく window.location.href を通じて直接取得されます。ルートジャンプを実行するには、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 つの質問の要約です。本来の目的は現在のページ上の他のページへのリンクを共有することなので、リンク内のページ リンクは同じである必要はありません。インターネット上で、これら 2 つは同じでなければならないと言っている人を見かけました。実際、Vue プロジェクトのページの 1 つを共有し、2 つの一貫性を保つために現在のページのみを共有する場合を除いて、その必要はありません。
関連する推奨事項:
以上がVue は現在のページに他のページを共有するメソッドを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。