ホームページ  >  記事  >  ウェブフロントエンド  >  vueで他のページの現在のページ共有機能を実装する方法

vueで他のページの現在のページ共有機能を実装する方法

亚连
亚连オリジナル
2018-06-22 18:14:183022ブラウズ

この記事では主に 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. 1. WeChat 共有で動的 URL を取得します

* 2. WeChat の二次共有 form=singlemessage によって自動的に追加されるパラメーター

* 3. Vue の各ページは共有を呼び出すことができます

3. 各ページがWeChat 共有を呼び出すには、vue ルート コンポーネントに監視監視コードを追加します

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 + '&timestamp=' + 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. 注意事項

*1 URL はウィンドウを通じて直接取得されます。 .location.href、取得に window.location .href.split(“#”)[0] を使用しません。私の vue プロジェクトはルーティング ジャンプにハッシュ モードを使用しているため、window.location.href.split(“#”) を直接使用します。 [0] は署名失敗

//拼接sha1加密字符串
signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '&timestamp=' + timestamp + '&url=' + window.location.href

*2 を引き起こし、現在のページを共有したいのですが、現在の共有ページではないときに他のユーザーがそれを開くことになります。これには、shareOut の obj オブジェクトのリンク パラメーターを調整する必要があります。 () 他のページにリンクする関数

6. リンクパラメータ

上記5つの質問の暗号化文字列概要のURLと、共有オブジェクト内のリンク内のページリンクは、元のページにリンクされているため、同じにする必要はありません。目的は、現在のページ上の他のページへのリンクを共有することです。インターネット上で、これら 2 つは同じでなければならないと言っている人を見かけました。実際、Vue プロジェクトのページの 1 つを共有し、2 つの一貫性を保つために現在のページのみを共有する場合を除いて、その必要はありません。

上記は私があなたのためにまとめたものです。

関連記事:

JavaScriptの配列操作の難しさについて(詳しいチュートリアル)

vueを使ったシームレスなスクロールコンポーネントの実装方法

knockoutjsにfluxを実装する方法

フロントの構築方法- ユニバーサル データ シミュレーション フレームワーク (詳細なチュートリアル) を終了

以上がvueで他のページの現在のページ共有機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。