Vue.js在特定元素上添加类

时间:2018-02-08 15:43:47

标签: laravel vue.js

因此,当点击<li>时,我想创建一个基本任务列表,我想完成它们。单击它时,我希望将一个类添加到单击的<li>。我无法用文档解决这个问题,所以我希望有人可以帮助我:D

我已经拥有的代码:

        <transition-group name="list">
            <li  class="list-item list-group-item"  v-for="(task, index) in list" :key="task.id" v-on:click="finishTask(task.id)" >
                @{{ task.text }}
                <button @click="removeTask(task.id)" class="btn btn-danger btn-xs pull-right">Delete</button>
            </li>
        </transition-group>



    </ul>

</div>

    // get the csrf token from the meta
var csrf_token = $('meta[name="csrf-token"]').attr('content');

export default {
    data() {
        return {
            list: [],
            taskInput: {
                id: '',
                text: ''
            }
        };
    },

    // So the tasks will show when the page is loaded
    created() {
        this.allTasks();
    },

    methods: {
        // get all the existing tasks
        allTasks() {
            axios.get('tasks').then((response) => {
                this.list = response.data;
            });
        },
        // create a new task
        createTask() {
            axios({
                method: 'post',
                url: '/tasks',
                data: {
                    _token: csrf_token,
                    text: this.taskInput.text,
                },
            }).then(response => {
                this.taskInput.text = '';
                this.allTasks();
            });
        },
        // remove the tasks
        removeTask(id) {
            axios.get('tasks/' + id).then((response) => {
                this.allTasks();
            });
        },
        finishTask(id) {
            axios({
                method: 'post',
                url: 'tasks/done/' + id,
                data: {
                    _token: csrf_token,
                    data: this.taskInput,
                },
            }).then(response => {
                this.allTasks();
            });
        }
    }
}

我知道我应该如何使用jquery而不是vue js,我希望这不是一个愚蠢的问题:D

2 个答案:

答案 0 :(得分:2)

您可以使用事件参数。您的点击方法会自动提供。

onListClicked(event) {
  event.target.className += " myClass";
}

我在这里为您做了一个演示:https://jsfiddle.net/6wpbp70g/

答案 1 :(得分:2)

您可以bind css classes and styles向默认值done的注释对象添加布尔false属性,当您点击注释时将其done属性更改为{{ 1}}。这是一个例子

true
new Vue({
	el:"#app",
  data:{
  	notes: [ 
    		{ text: "First note", done:false  }, 
        { text: "Second note", done:false  }, 
        { text: "Third note", done:false  }, 
        { text: "Fourth note", done:false  }, 
        { text: "Fifth note", done:false  } 
      ]
  },
  methods:{
  	finishNote(note){
    	// send your api request
      // then update your note
      note.done = true
    }
  }
})
.done{
  background-color:green;
}