vue实现随机生成分享海报(内容动态)

简介: vue实现随机生成分享海报(内容动态)


前言


主要是介绍了如何使用vue实现,动态分享内容为海报,且附带二维码,扫描二维码能直接进去文章的页面。但是有个小缺点,就是海报的背景,只有一种;

相信大家在看CSDN这种分享海报的时候,是可以随机切换精美背景的,今天,我们就来看看,随机海报背景如何实现。

最终效果


因为图片中含有二维码,可能后期会显示不出来,大家也可以自己去体验一下,体验步骤:

  1. 进入体验地址
  2. 拉到文章下面,点击【分享按钮】
  3. 每次点击分享按钮,都会出现不一样的海报,点击完之后关掉,继续点击。

实现思路

现在我们来介绍一下实现思路。

  1. 首先我们选10张精美海报图片放在一个地方先存起来,我这边放在了七牛云里面了,大家可以自行放置,放在本地也可以,到时候注意路径不要写错就可以。(命名尽量有规律,我是这样命名的:fx-bg1.png,fx-bg2.png,fx-bg3.png……
  2. 生成海报的时候,我是将选好的图片当做背景图来实现的,所以我们背景图就得写成动态的,不能写死。
  3. 使用随机数的策略,每次点击【分享】按钮的时候,都随机取一个数,然后拼接到图片地址中,置换在背景图的值即可。

实现代码

  1. 将海报的背景图修改成动态的,html代码修改如下:
<!--分享海报的弹出层-->
    <el-dialog
      width="20%"
      height="200px"
      center
      :visible.sync="dialogFengXiang"
    >
      <!-- 海报html元素 -->
      <div id="posterHtml" v-show="isShowBg" :style="fxbg">
        <div class="fx_content ">
          <span style="color: #000000;font-size: 16px">{{ posterTitle }}</span>
          <p style="font-size: 12px;">
            关注微信公众号【雄雄的小课堂】;
            <br />
            博客网址:https://www.穆雄雄.com
          </p>
        </div>
        <!-- 二维码 -->
        <div id="qrcodeImg" ref="qrcodeImg"></div>
      </div>
    </el-dialog>

注意这个地方: :style="fxbg"style前面是个冒号,这样才能是动态的。

  1. data中声明背景图的变量:
//背景图
      fxbg: ""
  1. 写一个生成随机数的方法,动态随机生成图片地址:
//随机生成背景图
    getRandomBg() {
      let path = process.env.VUE_APP_IMG_API;
      let max = 10;
      let random = Math.floor(Math.random() * max) + 1;
      let img_url = path + "fx-bg" + random + ".png";
      this.fxbg = { backgroundImage: "url(" + img_url + ")" };
    },

path是图片地址,我是配置的,这个地方大家也可以直接写死。

  1. 在分享按钮的点击事件中调用即可。
//分享的功能
    fenxiang() {
      //生成随机背景图
      this.getRandomBg();
      //生成海报
      this.createPoster();
      //生成二维码
      this.createQrcode();
      this.dialogFengXiang = true;
    },

然后就可以实现啦,大家想要体验的话,可以前往:这里去体验。

相关文章
|
7天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
8天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
8天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
8天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
7天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
9天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
7天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
9天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
14天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
14天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex

相关实验场景

更多