淘汰赛自定义验证:如何检查 observable 是不是等于特定值?

Posted

技术标签:

【中文标题】淘汰赛自定义验证:如何检查 observable 是不是等于特定值?【英文标题】:Knockout custom validation: How to check if observable is equal to a specific value?淘汰赛自定义验证:如何检查 observable 是否等于特定值? 【发布时间】:2019-07-05 12:18:06 【问题描述】:

我是 Knockout.js 的新手,我想检查我的表单字段是否具有特定值。实际上,我只检查它是否需要。我该怎么办?

这是我的 html 页面中的内容:

 <div data-bind="visible: !Vm.isValid()" class="text-danger">Fill each field to send data, otherwise show this message</div>

 <input data-bind="enable: Vm.isValid()" type="button" value="Send data!" />

这就是我的 vm.js 文件的样子:

 window.Vm = ko.validatedObservable(
     name : ko.observable().extend( required: true )
 );            

我会做这样的东西,但我不知道怎么做:

 var found = "found";
 window.Vm = ko.validatedObservable(
    name: ko.observable().extend(
       required: true,
       function: 
          if (this.val() == found)
             return true; // invalid value, can't submit my form
       
    )
 );

【问题讨论】:

【参考方案1】:

您可以像这样使用自定义validator (Documentation):

var found = "found";

var Vm = ko.validatedObservable(
  name: ko.observable().extend(
    required: 
      message: "This is a required field",
    ,
    validation: 
      validator: (val, paramValue) => 
        // "val" has the value entered in the field
        // "paramValue" has the value set in "params"
        return val === paramValue
      ,
      message: "The value is not " + found,
      params: found
    
  )
);

ko.applyBindings(Vm)
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout-validation/2.0.3/knockout.validation.min.js"></script>

<input type="text" data-bind="value: name" />

【讨论】:

【参考方案2】:

我实际上建议不要使用 Knockout Validation 库,因为它已经多年没有维护了。对于一个不再存在的问题,这是一个过时的解决方案。在 2019 年,您可以只使用每个现代浏览器原生的表单验证。只需在表单字段中添加required 属性,如果未填写所有必填字段,表单将不会提交。

如果你想让它更有活力,你可以这样做:

function ViewModel() 
    var vm = this;

    vm.name = ko.observable();
    vm.required = ['name', 'email'];

    vm.isRequired = isRequired;

    function isRequired(field) 
        return vm.required.indexOf(field) > -1;
    

并使用attr 绑定根据视图模型中所需元素的数组设置required 属性。

<input type="text" data-bind="textInput: name, attr:  required: isRequired('name') ">

【讨论】:

【参考方案3】:

我取数据为["A","B"],根据相同的数据进行搜索。

ko.extenders.required = function(target, overrideMessage) 
    //add some sub-observables to our observable
    target.hasError = ko.observable();
    target.validationMessage = ko.observable();
    target.data = ko.observableArray(["A","B"]);
 		target.found = ko.observable();
    target.foundMessage = ko.observable();
    //define a function to do validation
    function validate(newValue) 
       target.hasError(newValue ? false : true);
       target.validationMessage(newValue ? "" : overrideMessage || "This field is required");
       target.found(target.data().find(function(element) return newValue==element;));
       target.found()?target.foundMessage("element has found"):target.foundMessage("element has not found");
    
 
    //initial validation
    validate(target());
 
    //validate whenever the value changes
    target.subscribe(validate);
 
    //return the original observable
    return target;
;
 
function AppViewModel(first) 
    this.firstName = ko.observable(first).extend( required: "" );

 
ko.applyBindings(new AppViewModel("C"));
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/2.3.0/knockout-min.js"></script>
<p data-bind="css:  error: firstName.hasError ">
    <input data-bind='value: firstName, valueUpdate: "afterkeydown"' />
    <span data-bind='visible: firstName.hasError, text: firstName.validationMessage'> </span>
    <span data-bind='visible: (!firstName.hasError()), text: firstName.foundMessage'> </span>
</p>

【讨论】:

以上是关于淘汰赛自定义验证:如何检查 observable 是不是等于特定值?的主要内容,如果未能解决你的问题,请参考以下文章

如何将淘汰赛验证附加到自定义绑定

淘汰赛验证异步验证器:这是一个错误还是我做错了啥?

跟踪淘汰赛js中输入值的变化

UI 不会通过从自定义绑定方法更新中更新 observable 来更新

带油门的淘汰赛验证

将 jquery 版本从 2.1 升级到 3 后,淘汰验证自定义规则不起作用