问题:Vue.js中一键禁用按钮

我正在使用 Vue.js 构建一个新的应用程序,并且遇到了我认为是一个简单的问题,但还没有找到解决方案。

我有一个问题,有三个答案。我只希望用户能够单击一次我知道可以使用@click.once的答案,但我需要让用户知道它在 UI 中不再可单击。我尝试过一些类似<button :disabled="submitted" @click="checkAnswer('q1','3'), submitted = true"></button>的方法,但这会同时禁用所有三个按钮。有人可以告诉我如何在用户单击按钮后禁用按钮并使其独立于其他按钮吗?我真的很感激任何帮助。

HTML:

<ul>
    <li><button class="btn blue" @click="checkAnswer('q1','1')">Answer 1 for q1</button></li>
    <li><button class="btn blue" @click="checkAnswer('q1','2')">Answer 2 for q1</button></li>
    <li><button class="btn blue" @click="checkAnswer('q1','3')">Answer 2 for q1</button></li>
</ul>

代码:

export default {
name: 'Questions',
props: ['clue'],
data(){
    return {
        feedback: null,
        answer: null,
        answers: {
            q1: '2',
            q2: '1',
            q3: '3'
        }
    }
},
 methods: {
    checkAnswer(q, a) {
        if(a == this.answers[q]){
            this.answer = "Congrats!"
        } else {
            this.answer = "Sorry that was the wrong answer."
        }
    }
}
}

解答

传递$event作为第三个参数,然后在处理程序中,event.target.disabled = true

这确实是一种快速而肮脏的方法,只要这是按钮的尽头,就可以了。更健壮的方法是为每个按钮制作一个组件,并为它是否被禁用有一个状态变量。

Logo

前往低代码交流专区

更多推荐