详解如何为你的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 相关文章推荐
不一样的文字闪烁 轮番闪烁
Nov 11 Javascript
微信小程序实现图片自适应(支持多图)
Jan 25 Javascript
node.js程序作为服务并在windows下开机自启动(用forever)
Mar 29 Javascript
详解Vue 事件修饰符capture 的使用
Dec 29 Javascript
web前端vue实现插值文本和输出原始html
Jan 19 Javascript
react以create-react-app为基础创建项目
Mar 14 Javascript
vue动态绑定class选中当前列表变色的方法示例
Dec 19 Javascript
微信小程序实现日期格式化和倒计时
Nov 01 Javascript
layui 上传图片 返回图片地址的方法
Sep 26 Javascript
JavaScript实现手机号码 3-4-4格式并控制新增和删除时光标的位置
Jun 02 Javascript
element日历calendar组件上月、今天、下月、日历块点击事件及模板源码
Jul 27 Javascript
uniapp实现可以左右滑动导航栏
Oct 21 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
DIY实用性框形天线
2021/03/02 无线电
在次封装easyui-Dialog插件实现代码
2010/11/14 Javascript
动态加载外部javascript文件的函数代码分享
2011/07/28 Javascript
jquery插件jSignature实现手动签名
2015/05/04 Javascript
js制作带有遮罩弹出层实现登录注册表单特效代码分享
2015/09/05 Javascript
js图片卷帘门导航菜单特效代码分享
2015/09/10 Javascript
javascript实现获取浏览器版本、浏览器类型
2015/12/02 Javascript
全面介绍javascript实用技巧及单竖杠
2016/07/18 Javascript
jQuery progressbar通过Ajax请求实现后台进度实时功能
2016/10/11 Javascript
Angular下H5上传图片的方法(可多张上传)
2017/01/09 Javascript
canvas绘制万花筒效果(代码分享)
2017/01/20 Javascript
three.js快速入门【推荐】
2017/01/21 Javascript
bootstrap 路径导航 分页 进度条的实例代码
2018/08/06 Javascript
Nodejs中怎么实现函数的串行执行
2019/03/02 NodeJs
extjs图形绘制之饼图实现方法分析
2020/03/06 Javascript
[05:36]DOTA2 2015国际邀请赛中国区预选赛第四日TOP10
2015/05/29 DOTA
基于DataFrame改变列类型的方法
2018/07/25 Python
python读取文本中的坐标方法
2018/10/14 Python
Python不同目录间进行模块调用的实现方法
2019/01/29 Python
Python使用lambda表达式对字典排序操作示例
2019/07/25 Python
django-xadmin根据当前登录用户动态设置表单字段默认值方式
2020/03/13 Python
Pandas把dataframe或series转换成list的方法
2020/06/14 Python
Python join()函数原理及使用方法
2020/11/14 Python
HTML5之SVG 2D入门2—图形绘制(基本形状)介绍及使用
2013/01/30 HTML / CSS
加拿大消费电子和手机购物网站:The Source
2017/01/28 全球购物
英国鞋网:Rubber Sole
2020/03/03 全球购物
信息专业学生学习的自我评价
2014/02/17 职场文书
内刊编辑求职自荐书范文
2014/02/19 职场文书
音乐之声音乐广播稿
2014/09/10 职场文书
七一建党节演讲稿
2014/09/11 职场文书
北京故宫的导游词
2015/01/31 职场文书
清明节扫墓活动总结
2015/02/09 职场文书
http通过StreamingHttpResponse完成连续的数据传输长链接方式
2022/02/12 Python
SQL Server数据库基本概念、组成、常用对象与约束
2022/03/20 SQL Server
Tomcat用户管理的优化配置详解
2022/03/31 Servers
MySQL 表锁定 LOCK和UNLOCK TABLES的 SQL语法
2022/04/18 MySQL