详解如何为你的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 相关文章推荐
jQuery多级弹出菜单插件ZoneMenu
Dec 18 Javascript
js实现跨域的几种方法汇总(图片ping、JSONP和CORS)
Oct 25 Javascript
对Js OOP编程 创建对象的一些全面理解
Jul 26 Javascript
javascript表单正则应用
Feb 04 Javascript
详解vue2.0+vue-video-player实现hls播放全过程
Mar 02 Javascript
详解webpack-dev-server 设置反向代理解决跨域问题
Apr 18 Javascript
微信小程序实现发送模板消息功能示例【通过openid推送消息给用户】
May 05 Javascript
javascript异常处理实现原理详解
Feb 17 Javascript
使用 Jest 和 Supertest 进行接口端点测试实例详解
Apr 25 Javascript
js实现购物车商品数量加减
Sep 21 Javascript
js实现纯前端压缩图片
Nov 16 Javascript
Vue项目中如何封装axios(统一管理http请求)
May 02 Vue.js
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
如何选购合适的收音机
2021/03/01 无线电
PHP单例模式数据库连接类与页面静态化实现方法
2019/03/20 PHP
jQuery 联动日历实现代码
2012/05/31 Javascript
jQuery实现页面滚动时层智能浮动定位实例探讨
2013/03/29 Javascript
JS实现点击复选框将按钮或文本框变为灰色不可用的方法
2015/08/11 Javascript
jquery实现点击其他区域时隐藏下拉div和遮罩层的方法
2015/12/23 Javascript
纯JS代码实现气泡效果
2016/05/04 Javascript
修改Jquery Dialog 位置的实现方法
2016/08/26 Javascript
纯js实现倒计时功能
2017/01/06 Javascript
JavaScript中localStorage对象存储方式实例分析
2017/01/12 Javascript
node安装--linux下的快速安装教程
2017/03/21 Javascript
简述vue中的config配置
2018/01/23 Javascript
微信小程序实现YDUI的ScrollTab组件
2018/02/02 Javascript
实例解析Vue.js下载方式及基本概念
2018/05/11 Javascript
使用vue-router beforEach实现判断用户登录跳转路由筛选功能
2018/06/25 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
微信小程序:数据存储、传值、取值详解
2019/05/07 Javascript
JavaScript封闭函数及常用内置对象示例
2019/05/13 Javascript
python和pyqt实现360的CLable控件
2014/02/21 Python
rabbitmq(中间消息代理)在python中的使用详解
2017/12/14 Python
python matplotlib画图实例代码分享
2017/12/27 Python
python爬虫爬取某站上海租房图片
2018/02/04 Python
Django框架会话技术实例分析【Cookie与Session】
2019/05/24 Python
python GUI库图形界面开发之PyQt5布局控件QHBoxLayout详细使用方法与实例
2020/03/06 Python
Pytorch mask-rcnn 实现细节分享
2020/06/24 Python
css3实现文字扫光渐变动画效果的示例
2017/11/07 HTML / CSS
Java提供了哪些企业应用编程接口
2015/02/13 面试题
中文系学生自荐信范文
2013/11/13 职场文书
医护人员英文求职信范文
2013/11/26 职场文书
代理商会议邀请函
2014/01/27 职场文书
如何写股份合作协议书
2014/09/11 职场文书
2014年民主评议党员个人总结
2014/09/24 职场文书
2015年护士节慰问信
2015/03/23 职场文书
车间统计员岗位职责
2015/04/14 职场文书
python实现简单区块链结构
2021/04/25 Python
td 内容自动换行 table表格td设置宽度后文字太多自动换行
2022/12/24 HTML / CSS