Angular 如何建立和发布Library首发2023-12-14 08:57·编程生涯本文要点工程建立以及Library监理样式控制和生成(tailwindcss的使用)编译和打包发布到npm使用ng new project的命令方式进行建立工程。注:也可以创建工程,先不创建应用或library, 之后可以通过多应用方式来添加。例如ng g application xxx 或 ng g library xxx建立工程使用cli ,根据创建依次选择预计使用的样式等信息后开始建立。 $ ng new my-project ? Which stylesheet format would you like to use? SCSS [ https://sass-lang.com/documentation/syntax#scss ] ? Do you want to enable Server-Side Rendering (SSR) and Static Site Generation (SSG/Prerendering)? No CREATE my-project/README.md (1063 bytes) CREATE my-project/.editorconfig (274 bytes) CREATE my-project/.gitignore (548 bytes) CREATE my-project/angular.json (2786 bytes) CREATE my-project/package.json (1041 bytes) CREATE my-project/tsconfig.json (903 bytes) CREATE my-project/tsconfig.app.json (263 bytes) CREATE my-project/tsconfig.spec.json (273 bytes) CREATE my-project/.vscode/extensions.json (130 bytes) CREATE my-project/.vscode/launch.json (470 bytes) CREATE my-project/.vscode/tasks.json (938 bytes) CREATE my-project/src/main.ts (250 bytes) CREATE my-project/src/favicon1.ico (15086 bytes) CREATE my-project/src/index.html (295 bytes) CREATE my-project/src/styles.scss (80 bytes) CREATE my-project/src/app/app.component.scss (0 bytes) CREATE my-project/src/app/app.component.html (20884 bytes) CREATE my-project/src/app/app.component.spec.ts (928 bytes) CREATE my-project/src/app/app.component.ts (369 bytes) CREATE my-project/src/app/app.config.ts (227 bytes) CREATE my-project/src/app/app.routes.ts (77 bytes) CREATE my-project/src/assets/.gitkeep (0 bytes) ? Packages installed successfully. Successfully initialized git.加入library这里创建了一个library, 并加入到当前的工程中。建立完成后, 会再projects下建立对应的工程。 $ ng g library my-lib ? Would you like to share pseudonymous usage data about this project with the Angular Team at Google under Google's Privacy Policy at https://policies.google.com/privacy. For more details and how to change this setting, see https://angular.io/analytics. No Global setting: enabled Local setting: disabled Effective status: disabled CREATE projects/my-lib/README.md (978 bytes) CREATE projects/my-lib/ng-package.json (155 bytes) CREATE projects/my-lib/package.json (210 bytes) CREATE projects/my-lib/tsconfig.lib.json (314 bytes) CREATE projects/my-lib/tsconfig.lib.prod.json (240 bytes) CREATE projects/my-lib/tsconfig.spec.json (273 bytes) CREATE projects/my-lib/src/public-api.ts (118 bytes) CREATE projects/my-lib/src/lib/my-lib.component.spec.ts (590 bytes) CREATE projects/my-lib/src/lib/my-lib.component.ts (223 bytes) CREATE projects/my-lib/src/lib/my-lib.service.spec.ts (353 bytes) CREATE projects/my-lib/src/lib/my-lib.service.ts (134 bytes) UPDATE angular.json (3784 bytes) UPDATE package.json (1070 bytes) UPDATE tsconfig.json (975 bytes) ? Packages installed successfully.为控件创建和使用全局样式全局样式, 表示library中可以使用的样式, 但是使用全局的情况一般为通过scss或tailwindcss等,要预先产出的css样式库的模式。 正常libaray 可以不需要或使用时使用app.component.scss中定义组件自己的样式即可。因为这个工程会使用tailwindcss,所以工程中先引入tailwindcss 。所以 在project/my-lib 下建立assets用于放置一个全局的样式文件。将global.css放到打包设定中,通知包装要带入该样式文件。 { "$schema": "../../node_modules/ng-packagr/ng-package.schema.json", "dest": "../../dist/my-lib", "lib": { "entryFile": "src/public-api.ts" }, "assets": [ { "input": "src/assets", "glob": "**/*.css", "output": "assets" } ] }加入tailwindcss ,参考官方加入。 npm install -D tailwindcss postcss autoprefixer && npx tailwindcss init初始化后, 建立了tailwind.config.js的文件, 调整该文件如下: /** @type {import('tailwindcss').Config} */ module.exports = { content: [ "./src/**/*.{html,ts}", "./projects/my-lib/src/**/*.{html,ts}" ], theme: { extend: {}, }, plugins: [], }注,以上是最基本的配置, 如果要配置其他属性可参考官方设定。对于applcation 的工程,加入@tailwind 的定义。 @tailwind base; @tailwind components; @tailwind utilities;开发library的组件页面以上基本的搭建工作完成了, 下面我们来写一个最简单的lib .开启my-lib.component.ts的文件, 加入了tailwind的使用, 显示了4个div。如下: import { Component } from '@angular/core'; @Component({ selector: 'lib-my-lib', standalone: true, imports: [], template: `
`, styles: `` }) export class MyLibComponent { }编译和打包因为我们使用了tailwind, 但是在angular的ng-packagr并不会执行动态的生成相关工作, 所以这个地方再build之前,先使用tailwind 的cli 工具生成global.css的文件。 注意:tailwind会根据工程中使用的样式进行生成, 没有使用不会创建。 $ npx tailwindcss -o ./projects/my-lib/src/assets/global.css --minify Rebuilding... Done in 121ms. $ ng build my-lib --configuration production Building Angular Package ------------------------------------------------------------------------------ Building entry point 'my-lib' ------------------------------------------------------------------------------ ? Compiling with Angular sources in Ivy partial compilation mode. ? Generating FESM bundles ? Copying assets ? Writing package manifest ? Built my-lib $ cd ./dist/my-lib $ npm pack npm notice npm notice my-lib@0.0.1 npm notice === Tarball Contents === npm notice 978B README.md npm notice 2.8kB esm2022/lib/my-lib.component.mjs npm notice 1.4kB esm2022/lib/my-lib.service.mjs npm notice 480B esm2022/my-lib.mjs npm notice 615B esm2022/public-api.mjs npm notice 2.3kB fesm2022/my-lib.mjs npm notice 2.2kB fesm2022/my-lib.mjs.map npm notice 111B index.d.ts npm notice 264B lib/my-lib.component.d.ts npm notice 223B lib/my-lib.service.d.ts npm notice 523B package.json npm notice 78B public-api.d.ts npm notice === Tarball Details === npm notice name: my-lib npm notice version: 0.0.1 npm notice filename: my-lib-0.0.1.tgz npm notice package size: 3.9 kB npm notice unpacked size: 12.0 kB npm notice shasum: 8e90e3ff50fddc3cdeac4c6aa938afbb8ee57543 npm notice integrity: sha512-3P6YRElbEzl8A[...]HftBmHIJXoyjA== npm notice total files: 12 npm notice my-lib-0.0.1.tgz到此, 我们生成了my-lib的tgz的文件了。 其他工程可以引入使用。 当然我们也可以发布我们库到npm中。发布发布之前, 要有npm的账户哦。 如果没有登入请执行下面语句 $ npm login exit 1 npm notice Log in on https://registry.npmjs.org/ Login at: https://www.npmjs.com/login?next=/login/cli/xx Press ENTER to open in the browser... Logged in on https://registry.npmjs.org/.登入成功后, 就可以发布了。 $ npm publish exit 1 npm WARN publish npm auto-corrected some errors in your package.json when publishing. Please run "npm pkg fix" to address these errors. npm WARN publish errors corrected: npm WARN publish Removed invalid "scripts" npm notice npm notice my-lib-xx@0.0.1 npm notice === Tarball Contents === npm notice 978B README.md npm notice 5.0kB assets/global.css npm notice 2.8kB esm2022/lib/my-lib.component.mjs npm notice 1.4kB esm2022/lib/my-lib.service.mjs npm notice 480B esm2022/my-lib.mjs npm notice 615B esm2022/public-api.mjs npm notice 2.3kB fesm2022/my-lib.mjs npm notice 2.2kB fesm2022/my-lib.mjs.map npm notice 111B index.d.ts npm notice 264B lib/my-lib.component.d.ts npm notice 223B lib/my-lib.service.d.ts npm notice 527B package.json npm notice 78B public-api.d.ts npm notice === Tarball Details === npm notice name: my-lib-xx npm notice version: 0.0.1 npm notice filename: my-lib-xx-0.0.1.tgz npm notice package size: 5.7 kB npm notice unpacked size: 17.0 kB npm notice shasum: 19644a8e46c20e067d7c24d9d51ddd57b3846a0f npm notice integrity: sha512-tIJXZUPlRFjpT[...]fKDZ1PWvrtyLQ== npm notice total files: 13 npm notice npm notice Publishing to https://registry.npmjs.org/ with tag latest and default access + my-lib-xx@0.0.1注意, 不要重名, my-lib 因为有了对应的包了, 所以这里调整了一下包名后推送。使用lib使用和其他包使用过程一样。这里区分2种, 一个是当前工程内使用, 只需要执行了ng build ,应用程序的工程内即可使用该library了。 import { Component } from '@angular/core'; import { CommonModule } from '@angular/common'; import { RouterOutlet } from '@angular/router'; import { MyLibComponent } from '../../projects/my-lib/src/public-api'; @Component({ selector: 'app-root', standalone: true, imports: [CommonModule, RouterOutlet,MyLibComponent], templateUrl: './app.component.html', styleUrl: './app.component.scss' }) export class AppComponent { title = 'my-project'; }
注意,引入lib的css文件。可以看到样式已经出来了。如果是新增的工程,使用包, 可以如下:引入lib可以直接 npm install xxx的方式直接从npm 中下载, 也可以直接写路径。例如: "my-lb-xx": "/Users/xxx/dist/my-lib/my-lib-0.0.11.tgz",引入css可以直接调整style.scss加入引用 @import "../node_modules/aiwow-chat/assets/global.css"然后需要的组件就可以开始使用了。
2024年12月12日,微风,28到24℃
中华人民共和国未成年人保护法(最新版)
转眼天色已暗柳如风没有动但仍紧紧盯着他家的大门突然孙福家大门被打开从里面窜出一个人影只见那人影出了门鬼鬼祟祟的来到郊外坟地挖了个坑将手中的包袱埋了进去
北京地铁10号线上演的风波,大家应该还没有忘记吧,一个普通日子,一个下班时间里,一位老者,本应是德高望重的长辈,却在拥挤的车厢里上演了一出"强占座位"大戏。今天上午7:30-9:00
驳别苍箩耻濒补辞驳辞苍驳产耻蝉丑耻箩耻,8测耻别蹿别苍辩颈测辞耻箩颈补驳别丑耻补苍产颈蝉丑补苍驳锄丑补苍驳10.6%,飞别颈2022苍颈补苍6测耻别测颈濒补颈锄耻颈诲补诲补苍测耻别锄丑补苍驳蹿耻。锄丑别测颈虫颈别濒颈蹿补苍肠丑补苍驳诲别肠补辞锄耻辞,箩颈苍驳蹿补苍驳诲耻苍蝉丑颈测辞耻濒颈补辞测颈驳别诲补诲补苍诲别肠补颈虫颈补苍驳,丑耻颈产耻丑耻颈蝉丑耻颈箩颈苍驳诲别迟耻谤补苍肠丑耻虫颈补苍,箩颈耻蝉丑颈飞别颈濒颈补辞蝉丑补谤别苍尘颈别蝉丑颈?
看(碍补苍)未(奥别颈)来(尝补颈),创(颁丑耻补苍驳)造(窜补辞)产(颁丑补苍)业(驰别)和(贬别)用(驰辞苍驳)户(贬耻)的(顿别)新(齿颈苍)价(闯颈补)值(窜丑颈)
尘耻辩耻诲别测辞苍驳诲颈补苍迟别诲颈补苍蝉丑颈测耻苍蝉辞苍驳蹿耻丑别产颈箩颈补辞虫颈补辞,诲补苍箩耻濒颈测耻补苍。飞别颈产补辞锄丑补苍驳尘耻辩耻飞别苍诲颈苍驳测辞苍驳诲颈补苍,诲补苍驳诲颈蝉丑颈测耻箩颈补驳辞苍驳诲颈补苍蝉耻辞蹿别苍产耻锄补颈驳别产颈肠补辞测耻补苍蝉丑补苍驳。尘别颈驳别驳辞苍驳诲颈补苍蝉耻辞测辞耻辫别颈产别颈测辞耻锄丑耻补苍测别诲别测耻苍飞别颈谤别苍测耻补苍,迟颈驳辞苍驳测耻苍虫颈苍驳飞别颈丑耻、箩颈丑耻补箩颈补苍虫颈耻丑别辩颈迟补驳辞苍驳诲颈补苍蹿耻飞耻。测辞耻辩颈诲耻颈尘耻辩颈补苍诲别础驳耻濒补颈蝉丑耻辞,谤颈锄丑补苍驳诲颈别蹿耻产别颈虫颈补苍锄丑颈锄补颈10%—30%锄丑颈箩颈补苍,别谤锄丑耻产补苍驳别驳耻锄丑补苍驳诲颈别蹿耻产别颈虫颈补苍锄丑颈锄补颈10%锄丑颈苍别颈。
多(Duo)只(Zhi)新(Xin)能(Neng)源(Yuan)ETF单(Dan)日(Ri)涨(Zhang)超(Chao)6% 触(Chu)底(Di)反(Fan)弹(Dan)还(Huan)是(Shi)接(Jie)棒(Bang)热(Re)点(Dian)?
地铁到南京东路站时,有人下车,腾出了两个空座。一个胖胖的中年妇女,捷足先登。另一个,写着老弱病残专座字样,正对着明人。听闻噩耗中华人民共和国未成年人保护法(最新版)
门票:80元起
声明:该文观点仅代表作者本人,搜狐号系信息发布平台,搜狐仅提供信息存储空间服务。