当前位置: 首页 > article >正文

Vue 3 中集成 Three.js 场景的完整实践指南

本文详解如何在 vue 3javascript 版本项目中正确集成 three.js 基础场景涵盖 dom 挂载、生命周期协调、渲染循环管理及常见陷阱规避。 本文详解如何在 vue 3javascript 版本项目中正确集成 three.js 基础场景涵盖 dom 挂载、生命周期协调、渲染循环管理及常见陷阱规避。在 Vue 3 的响应式架构下直接嵌入 Three.js 渲染逻辑需特别注意 DOM 元素可用性、渲染器生命周期与 Vue 组件生命周期的协同。原生 Three.js 示例依赖 document.body.appendChild()但在 Vue 单文件组件SFC中必须通过 ref 获取真实 DOM 节点并在 onMounted 钩子中安全挂载渲染器——这是避免 Cannot read property appendChild of null 等错误的关键。以下是一个可直接运行的 App.vue 完整实现使用 JavaScript非 TypeScriptscript setupimport { ref, onMounted, onUnmounted } from vue;import * as THREE from three;// 创建 DOM 引用容器const target ref();// 初始化 Three.js 核心对象const scene new THREE.Scene();const camera new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000);const renderer new THREE.WebGLRenderer({ antialias: true });renderer.setSize(500, 500); // 推荐显式设置尺寸避免默认拉伸renderer.setPixelRatio(window.devicePixelRatio); // 提升高 DPI 屏幕显示质量// 创建绿色立方体const geometry new THREE.BoxGeometry(1, 1, 1);const material new THREE.MeshBasicMaterial({ color: 0x00ff00 });const cube new THREE.Mesh(geometry, material);scene.add(cube);camera.position.z 5;// 动画循环函数闭包内维持引用避免重复创建let animationId null;function animate() { animationId requestAnimationFrame(animate); cube.rotation.x 0.01; cube.rotation.y 0.01; renderer.render(scene, camera);}// 组件挂载后挂载渲染器 DOM 并启动动画onMounted(() { if (target.value) { target.value.appendChild(renderer.domElement); animate(); }});// 【重要】组件卸载前清理资源防止内存泄漏onUnmounted(() { if (animationId) { cancelAnimationFrame(animationId); } if (renderer.domElement renderer.domElement.parentNode) { renderer.domElement.parentNode.removeChild(renderer.domElement); } renderer.dispose(); // 释放 WebGL 资源});/scripttemplate div reftarget classthree-container/div/templatestyle scoped.three-container { width: 500px; height: 500px; margin: 2rem auto; border: 1px solid #eee;}/style? 关键要点说明 ref onMounted 是黄金组合确保 renderer.domElement 只在真实 DOM 节点就绪后才插入 显式 setSize() 优于 renderer.setSize(window.innerWidth, ...)避免因响应式容器尺寸变化导致渲染异常推荐结合 CSS 控制容器宽高Three.js 渲染器按需适配 务必调用 renderer.dispose() 和 cancelAnimationFrameVue 组件可能被复用或销毁未清理的动画帧和 WebGL 上下文将引发内存泄漏 添加 antialias: true 和 setPixelRatio显著提升视觉质量尤其在 Retina 屏幕上 避免在 setup() 顶层执行渲染逻辑Three.js 对象如 scene, camera可定义在顶层但 DOM 操作与动画启动必须延迟至 onMounted。? 进阶提示如需响应窗口缩放可监听 window.resize 事件并更新 camera.aspect 与 renderer.setSize()但需注意防抖以避免高频重绘。 Zeemo AI 一款专业的视频字幕制作和视频处理工具

相关文章:

Vue 3 中集成 Three.js 场景的完整实践指南

本文详解如何在 vue 3(javascript 版本)项目中正确集成 three.js 基础场景,涵盖 dom 挂载、生命周期协调、渲染循环管理及常见陷阱规避。 本文详解如何在 vue 3(javascript 版本)项目中正确集成 three.js 基础场景…...

AI写春联实测:春联生成模型-中文-base生成效果惊艳案例

AI写春联实测:春联生成模型-中文-base生成效果惊艳案例 1. 引言:当AI遇见传统文化 春节贴春联是中国延续千年的传统习俗,一副好春联既要对仗工整,又要寓意吉祥,创作起来颇有难度。如今,AI技术让这一传统艺…...

别再调参了!SITS2026已淘汰微调依赖——揭秘Zero-Shot Contextual Inference引擎如何实现跨项目零样本泛化(附VS Code插件预览版申请通道)

第一章:SITS2026深度解读:代码补全技术演进 2026奇点智能技术大会(https://ml-summit.org) SITS2026(Software Intelligence & Tooling Summit 2026)首次系统性地将代码补全技术划分为“感知—推理—协同”三阶段范式&#…...

Security:Elastic Security 实战:从零构建威胁检测与响应闭环

1. Elastic Security 初探:企业安全防护新思路 第一次接触Elastic Security时,我被它"SIEM端点防护"的二合一设计惊艳到了。传统企业安全方案往往需要采购多个独立系统,而Elastic Security直接把日志分析、威胁检测、终端防护这些功…...

2026 初学者吉他选购清单|500-3000 元全覆盖,十年从业者良心整理!

作为在乐器行业深耕十年、同时长期接触吉他教学与选购的从业者,我见过太多初学者因为选错琴而放弃。不少人抱着热情入手,却因为弦距过高、手感生硬、音准偏差,把练琴变成煎熬,最终让乐器闲置。 新手选琴常见的误区主要有三类&…...

告别‘一发一收’:用Wireshark抓包实战解析802.11n的Block ACK机制如何提升Wi-Fi速度

告别“一发一收”:用Wireshark抓包实战解析802.11n的Block ACK机制如何提升Wi-Fi速度 在拥挤的咖啡厅里,你的视频会议突然卡成PPT;游戏团战时,角色莫名漂移——这些糟心体验背后,往往藏着Wi-Fi协议层的效率瓶颈。传统8…...

Hermes Agent怎么部署?2026年阿里云计算巢/无影/轻量服务器部署图文教程及常见问题汇总

Hermes Agent是由Nous Research开发的开源自主AI智能体,遵循MIT开源协议,核心价值在于持久化记忆与完整的自我学习闭环。它并非简单的代码辅助工具或套壳聊天机器人,而是能自主创建技能、在使用中优化技能、跨会话召回记忆的"数字员工&q…...

3分钟快速安装Figma中文界面插件:设计师必备的免费汉化工具

3分钟快速安装Figma中文界面插件:设计师必备的免费汉化工具 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 你是否因为Figma的英文界面而感到困扰?专业术语看不懂…...

SAP物料主数据增强进阶:除了MARA,如何搞定MARC工厂级数据与F4搜索帮助增强?

SAP物料主数据增强进阶:MARC工厂级数据与F4搜索帮助实战解析 物料主数据增强是SAP实施过程中最常见的开发需求之一。当基础字段增强已经不能满足业务需求时,开发者往往需要面对两个更具挑战性的场景:工厂级数据(MARC表&#xff09…...

别再一上来就关SELinux了!搞懂Permissive、Enforcing、Disabled三种模式,让你的Linux服务器更安全

别再一上来就关SELinux了!搞懂Permissive、Enforcing、Disabled三种模式,让你的Linux服务器更安全 第一次在服务器上部署Web应用时,我遇到了一个诡异的权限问题:Nginx明明以root身份运行,却无法读取我新上传的静态文件…...

智能代码生成≠自动复用:3个被99%开发者忽略的上下文耦合陷阱,今天必须修复

第一章:智能代码生成代码复用策略 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成正从辅助补全工具演进为系统级复用引擎,其核心价值在于将重复性高、模式明确的代码逻辑沉淀为可检索、可组合、可验证的知识单元。开发者不再仅依赖复制粘贴…...

【实战指南】从根源到修复:全面剖析Unity中的NullReferenceException

1. 什么是NullReferenceException? 如果你用过Unity开发游戏,肯定见过这个让人头疼的错误提示:"NullReferenceException: Object reference not set to an instance of an object"。简单来说,就是你在代码里引用了一个空…...

紧急预警:未建立AI生成代码可信度评估机制的敏捷团队,正面临Sprint Review阶段平均2.8次重大逻辑回滚(附ISO/IEC 23894合规自检表)

第一章:智能代码生成在敏捷开发中的应用 2026奇点智能技术大会(https://ml-summit.org) 智能代码生成正深度融入敏捷开发的迭代闭环,成为提升需求响应速度与交付质量的关键杠杆。它不再仅作为辅助补全工具,而是嵌入用户故事拆解、测试驱动开…...

STM32CubeMX实战:基于单级PID与编码器反馈的直流减速电机闭环调速

1. 从零搭建电机闭环调速系统 搞过机器人项目的朋友都知道,电机调速是个绕不开的坎。去年我做智能小车时,就遇到过电机转速不稳的问题——上坡时慢得像蜗牛,下坡时又疯跑。后来用STM32CubeMX配合PID算法实现了闭环控制,效果立竿见…...

STM32CubeIDE汉化包安装与卸载全攻略:如何管理你的多语言开发环境

STM32CubeIDE多语言环境管理实战:从汉化安装到团队协作规范 如果你曾在深夜盯着满屏英文的STM32CubeIDE界面,试图回忆某个晦涩菜单项的位置,那么多语言支持可能正是你需要的救星。但汉化包的安装远不止是点击几下按钮那么简单——版本兼容性、…...

ZYNQ:从分立到融合,揭秘异构计算新范式

1. 从分立到融合:ZYNQ如何解决传统方案的痛点 十年前我第一次接触嵌入式系统设计时,最常见的架构就是ARM处理器外挂FPGA的方案。当时做医疗影像处理项目,主控用的TI的ARM芯片,通过EMIF总线连接Xilinx Spartan-6 FPGA做图像预处理。…...

【头部金融科技团队内部文档泄露】:如何用Diff-aware Prompt Engineering实现零感知风格归一化?

第一章:【头部金融科技团队内部文档泄露】:如何用Diff-aware Prompt Engineering实现零感知风格归一化? 2026奇点智能技术大会(https://ml-summit.org) 当某头部金融科技团队的多份内部风控策略文档在灰产渠道批量泄露后,其核心…...

职业瓶颈突破:测试工程师转型管理

从技术深潜到管理航向在软件质量保障领域深耕多年后,许多优秀的测试工程师都会面临一个共同的职业十字路口:是继续沿着技术专家的路径纵向钻研,还是转向管理岗位,开启更广阔的职业视野?对于不少从业者而言,…...

WPF企业级界面架构决策:Fluent.Ribbon如何解决复杂业务界面的可维护性挑战

WPF企业级界面架构决策:Fluent.Ribbon如何解决复杂业务界面的可维护性挑战 【免费下载链接】Fluent.Ribbon WPF Ribbon control like in Office 项目地址: https://gitcode.com/gh_mirrors/fl/Fluent.Ribbon 在当今企业级应用开发中,用户界面的复…...

【限时解禁】Gartner未公开评估报告节选:Top 8低代码平台AI就绪度排名,第3名意外反超OutSystems(含API粒度级生成延迟实测数据)

第一章:智能代码生成与低代码平台融合的范式演进 2026奇点智能技术大会(https://ml-summit.org) 传统软件开发正经历一场静默而深刻的范式迁移:从“手写全栈逻辑”走向“意图驱动的协同构建”。智能代码生成模型(如基于LLM的Copilot类工具&a…...

告别手动配IP:在FreeRTOS+STM32F4上为LwIP添加NetBIOS主机名功能全记录

基于FreeRTOS与LwIP的嵌入式设备网络标识优化实践 办公室里同时调试五台STM32设备时,每次都要通过串口日志查看动态分配的IP地址,这种低效的调试方式让我决定彻底改变现状。本文将分享如何通过NetBIOS协议实现设备主机名访问,让ping my_devic…...

实测Qwen2.5-7B:用Ollama快速搭建,体验多语言AI对话的魅力

实测Qwen2.5-7B:用Ollama快速搭建,体验多语言AI对话的魅力 1. 引言:为什么选择Qwen2.5-7B 在当今AI大模型百花齐放的时代,阿里开源的Qwen2.5系列凭借其出色的多语言能力和本地化部署优势脱颖而出。作为该系列中的7B参数版本&…...

千问3.5-2B图文理解实操手册:清晰图/模糊图/反光图/低对比度图四类适配策略

千问3.5-2B图文理解实操手册:清晰图/模糊图/反光图/低对比度图四类适配策略 1. 模型能力概述 千问3.5-2B是Qwen系列中的小型视觉语言模型,专为图片理解与文本生成任务设计。这个开箱即用的解决方案已经完成本地部署,无需额外安装依赖&#…...

OpenCDA实战:从零构建协同驾驶仿真场景与算法集成指南

1. OpenCDA框架初探:为什么选择这个协同驾驶开发神器? 第一次接触OpenCDA时,我正被CARLA和SUMO的联合调试折磨得焦头烂额。直到发现这个"开箱即用"的框架,才明白什么叫"站在巨人肩膀上开发"。简单来说&#x…...

告别裸机点灯:用LVGL在STM32F4 Discovery板上做个炫酷的仪表盘(源码已开源)

从零打造STM32F4炫酷仪表盘:LVGL实战全解析 第一次在STM32F407 Discovery开发板的4.3寸LCD屏上看到LVGL渲染的转速表指针平滑转动时,那种成就感至今难忘。作为一款专为嵌入式设计的轻量级图形库,LVGL让我们能在资源有限的MCU上实现接近智能手…...

从凸包到对话:深入解析Pointer Network如何革新序列生成任务

1. 从几何问题到序列生成:Pointer Network的诞生背景 我第一次接触Pointer Network是在解决一个看似简单的几何问题时——计算给定点集的凸包。传统算法虽然能完美解决,但当我尝试用神经网络实现时,立刻遇到了seq2seq模型的致命缺陷&#xff…...

Understanding strict=False in PyTorch: When Size Mismatch Still Matters

1. 为什么strictFalse还会报错?理解PyTorch的加载逻辑 第一次遇到strictFalse却报size mismatch错误时,我也是一头雾水。明明官方文档说这个参数可以忽略不匹配的键值对,为什么还会因为形状问题卡住?这就像你去超市买东西&#xf…...

微软这个开源语音 AI 火了:GitHub 星标逼近 4 万,为什么大家都在讨论它?

聊天机器人这边还没卷明白,微软又把语音 AI 推上了热榜。这次火起来的项目,叫 VibeVoice。 它不是一个单点模型,而是一整套开源语音 AI 方案。GitHub 仓库当前星标已经逼近 4 万,确实是最近开源圈里最受关注的项目之一。更重要的是…...

Python Android开发终极指南:从Python代码到Android APK的一站式解决方案

Python Android开发终极指南:从Python代码到Android APK的一站式解决方案 【免费下载链接】python-for-android Turn your Python application into an Android APK 项目地址: https://gitcode.com/gh_mirrors/py/python-for-android 对于Python开发者来说&a…...

【技术解析】潜在扩散模型(LDM)中的图像压缩:从VAE到VQ-GAN的演进之路

1. 为什么图像压缩是LDM的第一步? 当你第一次接触潜在扩散模型(LDM)时,可能会好奇:为什么要在扩散过程前先压缩图像?这就像搬家时先把家具拆成零件再运输——原始像素空间就像笨重的实木家具,而…...