使用Angular CLI生成 Angular 5项目教程详解


Posted in Javascript onMarch 18, 2018

如果您正在使用angular, 但是没有好好利用angular cli的话, 那么可以看看本文.

Angular CLI 官网:https://github.com/angular/angular-cli

安装angular cli:

npm install -g @angular/cli

不过首先要确保您安装了比较新版本的nodejs.

今天主要通过以下几个方面介绍Angular CLI:

  • 生成项目
  • 参数介绍
  • 配置和自定义CLI
  • 检查和修复代码
  • 生成新项目:
ng new my-app

这个命令会生成一个新的项目叫做my-app并把该项目的文件放在my-app这个文件夹下.

项目生成完的时候别忘了cd进入到my-app目录.

另一个选项是使用--dry-run参数:

ng new my-app --dry-run

使用这个参数呢, 不会真的生成项目, 而是会打印出来如果创建该项目的话哪些文件将会生成.

使用Angular CLI生成 Angular 5项目教程详解

另外一个常用的参数是--skip-install:

ng new my-app --skip-install

这个命令作用是, 生成完项目文件之后不执行npm install这个动作.

不过以后还是需要手动执行npm install的.

使用--help参数可以查看帮助:

ng new --help

使用Angular CLI生成 Angular 5项目教程详解

下面我要生成一个项目, 先不执行npm install:

使用Angular CLI生成 Angular 5项目教程详解

这个速度非常快, 然后使用我最喜欢的IDE VSCode将其打开:

code .

看看整个的项目结构, 以及package.json:

使用Angular CLI生成 Angular 5项目教程详解

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.json:

它是angular cli针对该项目的配置文件.

使用Angular CLI生成 Angular 5项目教程详解

里面的prefix比较有趣, 它是所有生成的components和directives的默认前缀.

可以查看一下app.component.ts:

使用Angular CLI生成 Angular 5项目教程详解

它的前缀就是app.

如果想更改默认前缀的话, 就可以修改angular-cli.json文件里面的prefix属性值了, 如果改成sales, 那么以后生成的components和directives的前缀就是sales. 但是对已经生成的components/directives就不起作用了.

那么如何保证生成的项目的components/directives前缀是您想要的呢?

就是使用ng new的另一个参数 --prefix:

ng new sales-app --prefix sales

使用Angular CLI生成 Angular 5项目教程详解

这时里面生成的component的selector就是:

使用Angular CLI生成 Angular 5项目教程详解

angular-cli.json文件里面的prefix:

使用Angular CLI生成 Angular 5项目教程详解

在生成的项目里可以看到, 同时还生成了spec文件. 如果我不想让我的项目生成spec文件呢?

ng new也有这个参数--skip-tests:

ng new my-app2 --skip-tests

使用Angular CLI生成 Angular 5项目教程详解

可以看到, 并没有生成任何spec文件.

ng new的参数一共有这些:

使用Angular CLI生成 Angular 5项目教程详解

有几个介绍过的, 其他的例如:

--skip-git: 生成项目的时候就不会把它初始化为git repository, 默认是初始化为git repository的.

--directory: 可以设定生成的目录, 默认是使用的项目名称.

--style: 可以设定样式的类型, 默认是css, 例如可以改成scss.

也可以通过--inline-style把样式的写法设为行内样式, 这个默认是false的.

下面我来生成一个使用scss样式的项目:

使用Angular CLI生成 Angular 5项目教程详解

可以看到生成的是styles.scss, app.component.scss文件, angular cli不仅会生成scss文件, 而且也会编译它们.

查看angular-cli.json, 可以在文件的下方看到采用的是scss样式文件:

使用Angular CLI生成 Angular 5项目教程详解

这样, 以后生成的component的默认样式文件就是scss了.

最后我想介绍一下这个参数, --routing:

使用Angular CLI生成 Angular 5项目教程详解

如果想手动为项目配置路由的话, 还是需要一些步骤的, 所以可以使用这个参数直接生成带路由配置的项目.

看一下项目路由文件:

使用Angular CLI生成 Angular 5项目教程详解

再查看一下app.module:

使用Angular CLI生成 Angular 5项目教程详解

可以看到import了AppRoutingModule.

综上, ng new 的这些参数可以在生成项目的时候作为命令的参数联合使用, 其中有一些参数也可以在项目生成以后通过修改angular-cli.json文件来做修改.

比较推荐的做法是:

在生成项目的时候使用: --routing, --prefix, --style, --dry-run参数. 首先通过--dry-run参数, 确保会生成哪些文件是否正确, 确认后把--dry-run参数去掉, 生成文件.

下面我生成一个项目, 并且执行npm install:

使用Angular CLI生成 Angular 5项目教程详解

命令执行完, 可以看到如下的项目结构;

使用Angular CLI生成 Angular 5项目教程详解

里面有node_modules目录了, 也就是所有的包都安装好了, 接下来我可以运行该项目了:

ng serve -o

其中的-o(--open)参数表示运行项目的时候打开默认浏览器.

使用Angular CLI生成 Angular 5项目教程详解

查看浏览器http://localhost:4200:

使用Angular CLI生成 Angular 5项目教程详解

ng serve的优点是, 当代码文件有变化的时候会自动重新构建并且刷新浏览器, 您可以试一下.

另外一种配置CLI的方法 ng set.

前面我介绍了使用ng new参数和修改angular-cli.json文件的方式来配置cli, 下面我介绍下通过ng set <属性> <值> 来配置cli.

就拿当前这个项目来说, 它的默认样式文件类型是scss:

使用Angular CLI生成 Angular 5项目教程详解

如果我在该项目目录执行:

ng set defaults.styleExt css

那么该项目的设置就会改变:

使用Angular CLI生成 Angular 5项目教程详解

如果使用参数 -g(--global), 那就会进行一个全局的配置, 这个配置会保存在一个文件里(如果还没有任何去安居配置的情况下这个文件并不存在), 这个文件应该在users/xxx目录下, mac的话应该在home目录下.

它不会影响到已经存在的项目. 但是如果新生成的项目不指定ng new的参数情况下, 默认就会采用全局的配置:

使用Angular CLI生成 Angular 5项目教程详解

Lint:

使用命令ng lint.

首先可以查看一下帮助:

ng lint --help

使用Angular CLI生成 Angular 5项目教程详解

--fix: 尝试修复lint出现的错误.

--format: lint的输出格式.

首先我针对上面的my-app6执行ng lint:

使用Angular CLI生成 Angular 5项目教程详解

没有问题.

然后我故意弄出来几处错误/不规范的写法:

使用Angular CLI生成 Angular 5项目教程详解

然后再执行ng lint:

使用Angular CLI生成 Angular 5项目教程详解

可以看到这些错误都被详细的列了出来.

把格式化的参数加进去:

使用Angular CLI生成 Angular 5项目教程详解

可以看到现在lint结果的显示更直观了一些.

下面执行ng lint --fix:

使用Angular CLI生成 Angular 5项目教程详解

执行后lint的错误减少到了一个, 看下代码:

使用Angular CLI生成 Angular 5项目教程详解

以上所述是小编给大家介绍的使用Angular CLI生成 Angular 5项目教程详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
[转]JS宝典学习笔记
Feb 07 Javascript
Javascript 获取链接(url)参数的方法[正则与截取字符串]
Feb 09 Javascript
javascript实现简单查找与替换的方法
Jul 22 Javascript
阿里巴巴技术文章分享 Javascript继承机制的实现
Jan 14 Javascript
JavaScript编写Chrome扩展实现与浏览器的交互及时间通知
May 16 Javascript
Javascript实现跨域后台设置拦截的方法详解
Aug 04 Javascript
Angularjs上传图片实例详解
Aug 06 Javascript
JS+HTML5实现获取手机验证码倒计时按钮
Aug 08 Javascript
利用Vue实现一个markdown编辑器实例代码
May 19 Javascript
构建大型 Vue.js 项目的10条建议(小结)
Nov 14 Javascript
原生JS实现贪吃蛇小游戏
Mar 09 Javascript
Element InfiniteScroll无限滚动的具体使用方法
Jul 27 Javascript
分析javascript原型及原型链
Mar 18 #Javascript
jquery 实现拖动文件上传加载进度条功能
Mar 18 #jQuery
jQuery中each方法的使用详解
Mar 18 #jQuery
JavaScript中字符串的常用操作方法及特殊字符
Mar 18 #Javascript
js中DOM事件绑定分析
Mar 18 #Javascript
js中如何完美的解析数据
Mar 18 #Javascript
解决使用vue.js路由后失效的问题
Mar 17 #Javascript
You might like
Uncaught exception com_exception with message Failed to create COM object
2012/01/11 PHP
PHP中SimpleXML函数用法分析
2014/11/26 PHP
php 人员权限管理(RBAC)实例(推荐)
2017/05/24 PHP
php 猴子摘桃的算法
2017/06/20 PHP
通过源码解析Laravel的依赖注入
2018/01/22 PHP
微信公众平台开发教程④ ThinkPHP框架下微信支付功能图文详解
2019/04/10 PHP
js每次Title显示不同的名言
2008/09/25 Javascript
基于jquery的一个简单的脚本验证插件
2010/04/05 Javascript
JavaScript 判断日期格式是否正确的实现代码
2011/07/04 Javascript
$.format,jquery.format 使用说明
2011/07/13 Javascript
Knockout数组(observable)使用详解示例
2013/11/15 Javascript
JavaScript设计模式之工厂方法模式介绍
2014/12/28 Javascript
30分钟快速掌握Bootstrap框架
2016/05/24 Javascript
vue.js表格组件开发的实例详解
2016/10/12 Javascript
基于jquery日历价格、库存等设置插件
2020/07/05 jQuery
微信小程序的部署方法步骤
2018/09/04 Javascript
vue实现分环境打包步骤(给不同的环境配置相对应的打包命令)
2019/06/04 Javascript
Vue elementui字体图标显示问题解决方案
2020/08/18 Javascript
[02:08]DOTA2英雄基础教程 马格纳斯
2014/01/17 DOTA
Python获取linux主机ip的简单实现方法
2016/04/18 Python
Python复制Word内容并使用格式设字体与大小实例代码
2018/01/22 Python
python实现flappy bird游戏
2018/12/24 Python
用Python+OpenCV对比图像质量的几种方法
2019/07/15 Python
Python调用C语言的实现
2019/07/26 Python
python 实现手机自动拨打电话的方法(通话压力测试)
2019/08/08 Python
CAT鞋加拿大官网:CAT Footwear加拿大
2020/08/05 全球购物
新西兰最大、占有率最高的综合性药房:PharmacyDirect药房中文网
2020/11/03 全球购物
MYSQL相比于其他数据库有哪些特点
2013/07/19 面试题
硕士研究生自我鉴定范文
2013/12/27 职场文书
大二学期个人自我评价
2014/01/13 职场文书
陈欧广告词
2014/03/14 职场文书
市场营销毕业生自荐信范文
2014/04/01 职场文书
法律顾问服务方案
2014/05/15 职场文书
机关作风建设整改方案
2014/10/27 职场文书
2014年新教师工作总结
2014/11/08 职场文书
文员岗位职责
2015/02/04 职场文书