2017-01-10 148 views
2

我是VueJS的新手,所以我一直在关注他们的official guideVueJS Custom Props验证功能

我能够触发前5个属性验证器,但我似乎无法触发最后一个示例(自定义验证功能)。

我的JS文件:

Vue.component('propValidation', { 
    props: { 
     // basic type check (`null` means accept any type) 
     propA: Number, 
     // multiple possible types 
     propB: String, 
     // a required string 
     propC: { 
      type: String, 
      required: true 
     }, 
     // a number with default value 
     propD: { 
      type: Number, 
      default: 100 
     }, 
     // object/array defaults should be returned from a 
     // factory function 
     propE: { 
      type: Object, 
      default: function() { 
       return { message: 'hello' } 
      } 
     }, 
     // custom validator function 
     propF: { 
      type: Number, 
      validator: function (value) { 
       console.log("inside validator: " + value); 
       return value > 10; 
      } 
     } 
    }, 
    template:"<div>" + 
    "<p>PropA (Number): {{propA}}</p>" + 
    "<p>PropB ([String, Number]): {{propB}}</p>" + 
    "<p>PropC (Require String): {{propC}}</p>" + 
    "<p>PropD (Default Number): {{propD}}</p>" + 
    "<p>PropE (Default Object/Array): {{propE}}</p>" + 
    "<p>PropF (Custom Validator): {{propF.validator()}}</p>" + 
    "</div>" 
}); 

new Vue({ 
    el:"#example" 
}); 

和HTML文件:

<div id="example"> 
    <prop-validation :prop-a="200" prop-b="string" prop-c="Require String" :prop-e="{not:'wee'}" :prop-f="5"></prop-validation> 
</div> 

最后结果:

PropA (Number): 200 
PropB ([String, Number]): string 
PropC (Require String): Require String 
PropD (Default Number): 100 
PropE (Default Object/Array): { "not": "wee" } 
PropF (Custom Validator): 

与警告:

[Vue warn]: Invalid prop: custom validator check failed for prop "propF". (found in component <propValidation>)

在此先感谢

编辑:现在,我想想,难道它想返回“真”作为输出还是只是给予警告,这是不正确的? 我可能一直在寻找这种不同的方式,期望返回值是真/假。

回答

2

根据该文档:

这是可能的成分以指定它正在接收的道具的要求。如果不满足要求,Vue将发出警告。当您创作一个打算供其他人使用的组件时,这特别有用。

他们在这里说的是,应该始终满足您指定的验证器,以便该属性正常工作。如果没有,他们会发出警告,就像你正在经历的那样。

当你这样定义的验证,你说这个特定的验证所有输入应大于10

  validator: function (value) { 
      console.log("inside validator: " + value); 
      return value > 10; 

然后在绑定的数量为5值这个特定的属性,验证器返回false并发出警告。

1

你可能想签vue-properties

import {biggerThan} from 'vue-properties'; 

export default { 
    props: { 
     canDrink: { 
      type: Integer, 
      validator: biggerThan(18) 
     }, 
    } 
}