vue之v-for中给每个item动态绑定class,动态添加元素,动态删除某个元素的实现

4 篇文章 0 订阅

主要解决了在v-for时,如何给每个item添加动态的样式,即是说,鼠标滑动到某一项时,可以单独改变某一项的样式,同时添加按钮等操作。以及删除某一项的操作。

<template>
  <div class="hello">
      <ul>
          <li   v-for="(item, itemIndex) in test" 
                :key="item.id" 
                :class="{defaultClass: itemIndex === isActive}"
                @mouseenter="onMouseEnter(itemIndex)" 
                @mouseleave="onMouseLeave">
              {{ itemIndex+1 }} :{{ item.title }}
              <button v-if="isActive === itemIndex" @click="deleteItem(itemIndex)">删除({{itemIndex+1}})</button>
          </li>
      </ul>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  data () {
    return {
      test: [
          {     
              id: 1,
              title: 'title first'
          },
          {
              id: 2,
              title: 'title second'
          },
          {
              id: 3,
              title: 'title third'
          }
      ],
      isActive: ''
    }
  },
  methods: {
      onMouseEnter(index) {
          this.isActive = index
      },
      onMouseLeave() {
          this.isActive = ''
      },
      deleteItem(index) {
          this.test.splice(index, 1)
      }
  },
  computed: {
      
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
h1, h2 {
  font-weight: normal;
}
ul {
  list-style-type: none;
  padding: 0;
}
li {
  /* display: inline-block; */
  margin:10px;
}
a {
  color: #42b983;
}
.defaultClass{
    background-color: red;
}
</style>

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue动态绑定v-model,有几种方法可以实现。其一种方法是使用一个数组来存储动态生成的input的值,并使用v-model绑定到数组的每个元素上。 首先,创建一个空的数组,比如selectVal: []。然后,使用v-model绑定到每个input上,如v-model="selectVal[index].value"。接下来,使用循环或其他方式动态生成需要绑定v-model的input的数量,比如使用for循环生成10个input。 示例代码如下: ``` data() { return { selectVal: [] // 创建一个空的数组 } }, mounted() { var len = 10; for (var i = 0; i < len; i++) { var item = { value: '' }; // 创建一个对象,用来存储input的值 this.selectVal.push(item); // 将对象添加到数组 } } ``` 在上述代码,通过循环生成了10个需要绑定v-model的input,将每个input的值存储在selectVal数组的对应元素的value属性。 通过这种方式,可以实现动态绑定v-model,并且根据接口返回的数据动态生成相应数量的input。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [在 vue.js 动态绑定 v-model](https://blog.csdn.net/qq_30944053/article/details/88634779)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue v-model动态生成详解](https://download.csdn.net/download/weixin_38696336/14904156)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值