3

我正在使用淘汰赛并希望用户在 html 选择标记中选择一项。默认选择空值

<select required>
            <option value="">--Select something</option>
            <option value="True">True</option>
            <option value="False">False</option>

并且 viewModel 包含:

self.sampleBooleanValue.extend({required : true});

我希望以下绑定会有所帮助

<select data-bind="value: sampleBooleanValue" required>

 ....
</select>

验证有效,但未将 css 类添加到选择标记。谁能告诉为什么这不起作用?PS 它适用于另一个输入标签。

4

1 回答 1

5

我在一个没有应用错误类的更复杂的模型上遇到了同样的情况,在这种情况下,我创建了一个 selectedItemNotCaption 验证器,并且在没有应用的地方工作required: true(我相信这可能与我的标记上的错误有关 -我没有关闭 ,但这确实让我可以进一步调查)。

试试下面的自定义验证器,这里有小提琴

model = function () {
var self = this;
self.optionsAvailable = ['one', 'two'];

self.selectedOptionWithRequired = ko.observable().extend({
    required: true
});

self.selectedOption = ko.observable().extend({
    selectedItemNotCaption: true
});

self.submit = function () {
    console.log("checking for errors...");
    self.errors.showAllMessages();
};

self.errors = ko.validation.group(self);
};

ko.validation.configure({
insertMessages: false,
decorateElement: true,
errorElementClass: 'error'
});

ko.validation.rules['selectedItemNotCaption'] = {
validator: function (val) {
    console.log("in validator..." + val);
    return (typeof val != "undefined");
},
message: 'Please select an option'
};

ko.validation.registerExtenders();

ko.applyBindings(new model());
于 2013-07-26T08:30:08.517 回答