Prop

  1. Prop验证

    Vue.component('my-component', {
    props: {
    // 基础的类型检查 (`null` 和 `undefined` 会通过任何类型验证)
    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 ['success', 'warning', 'danger'].indexOf(value) !== -1
    }
    }
    }
    })
    • prop 会在一个组件实例创建之前进行验证
  2. 非 Prop 的 Attribute

    • 如果一个父组件向其子组件传递一个属性,但是子组件没有使用props接收它,那么这个属性就会被添加到子组件的根元素上去,即:在子组件使用 this.$attrs 就能获取到传入的属性对应的值

    • <div id="app">
      <child-com :name='name' :age='age' :sex='sex'></child-com>
      </div> <script>
      const vm = new Vue({
      el: '#app', // 父组件
      data: {
      name: 'lyl',
      age: 20,
      sex: '男'
      },
      components: {
      childCom: { // 子组件
      template: `
      <div>
      <span> {{name}} </span>
      <grand-com v-bind='$attrs'></grand-com> <!-- 注意看这里,你会发现这里的 v-bind后面直接跟上的不是一个属性而是等号 -->
      <!-- 这样一来我们就把 子组件中没有用到的属性(除class和style以外)全部传到了孙子组件 -->
      </div>
      `,
      props: ['name'], // 这里没有将 age 和 sex 在 props 中接收
      created() {
      console.log(this.$attrs) // 控制台打印:{age:20,sex:男}
      },
      components: {
      grandCom: { // 孙子组件
      template: `
      <div>
      <span>{{$attrs.age}}</span>
      <span>{{$attrs.sex}}</span>
      </div>
      `,
      }
      }
      }
      }
      })
      </script>
    • inheritAttrs 属性的用法

    • <div id="app">
      <child-com :name='name' :age='age' :sex='sex'></child-com>
      </div> <script>
      const vm = new Vue({
      el: '#app', // 父组件
      data: {
      name: 'lyl',
      age: 20,
      sex: '男'
      },
      components: {
      childCom: { // 子组件
      template: `
      <div>
      <span> {{name}} </span>
      </div>
      `,
      props: ['name'], // 这里没有将 age 和 sex 在 props 中接收
      created() {
      console.log(this.$attrs) // 控制台打印:{age:20,sex:男}
      }
      }
      }
      })
      </script>
    • 你就会发现,这里的div标签上面被绑定了age、sex这样的属性,这就是官方文档说的非Prop的属性会被添加被绑定组件的根元素上 ,就如上图所示,但是往往你是不想这样做的,那么就可以使用 inheritAttrs 属性了

      用法:在子组件的模板对象中添加 inheritAttrs: false 即可让这种情况禁止掉

      <div id="app">
      <child-com :name='name' :age='age' :sex='sex'></child-com>
      </div> <script>
      const vm = new Vue({
      el: '#app', // 父组件
      data: {
      name: 'lyl',
      age: 20,
      sex: '男'
      },
      components: {
      childCom: { // 子组件
      inheritAttrs: false, // 父组件传入的name、age、sex属性中除子组件props接收的属性name外,其他属性默认会被浏览器渲染成html属性,但是设置该属性之后则不会被浏览器这样渲染
      template: `
      <div>
      <span> {{name}} </span>
      </div>
      `,
      props: ['name'], // 这里没有将 age 和 sex 在 props 中接收
      created() {
      console.log(this.$attrs) // 控制台打印:{age:20,sex:男}
      }
      }
      }
      })
      </script>

Prop验证、inheritAttrs、$attrs的用法和坑的更多相关文章

  1. cin.getline()的用法和坑

    cin.getline()的用法和坑 cin.getline大致原型:**istream& getline (char* s, streamsize n, char delim='\n');* ...

  2. VueJs组件prop验证简单理解

    今天看了vuejs的组件,看到了prop组件,主要作用是在传入数据的时候对传入的值做判断,写了个小例子. <div id="app"> <my-child :nu ...

  3. Vue组件传值prop验证方式

    在Vue组件开发过程中,父组件要经常给子组件传递数据,在传递数据的过程中,子组件可以使用prop来接收父组件传递的值,同时呢,我们可以为组件的 prop 指定验证要求,例如你知道的这些类型.如果有一个 ...

  4. 苹果IOS内购二次验证返回state为21002的坑

    项目是三四年前的老项目,之前有IOS内购二次验证的接口,貌似很久都没用了,然而最近IOS的妹子说接口用不了,让我看看啥问题.接口流程时很简单的,就是前端IOS在购买成功之后,接收到receipt后进行 ...

  5. 组件Prop验证

    <div id="example"> <kkk></kkk> </div> <script src="https:/ ...

  6. ajax传递数组给controller的实现方法和坑

    这里是前端向后端传递一个数组的方式,参考下面这个示例: (主要是将前端的数组,用 JSON.stringify() 方法json化一下,然后后端springmvc接收到以后,使用 JSONArray  ...

  7. python 一些特殊用法和坑

    https://github.com/leisurelicht/wtfpython-cn

  8. ASP.NET Core 模型验证的一个小小坑

    今天在我们的一个项目中遇到一个 asp.net core 模型验证(model validation)的小问题.当模型属性的类型是 bool ,而提交上来的该属性值是 null ,asp.net co ...

  9. vue3中$attrs的变化与inheritAttrs的使用

    在vue3中的$attrs的变化 $listeners已被删除合并到$attrs中. $attrs现在包括class和style属性. 也就是说在vue3中$listeners不存在了.vue2中$l ...

随机推荐

  1. H3C 多路径网络中环路产生过程(1)

  2. 将url传参的中文字符在页面中显示正常

    //将url传参的中文字符在页面中显示正常var url=decodeURI(url);

  3. 用webAudio和canvas实现音频可视化

    前两天遇到了要显示音频波形图的需求,因为时间紧,就直接用了wavesufer.js,这两天有空,就研究了一下怎么用webAudio实现音频的可视化. 大致流程是对音源进行解析,解析得到的数据是个频谱数 ...

  4. yum安装错误:CRITICAL:yum.cli:Config Error: Error accessing file for config file:///home/linux/+

    上网搜了一下然后自己总结一份 : 出现原因:yum可能没有,或者损坏 解决: 第一步:下载   wget  http://yum.baseurl.org/download/3.2/yum-3.2.28 ...

  5. Linux 内核硬件资源

    一个 ISA 设备可配备有 I/O 端口, 内存区, 和中断线. 尽管 x86 处理器支持 64 KB I/O 端口内存(即, 处理器有 16 条地址线), 一些老 PC 硬 件仅解码最低的 10 位 ...

  6. P3803 FFT求多项式系数

    P3803 FFT求多项式系数 传送门:https://www.luogu.org/problemnew/show/P3803 题意: 这是一道FFT模板题,求多项式系数 题解: 对a和b的系数求一个 ...

  7. Android Library的依赖方式及发布(转)

    还是那句老话,好记性不然烂笔头,在此整理 Android Studio 依赖相关 以及 如何发布项目到 JCenter Android Studio 添加依赖Module 依赖module 依赖是指在 ...

  8. VC++取MD5算法记录下以后用得到(转)

    这个是网上扒下来的 作者已经无法知道是谁了 MD5.h #ifndef MD5_H #define MD5_H #include <string> #include <fstream ...

  9. 通用高效的数据修复方法:Row level repair

    导读:随着大数据的进一步发展,NoSQL 数据库系统迅速发展并得到了广泛的应用.其中,Apache Cassandra 是最广泛使用的数据库之一.对于 Cassandra 的优化是大家研究的热点,而 ...

  10. 【一起学源码-微服务】Ribbon 源码一:Ribbon概念理解及Demo调试

    前言 前情回顾 前面文章已经梳理清楚了Eureka相关的概念及源码,接下来开始研究下Ribbon的实现原理. 我们都知道Ribbon在spring cloud中担当负载均衡的角色, 当两个Eureka ...