详解如何为你的angular app构建一个第三方库
Angular 团队 在 angular6 中,使得创建 Angular 第三方库变得更为简单。如果你以前尝试过操作,你会发现其实不是很简单!
那么流程是什么呢?
首页我们构建一个搭建一个简单的环境,环境里面包含一些组件和服务以及一些接口。
创建项目
1.按照官方教程,使用 ng new
命令初始化项目:
ng new lib-demo --prefix ld
在 angular-cli 第6个之后版本。配置文件的方式发生了相当大变化, angular.json
现在代表 angular 工作空间,
你可以可以使用 ng generate application [my-app-name]
命令添加更多项目
你也可以通过 ng generate 指令创建一个公共库。
ng generate library tvmaze --prefix tm
当然你可以使用简写命令
ng g lib tvmaze --prefix tm
具体参照
使用 generate
在我们 angular.json 中添加一个项目。
在库中创建一个服务
我们会发现tvmaze有它自己的 package.json
, tsconfig.json
, tslint.json
和 karma.conf.js
,这样建立是有原因的,因为这个项目独立与主应用建立而成,它本身也有组件、服务、模块。稍后我们添加其他的内容。现在我们添加一些逻辑:
这里说明下 provideIn: root
是 angular6 之后的新属性,详情见官网;如果是为了打包优化。
在库中创建一个组件
我们使用 angular-cli 来创建一个组件
# 使用--project 指定创建在那个工程中 ng generate component poster --project=tvmaze
然后这样编辑
将组件注册到 TvmazeModule
中,并且 exports 中是的外部能够访问,还得添加 CommonModule
, HttpClientModule
两个模块。
构建一下
在我们使用之前,我们先构建一下,我们 ng build
构建,指定项目。
ng build tvmaze
使用库
接下来,我们来使用刚刚构建好的库,一般我们采用第三方库都是使用 import
来导入。
我们会发现库不存在。因为这种方式,它是从 node_modules 寻找,所以我们要在根目录下 tsconfig.json
添加 paths
接下来我们在主项目中运用:使用 <tm-poster>
标签,即可完成
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Angular使用ng-messages与PHP进行表单数据验证
这篇文章主要介绍了Angular使用ng-messages与PHP进行表单数据验证,ng-messages提供了更方便的表单数据验证服务,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-12-12AngularJS之ionic 框架下实现 Localstorage本地存储
这篇文章主要介绍了AngularJS之ionic 框架下实现 Localstorage本地存储,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-04-04用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)
这篇文章主要介绍了用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-12-12AngularJS的ng Http Request与response格式转换方法
这篇文章主要介绍了AngularJS的ng Http Request与response格式转换方法,结合实例形式分析了AngularJS实现Request与response格式转换操作的相关设置与使用技巧,需要的朋友可以参考下2016-11-11
最新评论