使用Vue,我有一些无线电输入:
<label>
<input
v-model="myProperty"
v-bind:value="true"
name="myProperty"
type="radio"
> True
</label>
<label>
<input
v-model="myProperty"
v-validate="input.rules ? input.rules : ''"
v-bind:value="false"
name="myProperty"
type="radio"
> False
</label>我正在用vue-test-utils和jest测试它们,在它们中,我选择并分配一个值给我的字段:
let myProperty = wrapper.find('[name="myProperty"]')
myProperty.setChecked(false)根据文档的说法,它应该是这样工作的。但我知道这个错误:
[vue-test-utils]: wrapper.setChecked() must be passed a boolean但是,当我将值设置为true而不是false时,它可以工作。作为一个实验,我尝试将值设置为字符串'false'。
myProperty.setChecked('false')然后我发现了一个错误:
[vue-test-utils]: wrapper.setChecked() must be passed a boolean那么,当值为vue-test-utils时,我应该如何选择在false中想要的无线电输入?如果我的无线电输入有用于值的字符串呢?
发布于 2018-11-27 19:07:19
您需要在组中的另一个无线电输入上调用setChecked。这将不检查组中的所有其他单选按钮,因为一次只能检查一个:
wrapper.find('[name="other property"]').setChecked(true)在Vue测试Utils中,我们不允许将单选按钮checked设置为false,因为这使您能够将一个无线电组置于一个没有被检查的状态,尽管作为一个用户这是不可能的。
也许我们应该重新考虑这个设计决定。如果您有用例,请在Vue Test repo中创建一个特性请求。
https://stackoverflow.com/questions/53490280
复制相似问题