Cesium打包命令总结
引言
Cesium实验室QQ群里有人在问Cesium的打包问题。我想干脆总结一下Cesium的打包命令特点,写篇文章,顺带庆祝一下1024程序员节。。
Cesium的npm脚本有好多,其中几个和打包相关的命令我用红框圈了出来,以下来一一解释。
大部分的命令都是以gulp开头,可以看出Cesium是使用gulp进行打包的。在webpack早已成趋势的今天,Cesium的做法算是比较古老了。打包的细节可以在根目录下的gulpfile.js文件中查找到。以下npm命令的实现代码截图也都是出自gulpfile.js文件。
之前我经常把打包命令称为编译命令,结果被同学给怼了。。后来查了一下js方面的术语,虽然网上也有些文章称为编译,但是大多还是叫打包。可能是我之前C++用多了的后遗症吧。。很抱歉之前给各位同学造成了迷惑。。所以我也更正一下之前的称呼。。统一叫打包。。
打包命令详述
npm start
这个命令是启动Cesium自己写的一个http服务,虽然不是打包命令,但是比较典型,这里简单介绍一下。
执行这个命令以后,就可以启动服务了,端口号强制为8080。这个时候可以在浏览器中输入localhost:8080
,效果如下:
注意点1: 如果这个端口号被占用,那么对不起,服务起不来。没有webpack那么机智,不会自动替换一个端口号。
所以有时候,如果真的不想停止现有的8080端口服务。可以手动换个端口号运行,执行下面的命令:
node server.js --port 8081
注意点2: 另外还有一个值得注意的问题,Cesium的npm start命令启动的服务, 只能在本机查看 ,如果想在局域网内其他机器上观看,是不行的。如何解决这个问题呢?可以运行以下命令来搞定:
npm run startPublic
注意,必须要加上 run ,否则还是跑不起来的。
npm run build
Cesium的npm run build命令,和其他一些开源库,真的是有点儿差别。大部分项目执行这个命令的意思,一般都是打包生成一个dist文件夹,并且把编译压缩优化(生产环境下)的js放进去。但是Cesium却是在Source目录下生成了一个Cesium.js文件,注意您没看错,是 Source 文件夹下。当然也偷偷做了点别的事情,暂且不表。。
重要的事情再说一遍:Source文件夹下的这个Cesium.js文件,默认情况下是没有的,并不是源码文件,是运行npm run build
命令构建出来的js文件。
奇怪了,Cesium打包的结果,为什么要放在Source文件夹下?
其实这里的Cesium.js文件并不是真正意义上对外输出(生产环境下)的js文件,仅仅是把Cesium源码中一千两百多个js文件做了一下引用。。所以这个Cesium.js也就相当于一个索引。这样外界使用时,只要引用这么一个Cesium.js文件,就会通过AMD模式自动引入其他Cesium的源码js文件来使用。
这是Cesium打包时的一个比较特殊的地方,Cesium通过这种方式,就可以在网页中直接调试源码了。很遗憾,Cesium并没有使用目前比较流行的SourceMap的方式。
那么既然npm run build
命令并不会进行打包,那么真正的打包命令是什么呢?这里就要说到npm run minifyRelease
命令了。
npm run minifyRelease
这个命令会把Source目录下所有的js文件打包放到Build/Cesium/目录下,并且生成一个真正的供生产环境下来使用的Cesium.js文件。因为执行了各种编译压缩打包等操作,所以编译速度比较慢,在我的机器上,大概需要2分钟才能编译完。。
我们再来分析一下这个命令的操作,如下图所示:
outputDirectory
选项中可以看到,Cesium把压缩优化后的Cesium.js文件放在了Build/Cesium/目录下。
optimizer
选项则表示js代码如何压缩优化,Cesium使用的是uglify2。
removePragmas
选项是用来删除源码中的调试信息的。我们查看Cesium源码时,有时会发现源码中有大量的includeStart
开头的注释,如下图所示。这里面大多是调试信息,removePragmas设置为true,相当于来删除includeStart
和includeEnd
之间的js语句。
npm run minify
npm run minify
命令的配置如下图所示,可以看到他会压缩优化js代码,但是不会去掉调试信息。
npm run combine
npm run combine
命令则是既不压缩优化,也不去掉调试信息。相当于生成具备调试信息的js文件。
npm run combineRelease
npm run combineRelease
命令相当于不进行压缩优化,但是去掉了调试信息。
npm run release
npm run release
命令则相当于combine、minifyRelease、generateDocumentation三个命令的集合。他会同时做了三件事:
- 在Build/CesiumUnminified目录下生成调试版的Cesium.js文件;
- 在Build/Cesium目录下生成压缩优化好的(生产环境下)的Cesium.js文件;
- 并且还生成了Cesium的api文档,文档放在Build/Documentation目录下。
打包遗留问题
看不到Development分组
很多同学会反馈Cesium的示例代码中有的时候看不到Development分组。
这主要是因为npm run build
和npm run release
命令都会生成Apps/Sandcastle/gallery/gallery-index.js文件,这个文件是用来管理Cesium的示例目录的。然而后者生成的gallery-index.js文件会去掉develop分组。所以实际情况是,执行了npm run release
命令以后,Development分组就会消失。如果希望再次看到,方法也很简单,就是再次执行一下npm run build
命令即可。
编译包和源码包的区别
Cesium官方在github中会同时提供两个版本的zip包,头一个是Cesium事先打包编译好的,这个zip包里面会有Build目录。在自己的项目中直接拿来引用Build/Cesium/Cesium.js就好。但是您在这个zip包里面是看不到Cesium示例中的development分组的,而且也不能执行npm run build
进行编译(部分编译文件被移除)。
如果希望看到development分组示例,或者修改Cesium源码的话,就只能用第二个zip包了。这个zip包里面只有源码,需要自行打包。
总结
- npm run build 只是生成了一个Source目录的Cesium.js文件,相当于一个索引;
- npm run minifyRelease 才是真正用来输出生产环境下的Cesium.js文件,输出目录在Build/Cesium/下;
- npm run release 同时输出调试版的Cesium.js、生产环境下的Cesium.js和api文档。
欢迎关注 Cesium实验室 ,QQ群号:595512567。
Cesium打包命令总结的更多相关文章
- Cesium打包命令
package.json中 (1) npm run build Source/Cesium.js 仅是把Cesium源码中一千两百多个js文件做了一下引用,并不会进行打包 所以这个Cesium.js也 ...
- 攻城狮在路上(叁)Linux(二十八)--- 打包命令:tar
首先介绍一下tar打包命令的基本格式,下面的三种之间不能混淆. tar [-j|-z] [cv] [-f 新文件名] file1 file2 ...; tar [-j|-z] [tv] [-f 新文件 ...
- Linux tar打包命令
Linux tar打包命令: 范例一:将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar [root@linux ~]# tar -cvf /tmp/etc.tar /etc < ...
- 转 vagrant package[打包命令]详解
转 vagrant package[打包命令]详解 vagrant的一个非常重要的功能就是在你的同事之间分享你的box从而使大家的开发环境保持同步,打包[package]正是实现这一功能的关键所在 ...
- 第九章、文件与文件系统的压缩与打包 3. 打包命令: tar
打包命令: tar gzip 与 bzip2 也能够针对目录来进行压缩, 不过,这两个命令对目录的压缩指的是『将目录内的所有文件 "分别" 进行压缩』! 将多个文件或目录包成一个大 ...
- 查看目标文件是否是以-fPIC编译的, ar 打包命令将多个静态库打包到一个里面
readelf --relocs foo.o | egrep '(GOT|PLT|JU?MP_SLOT)' 上句大多数时候(和平台有关)可以正确判断是否是以fPIC选项编译的,如果输出为空,基本可以表 ...
- ant打包命令
学习ant打包命令.发布到以上tomcat还未做集成部署,无法添加到jenkins中. http://blog.csdn.net/telnetor/article/details/7015935 ht ...
- iOS 应用打包命令一览
文章转载自:http://www.jianshu.com/p/5d59966eaecc 文章排版部分根据自己的理解做了一些修改. 各种命令的简介 使用命令打包iOS 应用一般会用到 xcodebuli ...
- Linux打包命令 - tar
上一篇文章谈到的命令大多仅能针对单一文件来进行压缩,虽然 gzip 与 bzip2 也能够针对目录来进行压缩, 不过,这两个命令对目录的压缩指的是『将目录内的所有文件 "分别" 进 ...
随机推荐
- javascript中onclick(this)用法和onclick(this.value)用法介绍
onclick(this.value)代码详解 <html> <head> <script language="javascript"> fun ...
- node.js在ubuntu上和windows上的安装
Ubuntu 上安装 Node.js Node.js 源码安装 以下部分我们将介绍在Ubuntu Linux下安装 Node.js . 其他的Linux系统,如Centos等类似如下安装步骤. 在 G ...
- python基于SMTP发送邮件
import smtplib from email.header import Header from email.mime.text import MIMEText ''' SMTP是发送邮件的协议 ...
- csdn的富文本编辑器(html)格式的文章,添加的代码格式粘贴到项目中总是不对,我这里是maven的pom文件。
在用富文本编辑器(html)格式编辑的时候,总是出现将pom文件的配置从csdn粘贴到项目中发现很多红,是因为自己在设置的时候有问题. 因为我们的是pom.xml,这里原来设置的java呀或者js为了 ...
- Hexo 博客图片添加至图床---腾讯云COS图床使用。
个人博客:https://mmmmmm.me 源码:https://github.com/dataiyangu/dataiyangu.github.io 腾讯云官网 登录注册 创建存储桶 进入上面的存 ...
- UVA 12412 A Typical Homework (a.k.a Shi Xiong Bang Bang Mang)
题目链接:https://vjudge.net/problem/UVA-12412 题目大意 略. 分析 比较大规模的模拟,注意输入输出,浮点数精度,还有排名相同的输出顺序,还有一些边界情况处理. 代 ...
- 依赖注入(DI)
Spring依赖注入(DI)的三种方式,分别为: 1. 接口注入 2. Setter 方法注入 3. 构造方法注入 依赖注入是一种思想,或者说是一种设计模式,在java中是通过反射机制实现,与具 ...
- docker上安装ActiveMQ
1.查看是否已经存在镜像 docker images 2.搜索镜像 docker search activemq 3.拉取镜像 docker pull webcenter/activemq 4.构建容 ...
- Python系统(os)相关操作
文件操作 python中常用于文件处理的模块有os,shutil等. 1 创建文件 文件的创建可以使用open()函数,如下创建一个test_file.txt的文件: >>> wit ...
- mysqldump使用记录
#导出单个数据库:结构 无数据 [root@localhost ~]#mysqldump -h127.0.0.1 -uroot -p --opt --no-data db_name >~/db_ ...