欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue微信分享的實現(xiàn)(在當前頁面分享其他頁面)

 更新時間:2019年04月16日 15:08:55   作者:敵人-別人家的孩子  
這篇文章主要介紹了vue微信分享,在當前頁面分享其他頁面,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

首先以分享給朋友為例

1、先看官方文檔

wx.onMenuShareAppMessage({

  title: '', // 分享標題

  desc: '', // 分享描述

  link: '', // 分享鏈接,該鏈接域名或路徑必須與當前頁面對應(yīng)的公眾號JS安全域名一致

  imgUrl: '', // 分享圖標

  type: '', // 分享類型,music、video或link,不填默認為link

  dataUrl: '', // 如果type是music或video,則要提供數(shù)據(jù)鏈接,默認為空

  success: function () {

    // 用戶確認分享后執(zhí)行的回調(diào)函數(shù)

  },

  cancel: function () {

    // 用戶取消分享后執(zhí)行的回調(diào)函數(shù)

  }

});

2、vue分享踩的坑

* 1、微信分享中獲取動態(tài)的url
* 2、 微信二次分享自動添加的參數(shù)     form=singlemessage
* 3、vue中各個頁面都可以調(diào)用分享

3、直接代碼分析

為了保證每個頁面都可以調(diào)起微信分享,需要在vue根組件中,添加 watch監(jiān)聽

代碼

watch: {
    // 監(jiān)聽 $route 變化調(diào)用分享鏈接
    "$route"(to, from) {
      let currentRouter = this.$router.currentRoute.fullPath;  //
      if(currentRouter.indexOf('userShare') == -1){   //如果不是userShare分享頁面,則分享另外一個接口
        this.shareOut();
      }else{
        this.shareOutTwo();     //當前頁面是userShare頁面時分享調(diào)用另外一個接口   
      }
    }
  },

4、shareOut()函數(shù)

      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', //自己服務(wù)器獲取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是直接通過 window.location.href 獲取的,不是使用 window.location.href.split(“#”)[0]來獲取, 因為我的vue項目是通過hash模式來進行路由跳轉(zhuǎn)的 , 直接使用 window.location.href.split(“#”)[0]會導(dǎo)致簽名失敗

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

*2、而且我們要在當前頁面分享出去之后 , 其他用戶打開之后 不是當前分享出去的頁面 ,這就需要 調(diào)整 shareOut()函數(shù)中 obj對象中的 link參數(shù)為其他頁面鏈接

6、link參數(shù)

上述 5 問題中的加密字符串匯總的 url 和 分享對象中 link中的頁面鏈接可以不用保持一樣,因為本來就是要在當前頁面分享出去其他頁面的鏈接。網(wǎng)上我看到有人說這兩個必須要保持一樣,其實沒有必要, 除非你只是簡單的在vue項目中的其中一個頁面做分享 , 然后只分享當前頁面才需要讓二者保持一致性。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 淺談Vue 初始化性能優(yōu)化

    淺談Vue 初始化性能優(yōu)化

    本篇文章主要介紹了淺談Vue 初始化性能優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Vue程序調(diào)試的方法

    Vue程序調(diào)試的方法

    這篇文章主要介紹了VUE程序調(diào)試的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • VUE 實現(xiàn)一個簡易老虎機的項目實踐

    VUE 實現(xiàn)一個簡易老虎機的項目實踐

    老虎機在很多地方都可以見到,可以設(shè)置中獎位置,以及中獎回調(diào),本文主要介紹了VUE 實現(xiàn)一個簡易老虎機的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 基于vue-cli3創(chuàng)建libs庫的實現(xiàn)方法

    基于vue-cli3創(chuàng)建libs庫的實現(xiàn)方法

    這篇文章主要介紹了基于vue-cli3創(chuàng)建libs庫的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Vue項目中使用jquery的簡單方法

    Vue項目中使用jquery的簡單方法

    這篇文章主要給大家介紹了關(guān)于Vue項目中使用jquery的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • webpack項目中使用vite加速的兼容模式詳解

    webpack項目中使用vite加速的兼容模式詳解

    這篇文章主要為大家介紹了webpack項目中使用vite加速的兼容模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Electron中打包應(yīng)用程序及相關(guān)報錯問題的解決

    Electron中打包應(yīng)用程序及相關(guān)報錯問題的解決

    這篇文章主要介紹了Electron中打包應(yīng)用程序及相關(guān)報錯問題的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue之父組件向子組件傳值并改變子組件的樣式

    vue之父組件向子組件傳值并改變子組件的樣式

    這篇文章主要介紹了vue之父組件向子組件傳值并改變子組件的樣式,需要的朋友可以參考下
    2022-12-12
  • vue.js 獲取select中的value實例

    vue.js 獲取select中的value實例

    下面小編就為大家分享一篇vue.js 獲取select中的value實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 關(guān)于vue自適應(yīng)布局(各種瀏覽器,分辨率)的示例代碼

    關(guān)于vue自適應(yīng)布局(各種瀏覽器,分辨率)的示例代碼

    這篇文章主要介紹了vue自適應(yīng)布局(各種瀏覽器,分辨率),主要使用了flex布局的flex:1屬性和自適應(yīng)的css+vh+百分比這種方式,開局設(shè)置overflow:hidden,主體main部分要設(shè)置:overflow:auto,需要的朋友可以參考下
    2022-09-09

最新評論