main.vue 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <script>
  2. export default {
  3. name: 'ElAvatar',
  4. props: {
  5. size: {
  6. type: [Number, String],
  7. validator(val) {
  8. if (typeof val === 'string') {
  9. return ['large', 'medium', 'small'].includes(val);
  10. }
  11. return typeof val === 'number';
  12. }
  13. },
  14. shape: {
  15. type: String,
  16. default: 'circle',
  17. validator(val) {
  18. return ['circle', 'square'].includes(val);
  19. }
  20. },
  21. icon: String,
  22. src: String,
  23. alt: String,
  24. srcSet: String,
  25. error: Function,
  26. fit: {
  27. type: String,
  28. default: 'cover'
  29. }
  30. },
  31. data() {
  32. return {
  33. isImageExist: true
  34. };
  35. },
  36. computed: {
  37. avatarClass() {
  38. const { size, icon, shape } = this;
  39. let classList = ['el-avatar'];
  40. if (size && typeof size === 'string') {
  41. classList.push(`el-avatar--${size}`);
  42. }
  43. if (icon) {
  44. classList.push('el-avatar--icon');
  45. }
  46. if (shape) {
  47. classList.push(`el-avatar--${shape}`);
  48. }
  49. return classList.join(' ');
  50. }
  51. },
  52. methods: {
  53. handleError() {
  54. const { error } = this;
  55. const errorFlag = error ? error() : undefined;
  56. if (errorFlag !== false) {
  57. this.isImageExist = false;
  58. }
  59. },
  60. renderAvatar() {
  61. const { icon, src, alt, isImageExist, srcSet, fit } = this;
  62. if (isImageExist && src) {
  63. return <img
  64. src={src}
  65. onError={this.handleError}
  66. alt={alt}
  67. srcSet={srcSet}
  68. style={{ 'object-fit': fit }}/>;
  69. }
  70. if (icon) {
  71. return (<i class={icon} />);
  72. }
  73. return this.$slots.default;
  74. }
  75. },
  76. render() {
  77. const { avatarClass, size } = this;
  78. const sizeStyle = typeof size === 'number' ? {
  79. height: `${size}px`,
  80. width: `${size}px`,
  81. lineHeight: `${size}px`
  82. } : {};
  83. return (
  84. <span class={ avatarClass } style={ sizeStyle }>
  85. {
  86. this.renderAvatar()
  87. }
  88. </span>
  89. );
  90. }
  91. };
  92. </script>