这篇文章将为大家详细讲解有关怎么在Angular中部署一个多模块项目,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
创建一个 Angular
项目,其名为 angular-project
,不创建 Application
,不进行交互,跳过依赖的安装。
ng new angular-project --createApplication=false --interactive=false --skipInstall=true
生成库 common
,生成应用 sso
,跳过依赖的安装。
ng g library common --skipInstall=true ng g application sso --style=scss --routing=true --skipInstall=true
安装依赖:
npm install --registry=https://registry.npm.taobao.org
项目结构
最终的项目结构长这样,所有模块位于 projects
目录下。
Angular Library
的结构如下,就像平常用的一样,也有 Module
, Module
中包含组件、服务等等。
同时我们开始反思之前用过的 ShareModule
,其实我们应该将其做成一个 Angular Library
,并将其发布到 npm
仓库,这样在多个项目之间快速移植公共模块也更高效快捷。
但是在开发过程中,共享模块可能有所改动,频繁发布就有些麻烦,如何直接引用本地的模块呢?
构建 common
库:
ng build common
如果该库频繁改动的话,可以添加监听参数,文件修改后自动构建:
ng build common --watch
命令执行后会在 dist
目录生成构建成功的 common
库。
使用起来就像我们使用的其他 Angular
库一样,直接 import
, WebStorm
会自动提示。
import { CommonModule } from 'common';
测试
在业务模块中引入 CommonModule
。
import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppRoutingModule } from './app-routing.module'; import { AppComponent } from './app.component'; import { CommonModule } from 'common'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, AppRoutingModule, CommonModule ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }
在 AppComponent
组件中使用 CommonModule
中的 CommonComponent
。
<h2>App Component HTML</h2> <lib-common></lib-common>
注:库组件生成的默认前缀是 lib
。
进入业务组件进行 ng serve
,成功。
关于怎么在Angular中部署一个多模块项目就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。