Avatar头像

用来代表用户或事物,支持图片、图标或字符展示。

代码演示

Avatar头像 - 图1

基本

头像有三种尺寸,两种形状可选。

  1. import { Component } from '@angular/core';
  2. @Component({
  3. selector: 'nz-demo-avatar-basic',
  4. template: `
  5. <div>
  6. <nz-avatar [nzSize]="64" nzIcon="user"></nz-avatar>
  7. <nz-avatar nzSize="large" nzIcon="user"></nz-avatar>
  8. <nz-avatar nzIcon="user"></nz-avatar>
  9. <nz-avatar nzSize="small" nzIcon="user"></nz-avatar>
  10. </div>
  11. <div>
  12. <nz-avatar [nzShape]="'square'" [nzSize]="64" [nzIcon]="'user'"></nz-avatar>
  13. <nz-avatar [nzShape]="'square'" [nzSize]="'large'" [nzIcon]="'user'"></nz-avatar>
  14. <nz-avatar [nzShape]="'square'" [nzIcon]="'user'"></nz-avatar>
  15. <nz-avatar [nzShape]="'square'" [nzSize]="'small'" [nzIcon]="'user'"></nz-avatar>
  16. </div>
  17. `,
  18. styles: [
  19. `
  20. nz-avatar {
  21. margin-top: 16px;
  22. margin-right: 16px;
  23. }
  24. `
  25. ]
  26. })
  27. export class NzDemoAvatarBasicComponent {}

Avatar头像 - 图2

自动调整字符大小

对于字符型的头像,当字符串较长时,字体大小可以根据头像宽度自动调整。

  1. import { Component } from '@angular/core';
  2. const userList = ['U', 'Lucy', 'Tom', 'Edward'];
  3. const colorList = ['#f56a00', '#7265e6', '#ffbf00', '#00a2ae'];
  4. @Component({
  5. selector: 'nz-demo-avatar-dynamic',
  6. template: `
  7. <nz-avatar
  8. [nzText]="text"
  9. nzSize="large"
  10. [ngStyle]="{ 'background-color': color }"
  11. style="vertical-align: middle;"
  12. ></nz-avatar>
  13. <button nz-button [nzType]="'dashed'" (click)="change()" style="margin-left: 16px; vertical-align: middle;">
  14. <span>Change</span>
  15. </button>
  16. `,
  17. styles: []
  18. })
  19. export class NzDemoAvatarDynamicComponent {
  20. text: string = userList[3];
  21. color: string = colorList[3];
  22. change(): void {
  23. let idx = userList.indexOf(this.text);
  24. ++idx;
  25. if (idx === userList.length) idx = 0;
  26. this.text = userList[idx];
  27. this.color = colorList[idx];
  28. }
  29. }

Avatar头像 - 图3

类型

支持三种类型:图片、Icon 以及字符,其中 Icon 和字符型可以自定义图标颜色及背景色。

  1. import { Component } from '@angular/core';
  2. @Component({
  3. selector: 'nz-demo-avatar-type',
  4. template: `
  5. <nz-avatar nzIcon="user"></nz-avatar>
  6. <nz-avatar nzText="U"></nz-avatar>
  7. <nz-avatar nzText="USER"></nz-avatar>
  8. <nz-avatar nzIcon="user" nzSrc="//zos.alipayobjects.com/rmsportal/ODTLcjxAfvqbxHnVXCYX.png"></nz-avatar>
  9. <nz-avatar nzText="U" style="color:#f56a00; background-color:#fde3cf;"></nz-avatar>
  10. <nz-avatar nzIcon="user" style="background-color:#87d068;"></nz-avatar>
  11. `,
  12. styles: [
  13. `
  14. nz-avatar {
  15. margin-top: 16px;
  16. margin-right: 16px;
  17. }
  18. `
  19. ]
  20. })
  21. export class NzDemoAvatarTypeComponent {}

Avatar头像 - 图4

带徽标的头像

通常用于消息提示。

  1. import { Component } from '@angular/core';
  2. @Component({
  3. selector: 'nz-demo-avatar-badge',
  4. template: `
  5. <nz-badge [nzCount]="5" style="margin-right: 24px;">
  6. <nz-avatar nzIcon="user" [nzShape]="'square'"></nz-avatar>
  7. </nz-badge>
  8. <nz-badge nzDot>
  9. <nz-avatar nzIcon="user" [nzShape]="'square'"></nz-avatar>
  10. </nz-badge>
  11. `
  12. })
  13. export class NzDemoAvatarBadgeComponent {}

API

单独引入此组件

想要了解更多关于单独引入组件的内容,可以在快速上手页面进行查看。

  1. import { NzAvatarModule } from 'ng-zorro-antd';

nz-avatarcomponent

参数说明类型默认值
[nzIcon]设置头像的图标类型,参考 Iconstring-
[nzShape]指定头像的形状'circle'|'square''circle'
[nzSize]设置头像的大小'large'|'small'|'default'|number'default'
[nzSrc]图片类头像的资源地址string-
[nzText]文本类头像string-