>웹 프론트엔드 >JS 튜토리얼 >vue에서 다른 페이지의 현재 페이지 공유 기능을 구현하는 방법

vue에서 다른 페이지의 현재 페이지 공유 기능을 구현하는 방법

亚连
亚连원래의
2018-06-22 18:14:183060검색

이 글에서는 주로 Vue WeChat 공유 기능을 모든 사람에게 자세히 소개합니다. Vue는 특정 참조 가치가 있는 다른 페이지를 공유하기 위해 현재 페이지를 구현합니다. 관심 있는 친구는 이를 참조할 수 있습니다.

이 글의 예는 Vue WeChat 공유를 공유합니다. 구체적인 내용은 다음과 같습니다

먼저 친구와 공유하는 것을 예로 들어보세요

1. vue 공유의 함정

* 1. WeChat 공유에서 동적 URL 가져오기

* 2. WeChat 보조 공유 form=singlemessage에 의해 자동으로 추가된 매개변수

* 3. vue의 각 페이지는 공유를 호출할 수 있습니다.

3. 각 페이지가 WeChat 공유를 호출할 수 있어야 합니다. vue 루트 구성 요소에 시계 모니터링

코드

wx.onMenuShareAppMessage({

  title: '', // 分享标题

  desc: '', // 分享描述

  link: '', // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致

  imgUrl: '', // 分享图标

  type: '', // 分享类型,music、video或link,不填默认为link

  dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空

  success: function () {

    // 用户确认分享后执行的回调函数

  },

  cancel: function () {

    // 用户取消分享后执行的回调函数

  }

});

4. shareOut() 함수

watch: {
    // 监听 $route 变化调用分享链接
    "$route"(to, from) {
      let currentRouter = this.$router.currentRoute.fullPath;  
      if(currentRouter.indexOf('userShare') == -1){   
     //如果不是userShare分享页面,则分享另外一个接口
        this.shareOut();
      }else{
        this.shareOutTwo();     
     //当前页面是userShare页面时分享调用另外一个接口   
      }
    }
  },

5. 참고 사항

*1. URL은 창을 통해 직접 가져옵니다. .location.href, window.location .href.split(“#”)[0]을 사용하지 않음, 내 vue 프로젝트가 라우팅 점프에 해시 모드를 사용하기 때문에 window.location.href.split(“#”)을 직접 사용하여 획득 [0]은 Signature failed

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
      })

*2를 유발하며 현재 페이지를 공유하려고 하며 현재 공유 페이지가 아닐 때 다른 사용자가 해당 페이지를 열 것입니다. 이를 위해서는 shareOut의 obj 개체에서 link 매개 변수를 조정해야 합니다. () 함수를 사용하여 다른 페이지로 연결

6. 링크 매개변수

위 5가지 질문의 암호화된 문자열 요약 URL과 공유 개체의 링크에 포함된 페이지 링크는 동일하게 유지될 필요가 없습니다. 목적은 현재 페이지의 다른 페이지에 대한 링크를 공유하는 것입니다. 나는 인터넷에서 이 두 개가 동일하게 유지되어야 한다고 말하는 것을 보았습니다. 실제로 Vue 프로젝트의 페이지 중 하나를 공유한 다음 두 페이지의 일관성을 유지하기 위해 현재 페이지만 공유하지 않는 한 이는 필요하지 않습니다.

위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

JavaScript 배열 작업의 어려움에 대해(자세한 튜토리얼)

vue를 사용하여 원활한 스크롤 구성 요소를 구현하는 방법

knockoutjs에서 Flux를 구현하는 방법

프런트 구축 방법 -범용 데이터 시뮬레이션 프레임워크 종료(자세한 튜토리얼)

위 내용은 vue에서 다른 페이지의 현재 페이지 공유 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.