Laya 1.x 使用TS开发时,经常会碰到代码文件太多,加载index.html时时间太长的问题。Laya编辑器貌似没有自带JS代码合并的功能。基于Laya去实现JS合并需要修改编辑器源码,合并JS并且要修改导出index.html,实现起来比较麻烦,所以考虑合并发布前的TS代码,这样可以正常使用Laya的发布流程,缺点就是修改代码时,需要先恢复源码,修改完再合并,稍微繁琐一点。尽量在稳定后,发布时合并一次即可。

环境配置

  • 工具:gulp、glup-concat、del、gulp-rename
  • 配置步骤:
    1. 进入项目根目录,打开命令行。
    2. 执行npm init初始化npm,根据需要填入对应信息,默认一直点回车即可。
    3. 执行npm install gulp --save-dev 安装gulp
    4. 执行npm install gulp-concat --save-dev 安装gulp-concat插件 用于合并TS代码。
    5. 执行npm install del --save-dev 安装del插件 用来删除文件
    6. 执行npm install gulp-rename --save-dev 安装gulp-rename插件,用于文件改名,如果用不到也可以不安装。
  • 在根目下创建gulpfile.js,用于写工具相关配置。

工具实现:

工作流程:备份src下代码->合并src下代码到src/output下->删除src下源代码->清理bin/js文件->复制导出用index->在编辑器中编译导出。

  • 备份代码实现:

    //备份源代码
    gulp.task('backup', function() {
    return gulp.src(['src/**/*'])
    .pipe(gulp.dest('../backup'));
    });

    将src/的所有文件,复制到../backup文件夹中。

    注意:备份地址不要放在根目录下,否则Laya会去读取这个文件,容易产生多次定义的bug。

    可以在命令行中执行gulp backup 测试脚本执行。之后步骤均可使用这种方式测试单个命令。

  • 合并代码实现:

    合并代码时需要控制文件的合并顺序,防止子类在父类之前定义的问题,这样编译TS时会报错。

    最理想情况是解析导出的index.html按照顺序依次合并,但实现起来比较复杂。这里手动控制父类的文件先合并,其他文件在合并。

    大部分情况下,只有几个文件或者文件夹需要提前处理,工作量并不是很大。只要保证父类在前就可以。

    合并的粒度可以自己控制,可以合成一个文件,也可以按src下文件夹合并,或者更细的粒度。

    //合并frame文件夹
    gulp.task('frame', function() {
    return gulp.src([
    'src/frame/A/**/*.ts', //先合并A文件夹下所有文件
    'src/frame/B/B.ts', //合并B下的B.ts
    'src/frame/C/*Base*.ts', //合并C下所有含有Base的问题
    'src/frame/**/*.ts', //合并frame下的其他所有文件
    ])
    .pipe(concat('frame.ts'))
    .pipe(gulp.dest('src/output'));
    });

    注:如果不是在根目录下执行脚本,如'../src/xxxxx',合并时特殊文件会被多合一次,还没有找到原因。

  • 删除源代码:

    //删除合并前代码
    gulp.task('delsource', function(){
    return del([
    'src/**',
    '!src/output',
    '!src/output/*',
    '!src/ui',
    '!src/ui/*',
    '!src', ], {force:true});
    });

    保留src下的output文件夹和ui文件夹。

    要保留文件夹下的文件,需要先保留文件夹。

  • 删除bin/js

    //删除bin下面js
    gulp.task('cleanBinJs', function(){
    return del([
    'bin/js/**',
    ], {force:true});
    });

    清理之前的js文件

  • 复制发布用index.html

    发布的index和开发的index可能不一样,尤其是在标签中定义文件时。这里是将发布用的index替换到bin下面。

    //拷贝开发index
    gulp.task('copyIndex', function()
    {
    return gulp.src('index/release.html') //找到文件
    .pipe(rename('index.html')) //将文件改名
    .pipe(gulp.dest('./bin/')); //拷贝到bin下面
    })
  • 设置一键脚本

    //打包代码
    gulp.task('merage', gulp.parallel('A', 'B', 'C')); gulp.task('release', gulp.series('backup','merage', 'delsource', 'cleanBinJs', 'copyIndex'));

    ABD为要合并的文件夹。

    只需要在命令行中执行gulp release 就会一键执行上面所有操作。最后再编辑器中发布即可。

Laya 1.x 按文件夹TS代码合并的更多相关文章

  1. 【原】Mac下统计任意文件夹中代码行数的工具——cloc

    这里介绍一个Mac系统统计代码行数的工具cloc. 1.首先,安装homebrew,已安装的请跳过. 打开终端工具Terminal,输入下列命令.过程中会让你按RETURN键以及输入mac桌面密码,按 ...

  2. java压缩指定目录下的所有文件和文件夹的代码

    将代码过程较好的代码段备份一下,下边资料是关于java压缩指定目录下的所有文件和文件夹的代码,希望对码农有帮助. String sourceDir="E:\test";int pa ...

  3. 【原】Mac下统计任意文件夹中代码行数的工

    [链接][原]Mac下统计任意文件夹中代码行数的工http://www.cnblogs.com/wengzilin/p/4580646.html

  4. summernote图片上传功能保存到服务器指定文件夹+php代码+java方法

    1.summernote富文本编辑器 summernote是一款基于bootstrap的富文本编辑器,是一款十分好用的文本编辑器,还附带有图片和文件上传功能. 那么在我们网站中想吧这个图片上传到服务器 ...

  5. OC获取文件(夹)的代码行数

    /* 考察NSString NSArray NSFileManager */ #import <Foundation/Foundation.h> /* 计算单个文件的代码行数 path:文 ...

  6. linux grep find查找文件夹、代码中的某行/字符串

    本文转载于:https://blog.csdn.net/Mr_Cat123/article/details/80541658 在Linux中,由于文件很多,代码很长,可能我们只知道其中的一两个字符串, ...

  7. Java_文件夹分割与合并

    一.思路: 1.文件切割: 使用类RandomAccessFile ,其中方法seek可以自定义读取位置,读一段,通过字节输出流(我使用BufferedOutputStream)写一段 2.文件合并 ...

  8. canvas生成图片并保存到本地文件夹主要代码

    js var url = canvas.toDataURL();//把canvas中的图片变成data:image C# string filepath = ""; string ...

  9. 目前为止最简洁的C#文件夹Copy代码,不接受反驳

    private static void CopyEntireDir(string sourcePath, string destPath) { foreach (string dirPath in D ...

随机推荐

  1. PHP设计模式系列 - 工厂模式

    工厂模式 提供获取某个对象实例的一个接口,同时使调用代码避免确定实例化基类的步骤. 工厂模式 实际上就是建立一个统一的类实例化的函数接口.统一调用,统一控制. 工厂模式是php项目开发中,最常用的设计 ...

  2. MEMCACHE与REDIS

    千万数据量的高并发,容灾. Redis 基于单线程, 持久性 多数据类型 内存中只存KEY Redis支持数据的备份,即master-slave模式的数据备份. Redis与Memcached的区别 ...

  3. 【转载】Java 集合框架

    http://wangkuiwu.github.io/2012/02/03/collection-03-arraylist/ 网上比较全的Java集合框架教程. 注:transient是Java语言的 ...

  4. 数据库学习之中的一个: 在 Oracle sql developer上执行SQL必知必会脚本

    1 首先在開始菜单中打开sql developer: 2. 创建数据库连接 点击左上角的加号 在弹出的对话框中填写username和password 測试假设成功则点击连接,记得角色要写SYSDBA ...

  5. Paxos算法简单陈述

    上文二段式和三段式提交协议是相对比较容易理解的.1990年Leslie Lamport 提出的Paxos算法是一种基于消息传递且具有高度容错特性的一致性算法.但是Paxos算法比较复杂,对于不能沉心学 ...

  6. js等比压缩上传

    一.js文件,这个是封装过的,借用了网络上的代码然后修改的 (function(window,undefined){ var upload = function(){ this.init(); }; ...

  7. 3631. [JLOI2014]松鼠的新家【树形DP】

    Description 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在“树”上.松鼠想邀 ...

  8. [USACO08JAN]Running

    嘟嘟嘟 这很显然是一道dp题. 令dp[i][j]表示第 i 分钟末,疲劳度为 j 是的最大跑步距离,则 dp[i][0] = max(dp[i - 1][0], max(dp[i - j][j])) ...

  9. 在centos7上搭建博客之小白教程~

    原理 http使用方法一编译安装,php模块打入方式实现. 软件版本 在本次实验中,我们需要用到的软件版本如下: apr-1.6.2 apr-util-1.6.0 httpd-2.4.28 maria ...

  10. pagination分页(支持首页,末页,跳转)

    最近在用jq做分页,大致的效果如下: jquery.pagination.js插件说明 用法如下: 1.引入jq.jquery.pagination.js.pagination.css 2.在页面上写 ...