Angular2.0于2016年9月上线,我于9月入坑。

入坑以来,一直让我很困惑的问题

  1、angular-cli是个什么鬼东西?

  2、为什么我们自己的资源文件还没写什么,就有起码50多个js文件加载出来,页面启动速度蜗牛级别

  3、ng build打包出来的文件,未压缩

  4、ng build --prod打包出来的文件,未压缩,而且缺少js文件

  5、部署后,如何替换客户端缓存文件,也就是文件版本如何更换

  6、文件配置文件在哪里?

  诸如此类问题,需要以下条件:

  angular-cli :Beta.14版本  (ng --version)

  node :Beta.4 or higher

  npm: Beta.3 or higher

  具体方法参见angular-cli在github上的原文:https://github.com/angular/angular-cli/wiki/Upgrading-from-Beta.10-to-Beta.14;

  我这里只介绍根据原文我所做的具体操作:

  1、卸载掉旧版cli,下载最新版

  npm uninstall -g angular-cli
  npm cache clean
  npm install -g angular-cli@latest  2、使用新版cli,new一个新项目出来
  ng new migration-project
  cd migration-project

  3、将新项目中的src目录备份

  mv src/ src.webpacktemplate/

 4、将原项目中的src,移入新项目中
  mv ${OLD_PATH}/src src

 5、将原项目中的e2e目录,移入新项目中
  mv ${OLD_PATH}/e2e e2e
 6、删掉新项目中不需要的文件
  rm src/system-config.ts
  rm src/typings.d.ts  7、将备份的src中这些文件拷贝出来
  cp src.webpacktemplate/polyfills.ts src/
  cp src.webpacktemplate/styles.css src/
  cp src.webpacktemplate/test.ts src/
  cp src.webpacktemplate/tsconfig.json src/
  cp src.webpacktemplate/typings.d.ts src/
 8、将备份中的src.webpacktemplate/main.ts文件,拷贝到新项目中,注意和你原项目中的main.ts做对比,保留你的代码
 9、如上操作src.webpacktemplate/index.html文件
 10、将旧目录的环境配置文件拷入,注意文件名
  mv ${OLD_PATH}/config/environment.dev.ts src/environments/environment.ts
  mv ${OLD_PATH}/config/environment.prod.ts src/environments/environment.prod.ts   此处原文标注:

  If you have any custom environments don't forget to move them too.

  Environments are now listed in the angular-cli.json. Make sure those files matches the files on your disk. More importantly, because they're part of your application, their paths are relative to   your main.ts.

 11、npm install --save ${LIBRARY}
 12、删除掉所有的 moduleId: module.id,在webpack中,module.id 是number,但是在angular中期望是一个string

 13、把你所有的静态资源文件,图片放入新项目中的src/assets目录,别忘了改代码里的引用路径
  cp -R ${OLD_PATH}/public/ src/assets/

 14、
  Finally, if you're using SASS or LESS, you need to rename your styleUrls in all your files. Webpack understands LESS and SASS so you can use styleUrls: ['my-component.scss'] in your component and it will be transcompiled automatically.
 15、可以入坑了,ng serve运行一下,改掉所有出错的地方,如果没有出错,就可以删掉src.webpacktemplate/目录了
  
 16、删掉新项目的.git配置,把原项目中的.git文件复制过来
  rm -rf .git/
  cp -R ${OLD_PATH}/.git .
  
 17、ng serve起项目,ng build --prod打包也成功了!     打包出来的东西少很多了!! 研究得出,它的配置文件是这个:


 
 
 
 

解决:Angular-cli:执行ng-build --prod后,dist文件里无js文件、文件未压缩等问题的更多相关文章

  1. 执行ng build --prod --aot命令报错

    D:\git\**\src\main\iui>ng build --prod --aotHash: 257ab60feca43633b6f7Time: 25358mschunk {0} poly ...

  2. ANGULAR 使用 ng build --prod 编译报内存错误的解决办法

    如果你遇到如下的情况 <--- Last few GCs ---> [13724:0000020D39C660D0] 231298 ms: Mark-sweep 1356.3 (1433. ...

  3. angular ng build --prod 打包报错解决方案

    使用以下代码  就不报错了 ng build --prod --no-extract-license    打包命令 使用以下代码  就不报错了 ng build --prod --no-extrac ...

  4. angular2 ng build --prod 报错:Module not found: Error: Can't resolve './$$_gendir/app/app.module.ngfactory'

    调试页面 ng serve 正常 ng build 也正常 ng build --prod 异常:Module not found: Error: Can't resolve './$$_gendir ...

  5. ng build --aot 与 ng build --prod

    angluar的编译有以下几种方式: ng build  常规的压缩操作    代码体积最大 ng build --aot   angular预编译      代码体积较小 ng build --pr ...

  6. 使用 ng build 构建后资源地址引用错误的问题

    最近使用 Angular 做项目的时候,通过 ng build 打包后的资源地址都带有 localhost:4200,百思不得其解,以为是打包的问题. 最后在 index.html 的文件中发现有一个 ...

  7. Angular6之ng build | ng build --aot | ng build --prod 差异

    由于写了大半年的项目终于要告一段落并且即将进行第二阶段优化开发,emmm 基础版本已经二十多个模块了,必不可少的优化是很重要的,尽管项目上使用多层嵌套懒加载,但是在首屏加载的时候,任然很慢啊,因为一直 ...

  8. nginx设置反向代理后,页面上的js css文件无法加载

    问题现象: nginx配置反向代理后,网页可以正常访问,但是页面上的js css文件无法加载,页面样式乱了. (1)nginx配置如下: (2)域名访问:js css文件无法加载: (3)IP访问:j ...

  9. Angular CLI 升级 6.0 之后遇到的问题

    Angular CLI 1.7.4 在使用 ng build --prod 会构建失败,而 ng build 是正常的.比较好的解决办法是使用 ng build --prod --extract-li ...

随机推荐

  1. C++ 箭头-> 双冒号:: 点号.操作符区别

    点 (.) 如果变量是一个对象或者对象引用,则用它来访问对象成员. 箭头( ->) 如果变量是一个对象指针,则用它来访问对象成员. 双冒号 (::) 如果操作目标是一个具有名空间的标识符,则用它 ...

  2. [Android Studio] Android studio 多渠道打包(超简洁版)

    [Android Studio] Android studio 多渠道打包(超简洁版) 转载:http://xuyazhou.com/archives/461 http://relex.me/usin ...

  3. UIVisualEffectView为视图添加特殊效果

    在iOS 8后,苹果开放了不少创建特效的接口,其中就包括创建毛玻璃(blur)的接口. 通常要想创建一个特殊效果(如blur效果),可以创建一个UIVisualEffectView视图对象,这个对象提 ...

  4. page-cache层以及各种标志位之间的转换

    对真实文件系统层,算是懂了,但是vfs层以及block层还是有点生疏呢,最近要好好分析一下了. page-cache层主要关注文件读写时的行为,包括页的状态之间的变化,何时变脏,何时变成writeba ...

  5. max_allowed_packet自动恢复

    https://dev.mysql.com/doc/refman/5.5/en/packet-too-large.html http://blog.chinaunix.net/uid-20304801 ...

  6. perl 简单学习,安装perl模块

    检查是否安装了某个perl模块 有多种方式 0.perldoc perlinstall 列出所有的模块及版本号 1. perl -M模块名 -e 1(模块名不加空格) 没有返回值则说明有此模块 2.p ...

  7. CSS 实现加载动画之三-钢琴按键

    今天做的这个动画实现也是非常简单,简单数几行代码就可以搞定.给这个动画取了个优雅的名字--钢琴按键,也实在是想不出什么更形象的名字了.废话不多说,直接上图. 1. 先看gif图 2. 代码实现思路 2 ...

  8. Caffe学习系列(9):运行caffe自带的两个简单例子

    为了程序的简洁,在caffe中是不带练习数据的,因此需要自己去下载.但在caffe根目录下的data文件夹里,作者已经为我们编写好了下载数据的脚本文件,我们只需要联网,运行这些脚本文件就行了. 注意: ...

  9. Google java代码风格导入Eclipse

    Git地址 https://github.com/codeset/google-java-styleguide 下载配置文件在Eclipse中执行导入:Window -> Preferences ...

  10. win系统 添加、修改右键“发送到”

    发现大家在往U盘,移动硬盘传东西的时候,总是喜欢在本地把文件复制(缺德的还会用剪切)然后在打开U盘选择粘贴,其实完全没必要使用那么多步骤,不知道大家注意没有,只要在你本地的文件上右键--发送到--你的 ...