作者版本 2.4.3
众所周知在插件脚本内是不能require外部脚本的,在下做过各种尝试,发现最终办法一共有两个:
- 在构建后修改index.js内的require顺序,实现(伪 - 插件脚本)
- 在插件脚本内通过同步/异步的require外部脚本,在下最开始尝试了同步方法,结果发现只能在编辑器或者网页预览的时候才能正常使用,于是用了异步的方法,测试在编辑器、网页预览、web-mobile测试通过(原生没测,不过应该也行)
这里给大家说的就是通过异步方式require,方法很简单,如下:
- 首先建立一个传递require的普通脚本
cc.director.emit("require", CC_PREVIEW ? globalThis.__quick_compile_project__.require : (require || globalThis.require || globalThis.__require));
- 然后在插件脚本内接收(注意:外部模块路径必须以
"./assets/tool"的格式传递,开头必须从./assets/开始)
cc.director.on("require", (_require)=> {
cc.log("插件脚本 require", _require("外部模块路径", CC_PREVIEW ? "preview-scripts/__qc_index__.js" : undefined));
});
当然这种方法还是些问题的,比如必须保证同步的装饰器,就不能作为外部依赖模块使用