使用Angular Cli如何创建Angular私有库详解


Posted in Javascript onJanuary 30, 2019

前言

在实际开发中,会发现我们好多工作都是重复的,在代码层面,发现好多代码是可以被重用的。这样我们就可以建一个库,类似于java的库,来提高工作效率。

下面话不多说了,来一起看看详细的介绍吧

创建Angular项目

打开命令行终端, cd 到用于创建应用的目录下,执行创建Angular项目命令:

ng new arsprojects -S

此命令将会创建一个新的Angular项目,文件夹名为 arsprojects 。 -S 参数表示不创建测试文件。我们创建的ng库都将依托于 arsprojects 项目,它只是作为ng库的容器存在,不需要建立测试。

用IDE打开 arsprojects 项目。

使用Angular Cli如何创建Angular私有库详解

看到的文件结构就是我们常用的Angular项目结构。平时我们开发Angular项目,就是在 src/app 目录下进行的。

我们想建的是一个ng库,它和原来的Angular项目还是有一定差异的,ng库不需要操作 src/app 下的内容。

创建一个组件库

ng g library ars-components -p ars

g 是generate的简写方式, library 表示我们创建的是一个库。 -p ars 表示我们创建的库里面的组件是以 ars 开头的。例如我们创建一个checkbox组件,那么他的selector就是 ars-checkbox ,在HTML中通过标签来使用我们组件。

执行完该命令后,在ide中会发现,在我们的arsprojects中多了一个 projects 文件夹,里面是我们刚创建的 ars-components 。

使用Angular Cli如何创建Angular私有库详解

同时,我们一开始创建arsprojects项目时创建的angular-cli.json也会被修改。里面会增加 ars-components 的项目信息。

"ars-components": {
"root": "projects/ars-components",
"sourceRoot": "projects/ars-components/src",
"projectType": "library",
"prefix": "ars",
"architect": {
"build": {
"builder": "@angular-devkit/build-ng-packagr:build",
"options": {
"tsConfig": "projects/ars-components/tsconfig.lib.json",
"project": "projects/ars-components/ng-package.json"
},
"configurations": {
"production": {
"project": "projects/ars-components/ng-package.prod.json"
}
}
},
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"main": "projects/ars-components/src/test.ts",
"tsConfig": "projects/ars-components/tsconfig.spec.json",
"karmaConfig": "projects/ars-components/karma.conf.js"
}
},
"lint": {
"builder": "@angular-devkit/build-angular:tslint",
"options": {
"tsConfig": [
"projects/ars-components/tsconfig.lib.json",
"projects/ars-components/tsconfig.spec.json"
],
"exclude": [
"**/node_modules/**"
]
}
}
}
}
},
"defaultProject": "arsprojects"

同时会在 tsconfig.json 中创建 paths 选项。

"paths": {
"ars-components": [
"dist/ars-components"
]

通过修改tsconfig.json配置,可以让我们方便的使用ars-components库。

创建web站点项目

ng g application arswebsite --prefix web

此命令通过 application 脚手架创建一个名为 arswebsite 的项目,selector前缀为 web 。在ide中发现在ars-commponents同级目录下创建了arswebsite和arswebsite-e2e两个文件夹。

运行项目

在运行项目前,先做一些小改动,用于区分项目。

修改 projects/arswebsite/src/app/app.component.html 为

<h1>ArsWeb</h1>

修改 src/app/app.component.html 为

<h1>Main Angular App</h1>

启动项目

ng serve

打开浏览器,访问 http://localhost:4200。

另打开一个终端,执行命令

ng serve arswebsite --port 4201

打开浏览器,访问 http://localhost:4201。

此时会发现,访问了两个不同的项目内容。

在ng库中创建新组件

cd projects/ars-components/src/lib
ng generate component checkbox --project=ars-components

这样就会在我们的ars-components库中创建一个checkbox组件,组件的selector为ars-checkbox

编译组件

cd yourfolder/arsprojects
ng build ars-components

会在dist目录下生成ars-components编译后的内容。

安装组件

编译后的组件,想要使用,需要现在本地安装。

npm install dist/ars-components

使用组件

在arswebsite中使用ars-components组件,此时和使用其他第三方组件没有任何区别。

website/src/app/app.moudle.ts 中引入 ArsComponentsModule :

import { ArsComponentsModule } from 'ars-components';

....

imports: [
 BrowserModule, ArsComponentsModule
],

这样就可以在arswebsite中直接使用自定义库中的库组件了。

arswebsite/src/app/app.component.html 添加自定义组件

<ars-checkbox></ars-checkbox>

总结

在使用Angular cli创建库总体来说还是很方便的,创建库的意义就是让我们在实际开发过程中,总结的一些可以被复用的代码形成一个可被共享的资源,从而提高效率。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
InnerHtml和InnerText的区别分析
Mar 13 Javascript
WEB高性能开发之疯狂的HTML压缩
Jun 19 Javascript
发布一个基于javascript的动画类 Fx.js
Nov 05 Javascript
JavaScript的事件绑定(方便不支持js的时候)
Oct 01 Javascript
jquery清空表单数据示例分享
Feb 13 Javascript
JS仿iGoogle自定义首页模块拖拽特效的方法
Feb 13 Javascript
JS+CSS实现可拖拽的漂亮圆角特效弹出层完整实例
Feb 13 Javascript
jQuery实现行文字链接提示效果的方法
Mar 10 Javascript
jquery中$each()方法的使用指南
Apr 30 Javascript
JavaScript的removeChild()函数用法详解
Dec 27 Javascript
jQuery实现点击查看大图并以弹框的形式居中
Aug 08 Javascript
详解AngularJS跨页面传值(ui-router)
Aug 23 Javascript
async/await优雅的错误处理方法总结
Jan 30 #Javascript
新年快乐! javascript实现超级炫酷的3D烟花特效
Jan 30 #Javascript
JavaScript之解构赋值的理解
Jan 30 #Javascript
JS实现点击按钮随机生成可拖动的不同颜色块示例
Jan 30 #Javascript
JS实现的新闻列表自动滚动效果示例
Jan 30 #Javascript
谈谈为什么你的 JavaScript 代码如此冗长
Jan 30 #Javascript
JS实现头条新闻的经典轮播图效果示例
Jan 30 #Javascript
You might like
亲密接触PHP之PHP语法学习笔记1
2006/12/17 PHP
用PHP控制用户的浏览器--ob*函数的使用说明
2007/03/16 PHP
初级的用php写的采集程序
2007/03/16 PHP
PHP下几种删除目录的方法总结
2007/08/19 PHP
php 全文搜索和替换的实现代码
2008/07/29 PHP
phpmyadmin打开很慢的解决方法
2014/04/21 PHP
Zend Framework动作助手Redirector用法实例详解
2016/03/05 PHP
找到了一篇jQuery与Prototype并存的冲突的解决方法
2007/08/29 Javascript
jQuery UI的Dialog无法提交问题的解决方法
2011/01/11 Javascript
弹出层之1:JQuery.Boxy (一) 使用介绍
2011/10/06 Javascript
js取滚动条的尺寸的函数代码
2011/11/30 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
JQUERY实现网页右下角固定位置展开关闭特效的方法
2015/07/27 Javascript
JS简单模拟触发按钮点击功能的方法
2015/11/30 Javascript
学习javascript面向对象 掌握创建对象的9种方式
2016/01/04 Javascript
jQuery简单动画变换效果实例分析
2016/07/04 Javascript
原生JS实现图片轮播切换效果
2016/12/15 Javascript
js实现简单的选项卡效果
2017/02/23 Javascript
微信小程序 ecshop地址三级联动实现实例代码
2017/02/28 Javascript
mongoose中利用populate处理嵌套的方法
2017/05/26 Javascript
深入浅析JavaScript中的RegExp对象
2017/09/18 Javascript
NodeJS如何实现同步的方法示例
2018/08/24 NodeJs
JS实现时间校验的代码
2020/05/25 Javascript
[51:52]Liquid vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.24
2019/09/10 DOTA
Python实现的数据结构与算法之双端队列详解
2015/04/22 Python
Python下调用Linux的Shell命令的方法
2018/06/12 Python
Python实现图片裁剪的两种方式(Pillow和OpenCV)
2019/10/30 Python
将tensorflow模型打包成PB文件及PB文件读取方式
2020/01/23 Python
Python操作Excel把数据分给sheet
2020/05/20 Python
windeln官方海外旗舰店:德淘超人气母婴超市
2017/12/15 全球购物
卡拉威高尔夫官方网站:Callaway Golf
2020/09/16 全球购物
宿舍打麻将检讨书
2014/01/24 职场文书
2014年保险业务员工作总结
2014/12/23 职场文书
小学语文继续教育研修日志
2015/11/13 职场文书
python的列表生成式,生成器和generator对象你了解吗
2022/03/16 Python
Python基本的内置数据类型及使用方法
2022/04/13 Python