vue爬坑路之----微信转发分享功能

19

vue爬坑路之----微信转发分享功能

?? Vue Crawling Pit: WeChat Forward Sharing Functionality ??As a Vue developer, you may have encountered the frustration of implementing a WeChat forward sharing functionality that only shares the basic page URL without any additional details or images. In this article, we'll dive into the pit and explore the solution to this problem.

The Problem

When implementing a WeChat forward sharing function in your Vue application, you might notice that the shared link only contains the basic page URL, without any additional information such as page title, description, or images. This can be quite disappointing, especially if you're trying to share rich content with your users.

The Cause

After some research and experimentation, we discovered that the root cause of this issue is due to the way WeChat handles forward sharing links. When you generate a sharing link using the WeChat API, it expects the link to be in a specific format, which includes the page title, description, and other metadata.

However, when you pass the backend-generated link to the frontend, it's likely that the link is not formatted correctly for WeChat's requirements. This can result in the shared link only containing the basic page URL, without any additional information.

The Solution

To overcome this issue, we need to generate a sharing link that meets WeChat's requirements. Here are the steps to achieve this:

1. Get the current page URL: Use Vue's built-in `window.location` object or a library like `vue-router` to get the current page URL.

2. Generate the sharing link: Create a new URL using the current page URL and add any additional metadata required by WeChat, such as:

* Page title: Use the `` tag from your HTML file or generate it dynamically based on your application's data.</p><p>* Description: Extract the description text from your HTML file or generate it dynamically based on your application's data.</p><p>* Images: Add any relevant images to the sharing link, such as thumbnails or featured images.</p><p>3. <strong>Pass the generated link to the backend</strong>: Send the generated sharing link to your backend server using an AJAX request or a library like Axios.</p><p>4. <strong>Use the generated link in WeChat API</strong>: In your backend code, use the generated link as the sharing link for WeChat's forward sharing functionality.</p><p><strong>Example Code</strong></p><p>Here's some sample Vue code that demonstrates how to generate a sharing link and pass it to the backend:</p><p>```javascript<template></p><p> <div></p><p> <!-- Your page content here --></p><p> <button @click="sharePage">Share Page</button></p><p> </div></p><p></template></p><p><script></p><p>export default {</p><p> methods: {</p><p> sharePage() {</p><p> const currentPageUrl = window.location.href;</p><p> const pageTitle = document.title;</p><p> const pageDescription = 'Your page description';</p><p> const images = ['image1.jpg', 'image2.jpg'];</p><p> // Generate the sharing link const sharingLink = `${currentPageUrl}?title=${pageTitle}&description=${pageDescription}&images=${images.join(',')}`;</p><p> // Pass the generated link to the backend axios.post('/share-page', { sharingLink })</p><p> .then(response => {</p><p> console.log('Sharing link sent successfully!');</p><p> })</p><p> .catch(error => {</p><p> console.error('Error sending sharing link:', error);</p><p> });</p><p> }</p><p> }</p><p>}</p><p></script></p><p>```</p><p><strong>Conclusion</strong></p><p>In this article, we've explored the pit of WeChat forward sharing functionality in Vue and provided a solution to overcome the issue. By generating a sharing link that meets WeChat's requirements and passing it to the backend, you can share rich content with your users.</p><p>Remember to always test your implementation thoroughly to ensure that the shared link is correctly formatted and contains the desired metadata. Happy coding! ??</p> </p> <p class="tag-wrap mt mb"> <i class="icon icontag"></i> <a href="/tags_%e8%bd%ac%e5%8f%91_1.html" class="tags" title="转发">转发</a><a href="/tags_%e5%8a%9f%e8%83%bd_1.html" class="tags" title="功能">功能</a><a href="/tags_VUE_1.html" class="tags" title="VUE">VUE</a> </p> <div> <div class="alert alert-dismissible alert-secondary"> <div> <strong class="addr">本文地址:</strong> <a href="http://weixin.cidiancha.com/detail_34995.html" title="vue爬坑路之----微信转发分享功能" target="_blank">http://weixin.cidiancha.com/detail_34995.html</a> </div> <div><span class="copyright">版权声明:</span>除非特别标注,否则均为网络文章,侵权请联系站长删除。</div> </div> </div> </div> </article> <div class="prev-next article_border clearfix bgf"> <p class="post-prev fl ellipsis"> <span class="prev">上一篇</span><strong> <a href="/detail_34994.html" title="求!微信语音是怎么转发给别人的原理">求!微信语音是怎么转发给别人的原理</a> </strong> </p> <p class="post-next fr ellipsis"> <span class="next">下一篇</span><strong> <a href="/detail_34996.html" title="禁用微信分享功能">禁用微信分享功能</a> </strong> </p> </div> <div class="card bgf relarticle"> <div class="card-header"><b>相关文章</b></div> <div class="card-body pdl20 pdb20"> <ul class="ul clearfix"> <li class="related-item mt fl"> <a href="/detail_34998.html" title="为什么微信内无法分享转发网址,详谈微信网址防屏蔽的办法"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="" alt="为什么微信内无法分享转发网址,详谈微信网址防屏蔽的办法"> </span> <p class="titile">为什么微信内无法分享转发网址,详谈微信网址防屏蔽的办法</p> </a> </li> <li class="related-item mt fl"> <a href="/detail_34999.html" title="微信小程序点击一张图片触发转发功能"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="/UploadFile/pic/shuiyin/20240724/711abce87f4c410a9c61edd327c2b6dc.jpg" alt="微信小程序点击一张图片触发转发功能"> </span> <p class="titile">微信小程序点击一张图片触发转发功能</p> </a> </li> <li class="related-item mt fl"> <a href="/detail_35000.html" title="微信小程序实现转发功能以及真机调试跳坑(附代码)"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="/UploadFile/pic/shuiyin/20240724/f84d99de3e164cf09a9f8f64bcc89b4f.jpg" alt="微信小程序实现转发功能以及真机调试跳坑(附代码)"> </span> <p class="titile">微信小程序实现转发功能以及真机调试跳坑(附代码)</p> </a> </li> <li class="related-item mt fl"> <a href="/detail_35001.html" title="feat:使用企业微信JS-SDK的onMenuShareAppMessage()实现点击转发自定义分享内容(TypeScript)"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="/UploadFile/pic/shuiyin/20240724/98f1564acbf449cba85cc101e4770c85.jpg" alt="feat:使用企业微信JS-SDK的onMenuShareAppMessage()实现点击转发自定义分享内容(TypeScript)"> </span> <p class="titile">feat:使用企业微信JS-SDK的onMenuShareAppMessage()实现点击转发自定义分享内容(TypeScript)</p> </a> </li> <li class="related-item mt fl"> <a href="/detail_35002.html" title="【全局配置】uniapp 微信页面转发、分享到朋友圈,收藏"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="" alt="【全局配置】uniapp 微信页面转发、分享到朋友圈,收藏"> </span> <p class="titile">【全局配置】uniapp 微信页面转发、分享到朋友圈,收藏</p> </a> </li> <li class="related-item mt fl"> <a href="/detail_35003.html" title="微信H5分享到朋友圈,转发朋友功能随记"> <span class="span"> <img class="img br img-cover lazyload" src="" data-original="/UploadFile/pic/shuiyin/20240724/1e25d70851f74fc6831bdb622b7ac6ec.jpg" alt="微信H5分享到朋友圈,转发朋友功能随记"> </span> <p class="titile">微信H5分享到朋友圈,转发朋友功能随记</p> </a> </li> </ul> </div> </div> </div> <div class="col-md-3 hidden-sm" id="itemscontent"> <div class="articleitems"> <section class="card border-light mb-3 zxtj bgf"> <div class="card-header"><b>最新推荐</b></div> <div class="card-body"> <ul class="list-group"> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13288.html" title="怎么清理微信表情包"> <div class="new-text"> <p class="articletitle">怎么清理微信表情包</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 27 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13289.html" title="清除的微信聊天记录怎么恢复"> <div class="new-text"> <p class="articletitle">清除的微信聊天记录怎么恢复</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 27 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13290.html" title="微信评论删除了怎么恢复"> <div class="new-text"> <p class="articletitle">微信评论删除了怎么恢复</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 24 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13291.html" title="微信语音播放失败怎么解决"> <div class="new-text"> <p class="articletitle">微信语音播放失败怎么解决</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 26 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13292.html" title="微信密码怎么设置"> <div class="new-text"> <p class="articletitle">微信密码怎么设置</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 22 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13293.html" title="微信怎么长截图"> <div class="new-text"> <p class="articletitle">微信怎么长截图</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 22 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13294.html" title="手动删除的微信聊天记录怎么恢复"> <div class="new-text"> <p class="articletitle">手动删除的微信聊天记录怎么恢复</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 22 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13295.html" title="微信怎么设置朋友圈"> <div class="new-text"> <p class="articletitle">微信怎么设置朋友圈</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 23 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13296.html" title="微信群不能退出怎么办"> <div class="new-text"> <p class="articletitle">微信群不能退出怎么办</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 25 </span> </div> </div> </a> </li> <li class="list-group-item d-flex justify-content-between align-items-center"> <a href="/detail_13297.html" title="微信密码怎么设置"> <div class="new-text"> <p class="articletitle">微信密码怎么设置</p> <div class="info"> <span class="time"> <i class="icon icontime"> </i>2025-03-15 </span> <span class="view"> <i class="icon iconeye"></i> 25 </span> </div> </div> </a> </li> </ul> </div> </section> <section class="card border-light mb-3 wztj bgf"> <div class="card-header"><b>文章推荐</b></div> <div class="card-body"> <div class="list-group"> <a href="/detail_26144.html" title="华为秘盒M310支持推送移动终端媒体文件功能吗" class="list-group-item list-group-item-action"><span class="wztj-1">1.</span>华为秘盒M310支持推送移动终端媒体文件功能吗</a> <a href="/detail_36931.html" title="微信直播转链接或二维码方法,超级简单" class="list-group-item list-group-item-action"><span class="wztj-2">2.</span>微信直播转链接或二维码方法,超级简单</a> <a href="/detail_26147.html" title="怎么开通微信" class="list-group-item list-group-item-action"><span class="wztj-3">3.</span>怎么开通微信</a> <a href="/detail_36997.html" title="微信传送文件会经过服务器吗,微信可以传送大文件了" class="list-group-item list-group-item-action"><span class="wztj-4">4.</span>微信传送文件会经过服务器吗,微信可以传送大文件了</a> <a href="/detail_36998.html" title="电脑版微信防撤回怎么设置?" class="list-group-item list-group-item-action"><span class="wztj-5">5.</span>电脑版微信防撤回怎么设置?</a> <a href="/detail_26145.html" title="支付宝陕西信合储蓄卡快捷支付如何撤销" class="list-group-item list-group-item-action"><span class="wztj-6">6.</span>支付宝陕西信合储蓄卡快捷支付如何撤销</a> <a href="/detail_26146.html" title="理财通安全吗" class="list-group-item list-group-item-action"><span class="wztj-7">7.</span>理财通安全吗</a> <a href="/detail_26148.html" title="手机微信怎么截图" class="list-group-item list-group-item-action"><span class="wztj-8">8.</span>手机微信怎么截图</a> <a href="/detail_37574.html" title="iOS微信登录步骤" class="list-group-item list-group-item-action"><span class="wztj-9">9.</span>iOS微信登录步骤</a> <a href="/detail_26149.html" title="微信怎么发纯文字" class="list-group-item list-group-item-action"><span class="wztj-10">10.</span>微信怎么发纯文字</a> </div> </div> </section> <section class="card border-light mb-3 rmbq bgf"> <div class="card-header"><b>热门标签</b></div> <div class="card-body pdl20 pdb20"> <a href="tags_抖音直播_1.html" class="btn btn-success">抖音直播</a> <a href="tags_抖音网页版_1.html" class="btn btn-info">抖音网页</a> <a href="tags_抖音认证_1.html" class="btn btn-warning">抖音认证</a> <a href="tags_抖音视频_1.html" class="btn btn-danger">抖音视频</a> <a href="tags_抖音退款_1.html" class="btn btn-dark">抖音退款</a> <a href="tags_下载视频_1.html" class="btn btn-secondary">下载视频</a> <a href="tags_抖音客服_1.html" class="btn btn-info">抖音客服</a> <a href="tags_抖音团购_1.html" class="btn btn-warning">抖音团购</a> <a href="tags_抖音支付_1.html" class="btn btn-primary">抖音支付</a> <a href="tags_抖音活动_1.html" class="btn btn-dark">抖音活动</a> <a href="tags_抖音群聊_1.html" class="btn btn-primary">抖音群聊</a> <a href="tags_抖音粉丝_1.html" class="btn btn-info">抖音粉丝</a> <a href="tags_浏览记录_1.html" class="btn btn-success">浏览记录</a> <a href="tags_微信支付_1.html" class="btn btn-primary">微信支付</a> <a href="tags_视频剪辑_1.html" class="btn btn-dark">视频剪辑</a> <a href="tags_回复评论_1.html" class="btn btn-warning">回复评论</a> <a href="tags_抖音认证_1.html" class="btn btn-success">抖音认证</a> <a href="tags_提现记录_1.html" class="btn btn-dark">提现记录</a> </div> </section> <section class="card border-light mb-3 wzfl bgf"> <div class="card-header"><b>问题分类</b></div> <div class="card-body pdl20 pdb20"> <a class="btn btn-outline-secondary" href="/cateid_1_1.html" title="视频问题">视频问题</a> <a class="btn btn-outline-success" href="/cateid_2_1.html" title="运营推广">运营推广</a> <a class="btn btn-outline-danger" href="/cateid_3_1.html" title="直播问题">直播问题</a> <a class="btn btn-outline-dark" href="/cateid_10_1.html" title="常见问题">常见问题</a> <a class="btn btn-outline-warning" href="/cateid_99_1.html" title="其他问题">其他问题</a> </div> </section> <script> //$("img.lazyload").lazyload(); </script> </div> </div> </div> </div> <script> $(function () { $("img.lazyload").lazyload(); }); </script> </div> <footer id="footer" class="footer theme-bg-dark pt-5"> <div class="container text-center"> </div><div class="bottom-bar"> <div class="container"> <small class="copyright">Copyright © 2022 词典查 - cidiancha.com</small></div> <div class="legal-links"> <a href="http://beian.miit.gov.cn/" target="_blank" rel="nofollow">备案号:豫ICP备2021009024号-6</a>    <small>联系邮箱:290110527@qq.com</small></div> </div> </footer> </body> </html>