Skip to content

运行环境

Cocos Creator 3.0 引擎的 API 都存在模块 cc 中,使用标准的 ES6 模块导入语法将其导入:

ts
import {
  Component, // 导入类 Component
  _decorator, // 导入命名空间 _decorator
  Vec3, // 导入类 Vec3
} from "cc";
import * as modules from "cc"; // 将整个 Cocos Creator 模块导入为命名空间 Cocos Creator

@_decorator.ccclass("MyComponent")
export class MyComponent extends Component {
  public v = new Vec3();
}

保留标识符 cc

注意,由于历史原因,cc 是 Cocos Creator 3.0 保留使用的标识符,其行为 相当于 在任何模块顶部定义了名为 cc 的对象。 因此,开发者不应该将 cc 用作任何 全局对象 的名称:

ts
/* const cc = {}; // 每个 Cocos Creator 脚本都等价于在此处含有隐式定义 */

import * as modules from "cc"; // 错误:命名空间导入名称 cc 由 Cocos Creator 保留使用

const cc = {
  x: 0,
};
console.log(cc.x); // 错误:全局对象名称 cc 由 Cocos Creator 保留使用

function f() {
  const cc = {
    x: 0,
  };
  console.log(cc.x); // 正确:cc 可以用作局部对象的名称

  const o = {
    cc: 0,
  };
  console.log(o.cc); // 正确:cc 可以用作属性名
}

console.log(cc, typeof cc); // 错误:行为是未定义的