若是您正在使用angular, 可是没有好好利用angular cli的话, 那么能够看看本文.css
Angular CLI 官网: https://github.com/angular/angular-clinode
安装angular cli:git
npm install -g @angular/cli
不过首先要确保您安装了比较新版本的nodejs.github
今天主要经过如下几个方面介绍Angular CLI:npm
ng new my-app
这个命令会生成一个新的项目叫作my-app并把该项目的文件放在my-app这个文件夹下.json
项目生成完的时候别忘了cd进入到my-app目录.浏览器
另外一个选项是使用--dry-run参数:app
ng new my-app --dry-run
使用这个参数呢, 不会真的生成项目, 而是会打印出来若是建立该项目的话哪些文件将会生成.工具
另一个经常使用的参数是--skip-install:ui
ng new my-app --skip-install
这个命令做用是, 生成完项目文件以后不执行npm install这个动做.
不过之后仍是须要手动执行npm install的.
使用--help参数能够查看帮助:
ng new --help
下面我要生成一个项目, 先不执行npm install:
这个速度很是快, 而后使用我最喜欢的IDE VSCode将其打开:
code .
看看整个的项目结构, 以及package.json:
scripts下面是一些预约义的项目命令:
start 是运行项目的意思, 执行npm start便可, 或者直接执行ng serve也能够.
npm build / ng build 是执行构建.......
不一一介绍了.
而后看下dependencies:
咱们使用的是angular 5.2.0, 前面的^符号表示, 咱们使用的版本号是大于等于5.2.0的可是确定会小于6.
最下面是devDependencies, 里面都是开发时用的工具库, 能够看到angular cli就在里面.
接下来看看angular-cli.json这个文件:
它是angular cli针对该项目的配置文件.
里面的prefix比较有趣, 它是全部生成的components和directives的默认前缀.
能够查看一下app.component.ts:
它的前缀就是app.
若是想更改默认前缀的话, 就能够修改angular-cli.json文件里面的prefix属性值了, 若是改为sales, 那么之后生成的components和directives的前缀就是sales. 可是对已经生成的components/directives就不起做用了.
那么如何保证生成的项目的components/directives前缀是您想要的呢?
就是使用ng new的另外一个参数 --prefix:
ng new sales-app --prefix sales
这时里面生成的component的selector就是:
angular-cli.json文件里面的prefix:
在生成的项目里能够看到, 同时还生成了spec文件. 若是我不想让个人项目生成spec文件呢?
ng new也有这个参数--skip-tests:
ng new my-app2 --skip-tests
能够看到, 并无生成任何spec文件.
ng new的参数一共有这些:
有几个介绍过的, 其余的例如:
--skip-git: 生成项目的时候就不会把它初始化为git repository, 默认是初始化为git repository的.
--directory: 能够设定生成的目录, 默认是使用的项目名称.
--style: 能够设定样式的类型, 默认是css, 例如能够改为scss.
也能够经过--inline-style把样式的写法设为行内样式, 这个默认是false的.
下面我来生成一个使用scss样式的项目:
能够看到生成的是styles.scss, app.component.scss文件, angular cli不只会生成scss文件, 并且也会编译它们.
查看angular-cli.json, 能够在文件的下方看到采用的是scss样式文件:
这样, 之后生成的component的默认样式文件就是scss了.
最后我想介绍一下这个参数, --routing:
若是想手动为项目配置路由的话, 仍是须要一些步骤的, 因此可使用这个参数直接生成带路由配置的项目.
看一下项目路由文件:
再查看一下app.module:
能够看到import了AppRoutingModule.
综上, ng new 的这些参数能够在生成项目的时候做为命令的参数联合使用, 其中有一些参数也能够在项目生成之后经过修改angular-cli.json文件来作修改.
比较推荐的作法是:
在生成项目的时候使用: --routing, --prefix, --style, --dry-run参数. 首先经过--dry-run参数, 确保会生成哪些文件是否正确, 确认后把--dry-run参数去掉, 生成文件.
下面我生成一个项目, 而且执行npm install:
命令执行完, 能够看到以下的项目结构;
里面有node_modules目录了, 也就是全部的包都安装好了, 接下来我能够运行该项目了:
ng serve -o
其中的-o(--open)参数表示运行项目的时候打开默认浏览器.
查看浏览器http://localhost:4200:
ng serve的优势是, 当代码文件有变化的时候会自动从新构建而且刷新浏览器, 您能够试一下.
前面我介绍了使用ng new参数和修改angular-cli.json文件的方式来配置cli, 下面我介绍下经过ng set <属性> <值> 来配置cli.
就拿当前这个项目来讲, 它的默认样式文件类型是scss:
若是我在该项目目录执行:
ng set defaults.styleExt css
那么该项目的设置就会改变:
若是使用参数 -g(--global), 那就会进行一个全局的配置, 这个配置会保存在一个文件里(若是尚未任何去安居配置的状况下这个文件并不存在), 这个文件应该在users/xxx目录下, mac的话应该在home目录下.
它不会影响到已经存在的项目. 可是若是新生成的项目不指定ng new的参数状况下, 默认就会采用全局的配置:
使用命令ng lint.
首先能够查看一下帮助:
ng lint --help
--fix: 尝试修复lint出现的错误.
--format: lint的输出格式.
首先我针对上面的my-app6执行ng lint:
没有问题.
而后我故意弄出来几处错误/不规范的写法:
而后再执行ng lint:
能够看到这些错误都被详细的列了出来.
把格式化的参数加进去:
能够看到如今lint结果的显示更直观了一些.
下面执行ng lint --fix:
执行后lint的错误减小到了一个, 看下代码:
接下来还会写几篇angular cli的文章.