详解如何为你的angular app构建一个第三方库


Posted in Javascript onDecember 07, 2018

Angular 团队 在 angular6 中,使得创建 Angular 第三方库变得更为简单。如果你以前尝试过操作,你会发现其实不是很简单!

那么流程是什么呢?

首页我们构建一个搭建一个简单的环境,环境里面包含一些组件和服务以及一些接口。

创建项目

1.按照官方教程,使用 ng new 命令初始化项目:

ng new lib-demo --prefix ld

在 angular-cli 第6个之后版本。配置文件的方式发生了相当大变化, angular.json 现在代表 angular 工作空间,

详解如何为你的angular app构建一个第三方库

你可以可以使用 ng generate application [my-app-name] 命令添加更多项目

你也可以通过 ng generate 指令创建一个公共库。

ng generate library tvmaze --prefix tm

当然你可以使用简写命令

ng g lib tvmaze --prefix tm

具体参照

使用 generate 在我们 angular.json 中添加一个项目。

详解如何为你的angular app构建一个第三方库

在库中创建一个服务

我们会发现tvmaze有它自己的 package.jsontsconfig.jsontslint.jsonkarma.conf.js ,这样建立是有原因的,因为这个项目独立与主应用建立而成,它本身也有组件、服务、模块。稍后我们添加其他的内容。现在我们添加一些逻辑:

详解如何为你的angular app构建一个第三方库

这里说明下 provideIn: rootangular6 之后的新属性,详情见官网;如果是为了打包优化。

在库中创建一个组件

我们使用 angular-cli 来创建一个组件

# 使用--project 指定创建在那个工程中
ng generate component poster --project=tvmaze

然后这样编辑

详解如何为你的angular app构建一个第三方库

将组件注册到 TvmazeModule 中,并且 exports 中是的外部能够访问,还得添加 CommonModule , HttpClientModule 两个模块。

详解如何为你的angular app构建一个第三方库

构建一下

在我们使用之前,我们先构建一下,我们 ng build 构建,指定项目。

ng build tvmaze

使用库

接下来,我们来使用刚刚构建好的库,一般我们采用第三方库都是使用 import 来导入。

详解如何为你的angular app构建一个第三方库

我们会发现库不存在。因为这种方式,它是从 node_modules 寻找,所以我们要在根目录下 tsconfig.json 添加 paths

详解如何为你的angular app构建一个第三方库

接下来我们在主项目中运用:使用 <tm-poster> 标签,即可完成

详解如何为你的angular app构建一个第三方库

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
深入解析contentWindow, contentDocument
Jul 04 Javascript
javascript中返回顶部按钮的实现
May 05 Javascript
jQuery form插件之formDdata参数校验表单及验证后提交
Jan 23 Javascript
详解vee-validate的使用个人小结
Jun 07 Javascript
解决在vue+webpack开发中出现两个或多个菜单公用一个组件问题
Nov 28 Javascript
解决vue中虚拟dom,无法实时更新的问题
Sep 15 Javascript
javascript实现计算指定范围内的质数示例
Dec 29 Javascript
前端Vue项目详解--初始化及导航栏
Jun 24 Javascript
JS实现移动端在线签协议功能
Aug 22 Javascript
Vue实现将数据库中带html标签的内容输出(原始HTML(Raw HTML))
Oct 28 Javascript
详解一些适用于Node.js的命名约定
Dec 08 Javascript
JS中箭头函数与this的写法和理解
Jan 14 Javascript
JS实现随机生成10个手机号的方法示例
Dec 07 #Javascript
angular学习之动态创建表单的方法
Dec 07 #Javascript
JavaScript栈和队列相关操作与实现方法详解
Dec 07 #Javascript
微信小程序实现两边小中间大的轮播效果的示例代码
Dec 07 #Javascript
vue webpack打包后图片路径错误的完美解决方法
Dec 07 #Javascript
详解在create-react-app使用less与antd按需加载
Dec 06 #Javascript
vant(ZanUi)结合async-validator实现表单验证的方法
Dec 06 #Javascript
You might like
不用数据库的多用户文件自由上传投票系统(3)
2006/10/09 PHP
解决了Ajax、MySQL 和 Zend Framework 的乱码问题
2009/03/03 PHP
php结合ACCESS的跨库查询功能
2015/06/12 PHP
Yii 2中的load()和save()示例详解
2017/08/03 PHP
Javascript 键盘事件的组合使用实现代码
2012/05/04 Javascript
jquery实现鼠标滑过显示提示框的方法
2015/02/05 Javascript
JavaScript实现网站访问次数统计代码
2015/08/12 Javascript
jQuery插件easyUI实现通过JS显示Dialog的方法
2016/09/16 Javascript
js初始化验证实例详解
2016/11/26 Javascript
微信小程序 增、删、改、查操作实例详解
2017/01/13 Javascript
详解Vue-基本标签和自定义控件
2017/03/24 Javascript
微信小程序简单实现form表单获取输入数据功能示例
2017/11/30 Javascript
[50:58]2018DOTA2亚洲邀请赛 4.1 小组赛 B组 Mineski vs EG
2018/04/03 DOTA
[02:33]2018 DOTA2亚洲邀请赛回顾视频 再次拾起那些美妙的时刻
2018/04/10 DOTA
Python中删除文件的程序代码
2011/03/13 Python
python中global用法实例分析
2015/04/30 Python
Python随手笔记第一篇(2)之初识列表和元组
2016/01/23 Python
python中pandas.DataFrame对行与列求和及添加新行与列示例
2017/03/12 Python
Python计时相关操作详解【time,datetime】
2017/05/26 Python
浅谈Python peewee 使用经验
2017/10/20 Python
Python函数参数操作详解
2018/08/03 Python
python实现贪吃蛇小游戏
2020/03/21 Python
python字符串替换第一个字符串的方法
2019/06/26 Python
浅析pandas 数据结构中的DataFrame
2019/10/12 Python
python中温度单位转换的实例方法
2020/12/27 Python
CSS3实现超酷的黑猫警长首页
2016/04/26 HTML / CSS
茵宝(Umbro)英国官方商店:英国足球服装生产商
2016/12/29 全球购物
Nike瑞士官网:Nike CH
2021/01/18 全球购物
英国珠宝网站Argento: PANDORA、Olivia Burton和Nomination等
2020/05/08 全球购物
路德维希•贝克(LUDWIG BECK)中文官网:德国大型美妆百货
2020/09/19 全球购物
销售自荐信
2013/10/22 职场文书
道路交通事故赔偿协议书
2014/10/24 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书
Nginx反向代理及负载均衡如何实现(基于linux)
2021/03/31 Servers
Python爬虫中urllib3与urllib的区别是什么
2021/07/21 Python
python3中apply函数和lambda函数的使用详解
2022/02/28 Python