Vue项目history模式下微信分享爬坑总结

  

「Vue项目history模式下微信分享爬坑总结」这篇攻略主要是在Vue项目开发中,针对微信分享的一些问题和解决方案进行总结,并重点介绍了在使用history模式下遇到的问题和解决方法,下面是详细的攻略:

1. 什么是Vue项目history模式下的微信分享?

在Vue的路由模式下,有两种路由方式:hash和history。history模式利用了HTML5 History Interface中新增的pushState()和replaceState()方法,用来完成URL的变化,而不需要重新加载页面。同时,history模式也会出现一些问题,尤其是在微信分享的时候。

2. 微信分享的问题

在微信分享中,我们需要在页面的头部加入如下代码:

<script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
<script>
  wx.config({
    // 配置信息
  });

  wx.ready(function() {
    // 分享信息
  });
</script>

然而,在使用history模式后,页面切换的时候,并不会重新加载页面,而是通过路由切换。这样就会导致以上代码只会在第一次加载时生效,后面的路由切换都没有再次加载。因此,我们需要解决这个问题,让微信分享在每次路由切换的时候都能够生效。

3. 解决方案

为了解决这个问题,我们可以在Vue项目中使用Vue Router的导航守卫实现在每次路由切换时都重新加载页面。具体有两种方法:

3.1 利用beforeEach导航守卫

在路由配置文件中,我们可以使用beforeEach导航守卫监听路由变化事件,当路由变化的时候,重新加载一遍页面。代码示例如下:

router.beforeEach((to, from, next) => {
  window.location.reload();
  next();
});

这种方法的缺点在于,无论是路由变化还是其他的原因,都会重新加载页面。

3.2 利用微信API的重新加载事件

在微信分享的API中,我们可以监听在“分享成功”、“分享失败”、“取消分享”等事件,当这些事件触发的时候,重新加载一遍页面。代码示例如下:

wx.ready(function() {
  // 分享信息

  wx.onMenuShareTimeline({
    success: function() { // 分享到朋友圈成功
      window.location.reload();
    },
    fail: function() { // 分享到朋友圈失败
      window.location.reload();
    },
    cancel: function() { // 分享到朋友圈取消
      window.location.reload();
    }
  });

  wx.onMenuShareAppMessage({ // 分享到微信好友
    success: function() {
      window.location.reload();
    },
    fail: function() {
      window.location.reload();
    },
    cancel: function() {
      window.location.reload();
    }
  });
});

这种方法的好处在于只会重新加载页面,当触发其他事件时不会重新加载页面。

4. 示例说明

4.1 利用beforeEach导航守卫的示例

在路由配置文件中,我们可以像下面这样监听路由变化事件:

import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)

const routes = [
  // 路由配置
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

router.beforeEach((to, from, next) => {
  window.location.reload();
  next();
});

export default router

这种方法的缺点在于,无论是路由变化还是其他的原因,都会重新加载页面。

4.2 利用微信API的重新加载事件的示例

在微信分享的API中,我们可以像下面这样监听微信分享的事件:

import wx from 'weixin-js-sdk'

export function shareWX() {
  wx.ready(function() {
    wx.onMenuShareTimeline({
      success: function() { // 分享到朋友圈成功
        window.location.reload();
      },
      fail: function() { // 分享到朋友圈失败
        window.location.reload();
      },
      cancel: function() { // 分享到朋友圈取消
        window.location.reload();
      }
    });

    wx.onMenuShareAppMessage({ // 分享到微信好友
      success: function() {
        setTimeout(() => {
          window.location.reload();
        }, 500);
      },
      fail: function() {
        setTimeout(() => {
          window.location.reload();
        }, 500);
      },
      cancel: function() {
        setTimeout(() => {
          window.location.reload();
        }, 500);
      }
    });
  });

  // 配置信息
}

这种方法的好处在于只会重新加载页面,当触发其他事件时不会重新加载页面。

5. 总结

Vue项目在使用history模式时,微信分享会遇到一些问题。我们可以通过使用Vue Router的导航守卫或者微信API的重新加载事件来解决这个问题。同时在分享的时候,还需要注意图片的大小和链接的正确性,这也是会影响分享效果的原因。

相关文章