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.tagListe.beal = !this.tagListe.beal; //点击后改变状态

if (this.tagListe.beal == true) {

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

} else {

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

var index = this.tagChooseData.map(item => item).indexOf(this.tagListe.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;

}

相关推荐
禅思院9 分钟前
大列表性能优化 · 工程实战·四
开发语言·前端·性能优化·前端框架·php·异步加载
rising start10 分钟前
五、Vue3 ref 用法 + Props 完整指南
前端·javascript·vue.js
web打印社区11 分钟前
前端html转换pdf并静默打印pdf最佳实现路径
前端·javascript·vue.js·electron·html
Curvatureflight20 分钟前
浏览器音频采集实践:麦克风权限、降噪、回声消除与 PCM 转换
前端·javascript·音视频·信息与通信·web·pcm
Dontla23 分钟前
HTML实体转义(HTML Entity Escaping)介绍
前端·html
咸鱼翻身小阿橙23 分钟前
高斯模糊降噪/磨皮算法降噪图像
前端·opencv·算法·webpack·c#
ct97825 分钟前
ES6 新特性
前端·vue.js·性能优化
KaMeidebaby32 分钟前
卡梅德生物技术快报|抗原如何自己检测?FAdV-4 重组抗原制备与 ELISA 体系技术调试指南
前端·人工智能·物联网·算法·百度
一拳不是超人35 分钟前
AI 辅助研发时代,如何用“规范 Skill”缩短测试周期
前端·人工智能·代码规范
夜郎king3 小时前
湖南高考天气查询:基于 HTML5 与百度天气 API 实现页面展示
前端·html5·百度天气实践·天气信息可视化