因此,当点击<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
答案 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;
}