vue3 setup语法糖使用vanta.js的使用方法

该代码示例展示了如何在Vue3组件中集成Vanta.js库,通过引入Three.js和Vanta特效,实现在挂载的<div>区域上创建动态3D云彩效果。onMounted和onBeforeUnmount钩子分别用于初始化和销毁动画,同时允许自定义颜色样式。
摘要由CSDN通过智能技术生成
<!--这里创建一个vantajs的挂载区域-->
<template>
    <div class="vanta_area" ref="Area"></div>
</template>
<script setup>
//导入vanta.js和three.js,以及ref等hooks
import * as THREE from 'three'
import CLOUDS from 'vanta/src/vanta.waves'
import {onMounted,onBeforeUnmount,ref} from 'vue'

//使用ref引用挂载区域
const Area=ref(null)
//创建一个全局的变量来使用vanta.js
/**
  *因为在vue2中,是使用this.vantaEffect来创建指定的3d动画模板的
  *但是vue3 setup中是没有this,所以要另外创建一个
**/
let vantaEffect=null;
//在两个生命周期钩子内创建vantaEffect
onMounted(()=>{
    vantaEffect=CLOUDS({
        el:Area.value,
        THREE:THREE,
        //如果需要改变样式,要写在这里
        //因为这里vantaEffect是没有setOptions这个方法的
        color: 0x16212a,
    })
})

onBeforeUnmount(()=>{
    if(vantaEffect){
        vantaEffect.destroy()
    }
})
</script>
<style lang="less" scoped>
.vanta_area {
  width:100vw;
  height:100vh;
}
</style>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

A_ugust__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值