CocosCreator learning modular script

CocosCreator learning modular script

Cocos Creator modular script

Cocos Creator allows you to split your code into multiple script files and let them call each other. This step is simply called modularization.

Modularity allows you to reference other script files in Cocos Creator:

  • Access parameters exported from other files
  • Call other file export methods
  • Use other file export types
  • Use or inherit other Component

JavaScript in Cocos Creator uses CommonJS standards that are almost the same as Node.js to achieve modularity. In short:

  • Each separate script file constitutes a module
  • Each module is a separate scope
  • Use the synchronous require method to reference other modules
  • Set module.exports to the exported variable

When you declare a component in a script, Creator will export it by default, and other scripts can use this component by directly requiring this module.

// Rotate.js

cc.Class({
   extends: cc.Component,
   // ...
}); SinRotate.js
// SinRotate.js

var Rotate = require("Rotate");

var SinRotate = cc.Class({
    extends: Rotate,
    update: function (dt) {
        this.rotation += this.speed * Math.sin(dt);
    }
});

Modules can not only define components, but you can actually export any JavaScript object. Suppose there is a script config.js :

// config.js - v2

var cfg = {
    moveSpeed: 10,
    version: "0.15",
    showTutorial: true,

    load: function () {
        // ...
    }
};
cfg.load();

module.exports = cfg;

Now if we want to access the cfg object from another script:

// player.js

var config = require("config");
cc.log("speed is", config.moveSpeed);

The default value of module.exports is:
When your module.exports has no definition, Creator will automatically set exports to the Component defined in the script. If the script does not define a Component but defines another type of CCClass, exports will be automatically set to the defined CCClass.

Exporting variables

module.exports is an empty object ( {} ) by default, and you can add new fields directly to it.

// foobar.js:

  module.exports.foo = function () {
      cc.log("foo");
  };
  module.exports.bar = function () {
      cc.log("bar");
  };
//test.js:

  var foobar = require("foobar");
  foobar.foo(); // "foo"
  foobar.bar(); // "bar"

The value of module.exports can be any JavaScript type.

// foobar.js:

  module.exports = {
      FOO: function () {
          this.type = "foo";
      },
      bar: "bar"
  };
//test.js:

  var foobar = require("foobar");
  var foo = new foobar.FOO();
  cc.log(foo.type); // "foo"
  cc.log(foobar.bar); // "bar"

The above is the detailed content of modular script learning in CocosCreator. For more information about modular script of CocosCreator, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Unity3D realizes camera lens movement and limits the angle
  • Detailed explanation of how to use several timers in CocosCreator
  • How to use physics engine joints in CocosCreator
  • How to use JSZip compression in CocosCreator
  • CocosCreator Getting Started Tutorial: Making Your First Game with TS
  • Interpretation of CocosCreator source code: engine startup and main loop
  • CocosCreator general framework design resource management
  • How to make a List in CocosCreator
  • How to use http and WebSocket in CocosCreator
  • Analysis of CocosCreator's new resource management system
  • How to use cc.follow for camera tracking in CocosCreator

<<:  Tutorial on installing lamp-php7.0 in Centos7.4 environment

>>:  Detailed analysis of SQL execution steps

Recommend

How to extend Vue Router links in Vue 3

Preface The <router-link> tag is a great to...

A solution to the abnormal exit of Tomcat caused by semaphore

I'm playing with big data recently. A friend ...

Centos7 installation and configuration of Mysql5.7

Step 1: Get the MySQL YUM source Go to the MySQL ...

How to query json in the database in mysql5.6 and below

When saving data in MySQL, sometimes some messy a...

MySQL 8.0.18 deployment and installation tutorial under Windows 7

1. Preliminary preparation (windows7+mysql-8.0.18...

Best Practices for Deploying ELK7.3.0 Log Collection Service with Docker

Write at the beginning This article only covers E...

js code that associates the button with the enter key

Copy code The code is as follows: <html> &l...

Usage instructions for the docker create command

The docker create command can create a container ...

jQuery plugin to achieve image comparison

This article example shares the specific code of ...

How to load third-party component libraries on demand in Vue3

Preface Take Element Plus as an example to config...

Detailed explanation of padding and abbreviations within the CSS box model

As shown above, padding values ​​are composite at...

Detailed explanation of WeChat Mini Program official face verification

The mini program collected user personal informat...

Detailed explanation of Docker daemon security configuration items

Table of contents 1. Test environment 1.1 Install...

MySQL DML statement summary

DML operations refer to operations on table recor...

960 Grid System Basic Principles and Usage

Of course, there are many people who hold the oppo...