Custom Project Build Template
Cocos Creator supports custom build templates for each project. Add a build-templates/[platform]
folder to the project path, and divide the sub-folder according to the platform name. Then all the files in this folder will be automatically copied to the build generated project according to the corresponding folder structure after the build. Currently, all platforms except the native platform support this function, the specific platform name can be referred to as the following custom build template supported platform list.
Folder Structure:
project-folder
|--assets
|--build
|--build-templates
|--web-mobile
// The file to be added, such as index.html
|--index.html
If the current platform is Web-Mobile
, then build-templates/web-mobile/index.html
will be copied to build/web-mobile/index.html
.
In addition, the file types currently supported by the build template include ejs type and json type. These two types will not copied directly but rather parsed. Please refer to the Special Custom Build Template Platform support list below for details on the support for these two template types by platform.
ejs
type
Since the content of the package is not guaranteed to be exactly the same in every version, when the build template within the editor is updated, the developer also needs to update the build template within their project. For example, if the MD5 Cache option is checked at build time, taking index.html
on the web platform as an example, the css
file referenced in it will have an MD5 Hash suffix, which may not match the one in the original template and may not work.
To optimize this problem, a new way is added to use the template. Click on Project -> Create Preview Template in the main menu, and an ejs
template file will be generated for the corresponding platform.
Developers only need to customize the generated build template in the .ejs
, the build will automatically synchronize the updates of the editor build template to the custom build template, and the frequently changed content will be synchronized to the sub-template (.ejs
) referenced by the template, so that the custom build template can be updated manually without frequent updates.
Taking the creation of a Web Mobile build template as an example, the generated build template directory structure is as follows:
Note: the copy template occurs after the rendered template. For example, if both
index.ejs
andindex.html
exist in this directory, the final packaged package will be theindex.html
file instead of theindex.ejs
rendered file.
json
Type
Many mini games have their own configuration JSON
files, like game.json
to WeChat Mini Games. Files in the build templates folder will just copy in default, but this configuration JSON will be merged instead of overwrite. Of course, it doesn’t mean that all JSON
file will be merged, you can check it in the tables below.
Special Custom Build Template supported Platform list
Most files placed in the build-templates/[platform]
directory will be copied directly to the corresponding directory. In addition, many platforms support some template files with special name formats. The supported file with special name formats for build templates by the platform are as follows:
Platform | Actual Name | Supported File Type |
---|---|---|
Huawei AGC | huawei-agc | not supported yet |
Alipay Mini Game | alipay-mini-game | game.json |
Taobao Mini Game | taobao-mini-game | game.json 、mini.project.json |
Douyin Mini Game | bytedance-mini-game | game.ejs 、game.json 、project.config.json |
OPPO Mini Game | oppo-mini-game | manifest.json |
Huawei Quick Game | huawei-quick-game | not supported yet |
Cocos Play | cocos-play | game.config.json |
vivo Mini Game | vivo-mini-game | project.config.json |
Xiaomi Quick Game | xiaomi-quick-game | manifest.json |
Baidu Mini Game | baidu-mini-game | game.json , project.swan.json |
WeChat Mini Game | wechatgame | game.ejs , game.json , project.config.json |
Web Desktop | web-desktop | index.ejs |
Web Mobile | web-mobile | index.ejs |
Native | native | not supported yet |