vue-标签选择

效果

选中后

代码

<span

:class="[item.beal==true?'p_yx_span span_active ':'span p_yx']"

@click="onTagSelect(index)"

v-for="(item,index) in tagList"

:key="index"

>{{item.name}}

</span>
// 列表值

tagList:[

{id: 1, name: 'tag 1',beal:false},

{id: 2, name: 'tag 2',beal:false},

{id: 3, name: 'tag 3',beal:false},

{id: 4, name: 'tag 4',beal:false},

{id: 5, name: 'tag 5',beal:false},

{id: 6, name: 'tag 6',beal:false}

],

// 选中值

tagChooseData:[],
// 标签选择

onTagSelect(e){

this.tagList[e].beal = !this.tagList[e].beal; //点击后改变状态

if (this.tagList[e].beal == true) {

this.tagChooseData.push(this.tagList[e].name); //如果点击后是true那么直接添加

} else {

//如果不是true的话说明这个标签已经存在了,那么就要查找然后删除

var index = this.tagChooseData.map(item => item).indexOf(this.tagList[e].name);

if (index != -1) {

this.tagChooseData.splice(index, 1);

}

}

}

样式

.span {

display: inline-block;

padding: 0 10px;

height: 20px;

line-height: 20px;

background: rgba(255, 255, 255, 1);

box-shadow: 0px 1px 4px 0px rgba(141, 141, 141, 0.3);

border-radius: 4px;

font-size: 12px;

font-family: Microsoft YaHei;

font-weight: 400;

color: rgba(34, 34, 34, 1);

margin-left: 10px;

cursor: pointer;

min-width: 44px;

text-align: center;

}

.span_active {

background: rgba(236, 173, 64, 1);

color: #fff;

}

.p_yx {

color: #222;

}

.p_yx_span {

display: inline-block;

padding: 0 10px;

height: 20px;

line-height: 20px;

background: rgb(76, 96, 193);

box-shadow: 0px 1px 4px 0px rgba(141, 141, 141, 0.3);

border-radius: 4px;

font-size: 12px;

font-family: Microsoft YaHei;

font-weight: 400;

color: rgba(34, 34, 34, 1);

margin-left: 10px;

cursor: pointer;

min-width: 44px;

text-align: center;

}

相关推荐
QQ1__8115175158 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态8 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子8 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室8 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI8 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing8 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者8 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册8 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李8 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢8 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web