vue3中使用vanta.js创建动态网页

通过npm的方式安装three和vanta.js

npm install vanta@0.5.24

npm install three@0.121.0

在vue3中进行引入和使用

<template>

  <div id="login" ref="Area">

  </div>

</template>

<script setup lang="ts">

import { onMounted,onBeforeUnmount,ref } from "vue";

//导入vanta.js和three.js,以及ref等hooks

import * as THREE from 'three';

import BIRDS  from 'vanta/src/vanta.birds';


 

//使用ref引用挂载区域

const Area=ref(null)

//创建一个全局的变量来使用vanta.js

/**

  *因为在vue2中,是使用this.vantaEffect来创建指定的3d动画模板的

  *但是vue3 setup中是没有this,所以要另外创建一个

**/

let vantaEffect=null;

//在两个生命周期钩子内创建vantaEffect

onMounted(()=>{

    vantaEffect=BIRDS ({

        el:Area.value,

        THREE:THREE,

        //如果需要改变样式,要写在这里

        //因为这里vantaEffect是没有setOptions这个方法的

        // color: 0x16212a,

        mouseControls: true,

      touchControls: true,

      gyroControls: true,

      scale: 2.0,

      color1: 14381274,

      color2: 16443110,

    })

})

onBeforeUnmount(()=>{

    if(vantaEffect){

        vantaEffect.destroy()

    }

})

</script>

<style lang="scss" scoped>

#login {

  height: 100vh;

  background-image: url("../assets//03.jpg");

  background-repeat: no-repeat;

  background-size: cover;

  background-position: center center;

  display: flex;

  justify-content: center;

  align-items: center;

  perspective: 800px;

}

</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值