前言
作为一个程序猿必须要把cesium的源码拿来自己打包试试,新版的Cesium要在node环境下用gulp打包,git,node的安装这里就不说了。假设自己已经安装好了。
gulp安装
此处参考https://blog.csdn.net/donglaoxie/article/details/104599035
1.如果你先前将 gulp 安装到全局环境中了,请执行以下命令将 gulp 删除
npm rm --global gulp
2.全局安装cli命令行工具:
npm install --global gulp-cli
3.命令行进入项目文件夹,安装gulp:
npm install --save-dev gulp
4.检查gulp是否安装成功:
gulp -version
出现gulp的版本号即表示gulp成功安装了
Cesium打包命令
此处参考https://www.cnblogs.com/onsummer/p/12597594.html和https://www.jianshu.com/p/2d4bd6e30c1b
不管运行哪个打包命令,先把cesium的依赖包安装好,执行以下命令:
npm install
1.傻瓜式打包
执行命令:npm run makeZipFile
会在根目录生成一个"Cesium-<版本号>.zip"压缩包,与官方提供的分发包是一模一样的。
2.发布式打包
执行命令:npm run release
在根目录下生成Build文件夹,内含Cesium子目录、CesiumUnminified子目录、Documentation子目录。
release命令会生成和官方分发包一样的两个版本API,即Cesium子目录、CesiumUnminified子目录,分别代表
Cesium:删除debug信息,压缩代码
CesiumUnminified:不删除debug信息,不压缩代码。
这个命令执行了combine、minifyRelease、generateDocumentation三个命令,代码中也是这么实现的
3.启动cesium自己的本地开发者站点&文档服务
执行命令:npm run start
注意:此命令执行后会弹出一个首页(无首页先release再start),这个服务是使用express架设起来的,端口为8080,在根目录的server.cjs中设置端口号
4.npm run build
大部分项目执行这个命令都是打包生成一个dist文件夹,并且把编译压缩优化(生产环境下)的js放进去。但是Cesium却是在Source目录下生成了一个Cesium.js文件(默认Source文件夹中没有这个js文件),这里的Cesium.js文件并不是真正意义上对外输出(生产环境下)的js文件,仅仅是把Cesium源码中一千两百多个js文件做了一下引用。。所以这个Cesium.js也就相当于一个索引。这样外界使用时,只要引用这么一个Cesium.js文件,就会通过AMD模式自动引入其他Cesium的源码js文件来使用。
5.npm run minifyRelease
这个命令会把Source目录下所有的js文件打包放到Build/Cesium/目录下,删除debug信息,并且生成一个真正的供生产环境下来使用的Cesium.js文件。编译速度比较慢,具体解释看开头我参考的博文,解释的很清楚,怕丢了,我截图了一下。
根据上面的解释,再看minify,combine,combineRelease就很清楚了。
6.npm run combine
命令则是既不压缩优化,也不去掉调试信息。相当于生成具备调试信息的js文件。