一文详解如何用Three.js和Vue 3实现3D商品展示

 更新时间:2025年07月18日 09:57:40   作者:前端极客探险家  
Three.js是一个基于JavaScript的开源库,用于在网页上创建和显示3D图形,这篇文章主要介绍了如何用Three.js和Vue 3实现3D商品展示的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、前言

在现代电商和产品展示中,3D 可视化技术正变得越来越流行。例如,在购物网站上,用户可以 360° 旋转商品,查看细节,甚至模拟不同的光照和材质效果。这种交互体验可以极大提升用户对商品的感知和购买欲望。

本篇文章将带你使用 Vue 3 + Three.js 构建一个 3D 商品展示组件,并支持 缩放、旋转、光照调整 等功能。

二、Three.js 简介

Three.js 是一个流行的 WebGL 库,提供了丰富的 3D 渲染 API,使前端开发者可以更轻松地在网页中创建 3D 场景。它的核心概念包括:

  • 场景(Scene):3D 物体的容器
  • 相机(Camera):决定观察角度
  • 光源(Lights):控制光照效果
  • 渲染器(Renderer):渲染 3D 画面
  • 模型(Mesh):3D 物体

三、搭建 Vue 3 + Three.js 项目

3.1 创建 Vue 3 项目并安装依赖

# 创建 Vue 3 项目
npm create vite@latest vue-3d-viewer --template vue
cd vue-3d-viewer

# 安装 Three.js
···l three

3.2 创建ThreeDViewer.vue组件

components 目录下创建 ThreeDViewer.vue,并初始化 Three.js 场景。

// ThreeDViewer.vue
<template>
  <div ref="threeContainer" class="three-container"></div>
</template>

<script setup>
import { ref, onMounted } from "vue";
import * as THREE from "three";

const threeContainer = ref(null);

onMounted(() => {
  // 创建场景
  const scene = new THREE.Scene();

  // 创建相机(透视相机)
  const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
  camera.position.set(0, 0, 5); // 设置相机位置

  // 创建渲染器
  const renderer = new THREE.WebGLRenderer();
  renderer.setSize(window.innerWidth, window.innerHeight);
  threeContainer.value.appendChild(renderer.domElement);

  // 创建一个立方体
  const geometry = new THREE.BoxGeometry();
  const material = new THREE.MeshStandardMaterial({ color: 0x0077ff });
  const cube = new THREE.Mesh(geometry, material);
  scene.add(cube);

  // 添加光源
  const light = new THREE.AmbientLight(0xffffff, 1);
  scene.add(light);

  // 渲染循环
  function animate() {
    requestAnimationFrame(animate);
    cube.rotation.x += 0.01;
    cube.rotation.y += 0.01;
    renderer.render(scene, camera);
  }
  animate();
});
</script>

<style>
.three-container {
  width: 100%;
  height: 100vh;
  overflow: hidden;
}
</style>

四、加载 3D 商品模型

4.1 安装GLTFLoader

Three.js 使用 GLTFLoader 加载 .gltf.glb 格式的 3D 模型。

npm install three/examples/jsm

4.2 加载 GLTF 模型

修改 ThreeDViewer.vue,使用 GLTFLoader 加载 3D 商品模型。

import { GLTFLoader } from "three/examples/jsm/loaders/GLTFLoader.js";

// 加载 3D 商品模型
const loader = new GLTFLoader();
loader.load("/models/product.glb", (gltf) => {
  const model = gltf.scene;
  model.scale.set(1, 1, 1); // 调整模型大小
  scene.add(model);
});

五、增加交互功能

5.1 旋转和缩放

使用 OrbitControls 实现 鼠标拖拽旋转和缩放

npm install three-orbitcontrols

5.2 添加OrbitControls

import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";

const controls = new OrbitControls(camera, renderer.domElement);
controls.enableDamping = true; // 使旋转更流畅
controls.dampingFactor = 0.05;
controls.screenSpacePanning = false;
controls.minDistance = 1; // 最小缩放距离
controls.maxDistance = 10; // 最大缩放距离

六、添加灯光和阴影

3D 商品的视觉效果很大程度上依赖于 光照,我们可以添加 环境光 + 聚光灯,增强立体感。

// 添加环境光
const ambientLight = new THREE.AmbientLight(0xffffff, 0.5);
scene.add(ambientLight);

// 添加聚光灯
const spotLight = new THREE.SpotLight(0xffffff, 1);
spotLight.position.set(5, 5, 5);
scene.add(spotLight);
{javascript}

并开启阴影:

{javascript}
renderer.shadowMap.enabled = true;
cube.castShadow = true;
cube.receiveShadow = true;
spotLight.castShadow = true;

七、最终效果

至此,我们的 3D 商品展示组件已经具备:

加载 3D 模型(支持 .glb/.gltf

鼠标旋转缩放OrbitControls

光照和阴影(环境光 + 聚光灯)

动画(自动旋转)

你可以在 App.vue 中引入并使用:

// App.vue
<template>
  <ThreeDViewer />
</template>

<script setup>
import ThreeDViewer from "./components/ThreeDViewer.vue";
</script>

八、总结

本篇文章介绍了如何使用 Vue 3 + Three.js 构建一个 3D 商品展示 组件,包括:

  1. Three.js 基础(场景、相机、渲染器)
  2. 加载 3D 商品模型(GLTFLoader)
  3. 添加交互控制(OrbitControls)
  4. 优化灯光和阴影(增强立体感)

你可以在此基础上进一步扩展:

  • 支持多角度切换(多个摄像机)
  • 支持模型变色、换材质
  • 加入 WebAR 进行增强现实展示

到此这篇关于如何用Three.js和Vue 3实现3D商品展示的文章就介绍到这了,更多相关Three.js和Vue3实现3D商品展示内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue+Electron打包桌面应用(超详细完整教程)

    Vue+Electron打包桌面应用(超详细完整教程)

    这篇文章主要介绍了Vue+Electron打包桌面应用超详细完整教程,在这大家要记住整个项目的json文件不能有注释,及时没报错也不行,否则运行命令时还是有问题,具体细节问题参考下本文详细讲解
    2024-02-02
  • Vue如何指定不编译的文件夹和favicon.ico

    Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue3 Transition组件给页面切换并加上动画效果

    Vue3 Transition组件给页面切换并加上动画效果

    这篇文章主要给大家介绍了关于Vue3 Transition组件给页面切换并加上动画效果的相关资料,vue的过渡动画主要是transition标签的使用,配合css动画实现的,需要的朋友可以参考下
    2023-06-06
  • vue 如何添加全局函数或全局变量以及单页面的title设置总结

    vue 如何添加全局函数或全局变量以及单页面的title设置总结

    本篇文章主要介绍了vue 如何添加全局函数或全局变量以及单页面的title设置总结,非常具有实用价值,需要的朋友可以参考下
    2017-06-06
  • Vue3目录调整方案详解

    Vue3目录调整方案详解

    默认生成的目录结构不满足我们的开发需求,所以这里需要做一些自定义改动,本文给大家分享Vue3目录调整方案,感兴趣的朋友一起看看吧
    2023-11-11
  • Vue实现穿梭框效果

    Vue实现穿梭框效果

    这篇文章主要为大家详细介绍了Vue实现穿梭框效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • vue项目之webpack打包静态资源路径不准确的问题

    vue项目之webpack打包静态资源路径不准确的问题

    这篇文章主要介绍了vue项目之webpack打包静态资源路径不准确的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue数据双向绑定原理及简单实现方法

    Vue数据双向绑定原理及简单实现方法

    vue数据双向绑定是通过数据劫持结合发布者-订阅者模式的方式来实现的.本文重点给大家介绍Vue数据双向绑定原理及简单实现方法,感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-05-05
  • Vue中父子组件的值传递与方法传递

    Vue中父子组件的值传递与方法传递

    这篇文章主要介绍了Vue中父子组件的值传递与方法传递,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Vue3注册全局组件的使用方法

    Vue3注册全局组件的使用方法

    例如组件使用频率非常高,几乎每个页面都在使用便可以封装成全局组件,下面通过本文给大家介绍Vue3注册全局组件的相关知识,感兴趣的朋友一起看看吧
    2024-01-01

最新评论