很久没写了,
我必须先说一句: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,每天都在用。
但也每天都在它的输出里,找到了自己非存在不可的理由。
这件事,焦虑过,现在清醒了。
如果你也觉得技术被替代了,别盯着它擅长的看。
去把它写的代码,扔到你最烂的一台设备上,跑一下。
答案就在那个报错里。