Vue实现微信分享好友,分享朋友圈。

实现微信分享功能。

1 、基于vue去实现在微信里去分享给你的微信好友,或者去分享到你的朋友圈里。如果是react 等等 一样用法。
2、目前实现微信分享功能是通过点击微信控件触发的,代码拿走直接用,因为分享出来的是一个有标题,有描述,有图标的一个类似连接,所以灵活使用,分享地址,分享图片,分享的话术等等根据各自的需求去写。
3、使用到微信官网的api
通过 npm i weixin-js-sdk 安装。
最好在项目的main.js里暴露出来。

html部分

  <div class="box">
   <button @click="shareFriend">分享好友</button>
   <button @click="shareGroup">分享朋友圈</button>
  </div>

简单粗暴,样式不细写。
注意:尽量要在页面创建时去拿到配置项,然后注入配置信息。

js部分

export default {
  data(){
    return{
      //必须配置项,从接口获取
      appId:"",
      timestamp:"",
      noncstr:"",
      signatureInfo:"",
      // 自配项
      imgurl:"",//分享图片(如分享出来链接上显示的小图标)
      url:"",//分享地址(如分享出来一个链接,点链接要跳的页面地址)
    }
  },
  created(){
    //指的是要做分享的页面的url送过去,请求成功才能拿到
    let url = location.href.split('#')[0];
    this.$axios({
       url:'/use/shareurl',//请求微信分享的接口地址
       method:'post',
       data:url,
    }).then(res=>{
      if(res.data.success){
        //这些配置参数必填项,后面去调微信的pai是需要传的。
        this.appId = res.data.appId;
        this.timestamp = res.data.timestamp;
        this.noncstr = res.data.noncstr;
        this.signatureInfo = res.data.signatureInfo;
      }
    }).catch(err=>{console.log(err)})
  },
  methods:{
    shareFriend(){//当点击分享好友按钮时
      //怎么取图片的地址取决于你放图片的路径,你也可以用线上图片,也可以放在你们的服务器上。
       this.imgurl = location.href.split('/index')[0] + "/static/shareimg.jpg";
       this.url = "这里是你要分享出来的页面的地址";
       this.title="这是一个王哈哈";
       this.desc="小绵羊呀小绵羊呀小绵羊呀小绵羊呀小绵羊呀分享好友呀呀哎呀呀啊";
       this.goshare()
    },
    goshare(){
      let that = this;
      //开始注入配置项
      wx.config({
        debug:false,//是否打开debug调试模式。
        appId:this.appId,	//必填,公众号唯一标识
        timestamp:this.timestamp,	//必填,生成签名的时间戳
        nonceStr:this.noncstr,	//必填,生成签名的随机串
        signature:this.signatureInfo,	//必填,生成的签名
        jsApiList:['onMenuShareTimeline','onMenuShareAppMessage']	//必填,允许分享好友,分享朋友圈
      })
      wx.error((res)=>{//配置成功
        for(var msg in res){
          let obj = {
            showAlert:true,
            errTitle:"错误提示",
            errMsg:JSON.stringify(res[msg]),
            errCode:""  
          }
        } 
      })
      //以上是配置项注入成功
      wx.ready(()=>{//点击要去分享
        wx.onMenuShareTimeline({//配置去分享朋友圈的选项
          title :this.share.title,//分享标题
          link : this.share.url, //分享链接
          imgUrl : this.share.imgurl, //分享图标
          success : function(res){//分享成功 
            console.log("已分享朋友圈成功")
            //如分享成功后想做一些其他的业务处理,可以在这里做
          },
          cancel:function(){
            //that.alert="失败弹框话术等等(注意 这里拿不到this实例的)"
            console.log("已分享失败")
          }
        })
        wx.onMenuShareAppMessage({//配置去分享好友的选项
          title :  this.share.title,  
          link :  this.share.url,    		
          desc : this.share.desc,             
          imgUrl : this.share.imgurl ,                            
          success : function(res){
            console.log("分享好友成功")
          },
          cancel:function(res){
            console.log("分享失败") 
          }
        });
      })
    },
  }
  
}

如果想给分享连接带参也是可以。
注意:到目前为止,是不能自动去调微信的分享控件按钮(指右上角的…)直接分享的,建议最好做个页面引导去手动通过控件按钮分享。

效果图:
在这里插入图片描述

在这里插入图片描述
总结:
1、分享的连接,分享的图片地址,域名尽量不要带端口号,把https替为 http。去调分享接口(获取配置信息时)传给后台的url的域名要和分享连接的域名保持一致(指路由之前的部分)
2、分享的连接里(路由之前的部分)不要带&符号
3、从别的页面跳到要分享的页面时,尽量用location.href= url
否则容易报签名配置失败,导致拿不到配置信息。

到这里就结束了,备注也加了。如果你项目用到分享很频繁,建议封装整理下,避免重复代码,有问题或者好的建议可以私聊。共同学习共同进步。

------努力努力再努力。

  • 18
    点赞
  • 52
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
Vue H5页面中实现微信分享,可以按照以下步骤进行: 第一步,获取微信分享所需的相关配置: 在Vue项目中引入微信开放平台的JS-SDK,然后通过微信开放平台接口获取到当前页面的分享配置信息,包括标题、描述、链接和图片等信息。 第二步,调用微信JS-SDK进行分享: 在Vue的组件中,通过引入微信JS-SDK提供的方法,如`wx.onMenuShareTimeline`和`wx.onMenuShareAppMessage`等,来实现对应的分享功能。可以将这些方法封装成一个单独的util文件,方便在项目中多次调用。 第三步,配置分享参数: 调用微信JS-SDK的分享方法前,需要将获取到的分享配置信息传入相应的参数中,如标题、链接、描述和分享图等。可以根据当前页面的不同内容来动态设置分享的参数。 第四步,设置微信签名: 在Vue页面中,可以使用`vue-router`插件进行路由控制,当进入到需要分享的页面时,通过异步请求来获取当前页面的分享配置信息和签名,然后将签名设置给微信JS-SDK。 第五步,调用分享方法: 在上面的配置完成后,即可通过微信JS-SDK提供的分享方法,如`wx.onMenuShareTimeline`和`wx.onMenuShareAppMessage`等,来实现对应的分享功能。可以按需选择分享朋友圈、发送给好友分享到QQ等渠道。 需要注意的是,Vue H5页面在与微信分享时,由于所处的环境和限制会有所不同,可能需要在不同的事件中触发分享,比如在路由切换完成后触发分享方法。 以上是实现Vue H5页面分享微信的一般步骤,具体实现还需要根据项目的需求和微信开放平台的接口文档进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值