vue中根据用户昵称首字母生成头像和颜色

需求:项目中需要做一个粗糙的评论板块,用户评论时需要显示头像,但是不需要去更换改头像
思路:用户昵称首字母作为头像,并且根据用户首字母生成固定的颜色,否则每次颜色都会随机
例如:
在这里插入图片描述
方法一
1.安装头像插件

npm install vue-avatar

2.引用

//template部分
<Avatar :username="name" :src="name" :background-color="extractColorByName(name)" color="#fff" style="vertical-align: middle;" :inline="true" />

//script部分
import Avatar from 'vue-avatar'

export default {
  ...
  data() {
    return {
    	name:'张三'
     }
  },
  components: {
    Avatar
  },
  ...
  methods(){
  //传入名字,根据名字生成颜色,这样颜色就固定下来了
	extractColorByName(name) {
	      var temp = [];
	      temp.push("#");
	      for (let index = 0; index < name.length; index++) {
	        temp.push(parseInt(name[index].charCodeAt(0), 10).toString(16));
	      }
	      return temp.slice(0, 5).join('').slice(0, 4);
	    },
	}
}

方法二

直接使用elementUI的el-avatar也是不错的选择

<el-avatar :style="`background:${extractColorByName('管理员')}`"> 管理员 </el-avatar>

可以自己定义这个头像框的大小,如果小了,昵称会显示不全,所以如果想只显示首字母汉字,建议使用第一种,如果想显示全称,建议选择第二种.

在这里插入图片描述

参考博客☝

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值