vue props自定义函数validator

2020-11-26 08:47:53

用于接收来自父组件的数据(子组件期待获得的数据)

类型:字符串数组或者object

validator自定义函数

props: {// 基础的类型检查 (`null` 匹配任何类型)propA: Number,// 多个可能的类型propB: [String, Number],// 必填的字符串propC: {type: String,required: true},// 带有默认值的数字propD: {type: Number,default: 100},// 带有默认值的对象propE: {type: Object,// 对象或数组且一定会从一个工厂函数返回默认值default: function () {return { message: 'hello' }}},// 自定义验证函数propF: {type: String,validator: function (t) {// 这个值必须匹配下列字符串中的一个return t === 'fade' || t === 'slide'},defalut:'slide'}

 数组:props: ['size', 'myMessage']
对象
 props: {
    // 只检测类型
    height: Number,
    // 检测类型 + 其他验证
    age: {
      type: Number,
      default: 0,
      required: true,
      validator: function (value) {
        return value >= 0
      }

    }
  }

HTML 特性是不区分大小写的。所以,当使用的不是字符串模板,camelCased (驼峰式) 命名的 prop 需要转换为相对应的 kebab-case (短横线隔开式) 命名:

父组件:

  1. <!-- kebab-case in HTML -->

  2. <child my-message="hello!"></child>

子组件:

// camelCase in JavaScript

props: ['myMessage'],

#动态Prop

要动态地绑定父组件的数据到子模板的 props需要使用v-bind,这样每当父组件的数据变化时,该变化也会传导给子组件。

#字面量语法vs动态语法 

(字面量分为字符串字面量(string literal )、数组字面量(array literal)和对象字面量(object literal),另外还有函数字面量(function literal)。)

父组件:

<!-- 传递了一个字符串 "1" -->

<comp some-prop="1"></comp>

=右边是字符串”1”而不是number。如果想要传递一个number,需要使用v-bind,从而让它的值被当作js表达式计算

<!-- 传递实际的 number -->

<comp v-bind:some-prop="1"></comp>

Prop中的数据

.prop 作为初始值传入后,子组件想把它当作局部数据来用;定义一个局部变量,并用 prop 的值初始化它:

子组件:

props: ['initialCounter'],

data: function () {

return { counter: this.initialCounter }

}

 2.prop 作为初始值传入,由子组件处理成其它数据输出。
定义一个计算属性,处理 prop 的值并返回。

子组件:

props: ['size'],

computed: {

normalizedSize: function () {

return this.size.trim().toLowerCase()

}

}

注意在 JavaScript 中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态。

#prop验证

子组件:

props: {

// 基础类型检测 (`null` 意思是任何类型都可以)

propA: Number,

// 多种类型

propB: [String, Number],

// 必传且是字符串

propC: {

type: String,

required: true

},

// 数字,有默认值

propD: {

 type: Number,

 default: 100

},

// 数组/对象的默认值应当由一个工厂函数返回

propE: {

 type: Object,

 default: function () {

  return { message: 'hello' }

 }

},

// 自定义验证函数

propF: {

 validator: function (value) {

 return value > 10

 }

 }

}

注意 props 会在组件实例创建之前进行校验,所以在 default 或 validator 函数里,诸如 data、computed 或 methods 等实例属性还无法使用。

 

#非父子组件通信

有时候两个组件也需要通信 (非父子关系)。在简单的场景下,可以使用一个空的 Vue 实例作为中央事件总线:

 

var bus = new Vue()
// 触发组件 A 中的事件bus.$emit('id-selected', 1)// 在组件 B 创建的钩子中监听事件bus.$on('id-selected', function (id) {// ...})


  • 2017-01-19 00:45:56

    nodejs之process进程

    虽然node对操作系统做了很多抽象的工作,但是你还是可以直接和他交互,比如和系统中已经存在的进程进行交互,创建工作子进程。node是一个用于事件循环的线程,但是你可以在这个事件循环之外创建其他的进程(线程)参与工作。

  • 2017-01-19 01:05:32

    process对象

    process对象是Node的一个全局对象,提供当前Node进程的信息。它可以在脚本的任意位置使用,不必通过require命令加载。该对象部署了EventEmitter接口。

  • 2017-01-20 21:59:11

    WEBPACK DEV SERVER

    webpack-dev-server是一个小型的node.js Express服务器,它使用webpack-dev-middleware中间件来为通过webpack打包生成的资源文件提供Web服务。它还有一个通过Socket.IO连接着webpack-dev-server服务器的小型运行时程序。

  • 2017-01-21 10:32:29

    Vue-cli proxyTable 解决开发环境的跨域问题

    和后端联调时总是会面对恼人的跨域问题,最近基于Vue开发项目时也遇到了这个问题,两边各自想了一堆办法,查了一堆资料,加了一堆参数,最后还得我把自己的localhost映射成上线时将要使用的域名。

  • 2017-01-21 21:44:29

    详解 ESLint 规则,规范你的代码

    在很久之前就想通过工具来规范自己的代码风格,减少程序出错的概率,如果看过我的 一个前端程序猿的Sublime Text3的自我修养 ,这篇博客的朋友,肯定知道在当时我使用 SublimeLinter-jshint 插件来规范风格,但是实际上一直懒癌发作也没去看它的文档,使用着它默认的规则。不过现在是时候切换到 ESLint 了!