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

完整指南html

原文链接 vineo.cn/how-to-buil…node

Angular 团队 在 angular6 中,使得建立 Angular 第三方库变得更为简单。若是你之前尝试过操做,你会发现其实不是很简单!npm

那么流程是什么呢?json

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

建立项目

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

ng new lib-demo --prefix ld
复制代码

angular-cli 第6个以后版本。配置文件的方式发生了至关大变化,angular.json如今表明angular工做空间,ide

Imgur

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

你也能够经过 ng generate指令建立一个公共库。优化

ng generate library tvmaze --prefix tm
复制代码

固然你能够使用简写命令ui

ng g lib tvmaze --prefix tm
复制代码

具体参照

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

Imgur

在库中建立一个服务

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

Imgur

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

在库中建立一个组件

咱们使用angular-cli 来建立一个组件

# 使用--project 指定建立在那个工程中
ng generate component poster --project=tvmaze
复制代码

而后这样编辑

Imgur

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

Imgur

构建一下

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

ng build tvmaze
复制代码

使用库

接下来,咱们来使用刚刚构建好的库,通常咱们采用第三方库都是使用import来导入。

Imgur

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

Imgur

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

Imgur

发布到npm中去

咱们直接使用如下命令:前提是你注册npm帐号

ng build tvmaze
cd dist / tvmaze 
npm publish
复制代码
相关文章
相关标签/搜索