首页 > 基础资料 博客日记
AI+Web3D:我让AI写了一年Three.js,结果它连一个内网白屏都修不了
2026-04-26 19:00:03基础资料围观2次
很久没写了,
我必须先说一句:AI写3D代码,确实强。
强到让人心慌。
以前我要翻三天文档、试七八种方案才能搭出来的模型交互管线,它十几秒全吐出来。GLTF加载、PBR材质、后处理特效,甚至我还没来得及想到的细节优化,它都能自动补全。
比如这段,我让AI写一个简单得模型加载代码,说实话,我自己手写也就这个水平:
// AI生成的Three.js模型加载——标准环境完美运行
import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js';
const loader = new GLTFLoader();
loader.load(
'/assets/model.glb',
(gltf) => {
scene.add(gltf.scene);
console.log('模型加载成功');
},
(progress) => {
console.log(`加载进度: ${(progress.loaded / progress.total * 100).toFixed(2)}%`);
},
(error) => {
console.error('模型加载失败:', error);
}
);
看起来没毛病对吧?加载进度回调、错误处理,该有的都有。
那一刻,说实话,我后背是凉的。六年的经验,在它面前好像瞬间贬值了。
但我这个人有个毛病:慌完,就会开始找它的破绽。

于是过去半年,我干了一件事:专门把AI写的Three.js代码,往"地狱环境"里扔。
什么是地狱环境?不是你那台MacBook,也不是Chrome最新版。是客户现场的工控机——Win7嵌入式、Chromium 49内核、核显、断网、安全软件还在后台悄悄删着东西。
AI的代码,在这里,死得很惨。
第一个翻车现场:内网离线环境,贴图全白
AI生成的加载器用的路径是 /assets/model.glb,里面内嵌的纹理引用了一堆相对路径。本地没问题,一丢到客户那台断网、没有外网DNS的内网服务器上——
全白。
控制台不报错,GLTFLoader 静默失败,连error回调都没触发。AI根本不知道,有些内网环境里,浏览器连 blob: 协议都会被安全策略拦截。
我最后改成了这样:
// 修复方案:内网离线环境适配
import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js';
const loader = new GLTFLoader();
// 关键:设置跨域策略,接管纹理加载
loader.setCrossOrigin('anonymous');
// 关键:禁用外部资源请求,强制所有纹理base64内嵌
loader.setResourcePath('');
// 预检测:当前环境是否支持blob协议
const isBlobSupported = (() => {
try {
const testBlob = new Blob(['test'], { type: 'text/plain' });
URL.createObjectURL(testBlob);
return true;
} catch (e) {
return false;
}
})();
if (!isBlobSupported) {
console.warn('当前环境不支持Blob协议,纹理将降级为纯色材质');
// 后续走降级渲染分支
}
AI不会写这段。它没见过一个连 Blob 都跑不了的环境。
第二个翻车现场:
老浏览器,跑着跑着GPU上下文直接丢了
AI写的渲染循环干净利落:
// AI生成的标准渲染循环
function animate() {
requestAnimationFrame(animate);
renderer.render(scene, camera);
stats.update();
}
animate();
放在Chrome最新版,稳如老狗。
放到那台国产化双核浏览器的极速模式下,跑不到五秒,整个canvas黑掉。控制台抛出一个AI从来没处理过的东西:
WebGL: CONTEXT_LOST_WEBGL
然后页面卡死,什么动静都没了。用户刷新也没用,因为浏览器已经把GPU进程挂起了。
AI的代码里,没有对这一行的任何防御。
我加的修复:
// 修复方案:老浏览器GPU上下文丢失防御
function animate() {
requestAnimationFrame(animate);
try {
renderer.render(scene, camera);
} catch (e) {
// 捕获渲染异常,避免整个循环崩溃
console.warn('渲染帧失败,跳过当前帧:', e.message);
return;
}
}
// 核心:接管上下文丢失事件
renderer.domElement.addEventListener('webglcontextlost', (event) => {
// 阻止默认行为,争取恢复时间
event.preventDefault();
console.warn('WebGL上下文丢失,2秒后尝试恢复...');
// 暂停渲染,释放部分GPU内存
cancelAnimationFrame(animationId);
// 尝试上下文恢复
setTimeout(() => {
renderer.domElement.addEventListener('webglcontextrestored', () => {
console.log('上下文已恢复,重新启动渲染');
animate();
}, { once: true });
}, 2000);
}, false);
// 额外保险:检测浏览器是否为国产双核
const isOldBrowser = /360|LieBao|MetaSr/.test(navigator.userAgent);
if (isOldBrowser) {
// 降低像素比,减少GPU内存压力
renderer.setPixelRatio(Math.min(window.devicePixelRatio, 1));
// 关闭阴影、后处理等耗GPU特性
renderer.shadowMap.enabled = false;
}
这段代码放进去之后,那台老机器跑了一个下午,没再崩过。
我盯着那些崩溃的日志,突然笑了。
不是嘲笑AI,是松了一口气。
原来,它强是真的,但它"没见过真实世界"也是真的。它的训练数据里,全是理想环境。标准浏览器、最新API、完善网络、最新驱动——这些在真实工业现场,是幻觉。
它不是神,它只是一个在完美环境里长大的学霸,从来没踩过泥坑。
而中国有多少这样的泥坑?国产化双核浏览器、内网安全策略拦截、老旧的硬件必须继续跑、杀毒软件把WebGL当病毒……这些,AI一行代码都解决不了。
不是说它以后解决不了,而是现在,它真的干不了。
想通这一点之后,我的焦虑就过去了。
不是因为我比AI聪明,而是因为我想明白了接下来我要干什么:
AI负责在完美的环境里,生成漂亮的Demo。
我负责在真实的地狱里,让它跑起来。
它给我降本增效,我给它擦屁股。
它当大脑,我当那个知道怎么在泥巴里走路的人。
技术壁垒,的确被冲垮了一道。
但新的壁垒,就在AI写的那堆代码"跑死在客户现场"的瞬间,重新立了起来。

所以现在,我拥抱AI,每天都在用。
但也每天都在它的输出里,找到了自己非存在不可的理由。
这件事,焦虑过,现在清醒了。
如果你也觉得技术被替代了,别盯着它擅长的看。
去把它写的代码,扔到你最烂的一台设备上,跑一下。
答案就在那个报错里。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:

