vue prop传值类型检验方式


Posted in Javascript onJuly 30, 2020

prop 传值检验规则

如果是 prop 是静态传值,则必须是 String 类型

如果是 prop 是动态传值,则可以验证任意类型

示例,如果必须要传一个Number,就必须使用 bind

//声明
Vue.component("blog-post", {
 props: {
  postTitle: {
   type: Number,
   default: 10000
  }
 },
 template: "<h3>{{ postTitle }}</h3>"
});
//在template中调用,静态传值,值必定是 String
<blog-post postTitle="54"></blog-post>
//在template中调用,动态传值,值可以是 String、Number、Boolen。。。
<blog-post :postTitle="54"></blog-post>

类型检查的 type 值,可以是下列原生构造函数中的一个:

String

Number

Boolean

Array

Object

Date

Function

Symbol

type 还可以是一个自定义的构造函数,并且通过 instanceof 来进行检查确认。

示例:

//例如,给定下列现成的构造函数:
function Person (firstName, lastName) {
 this.firstName = firstName
 this.lastName = lastName
}
//可以使用,检验是否为 Person 的实例
Vue.component('blog-post', {
 props: {
  author: Person
 }
})

补充知识:vue中prop验证、类型检查及注意事项

1、注意:null和undefined会通过任何类型检测

2、数组或对象类型需要提供默认值的话需要通过函数返回。详情看这里

props:{// 数组或对象的默认值需要通过函数返回
  authInfo:{
  type:Object,
        default(){
   return{
   name:'张三',
            sex:0
          }
        }
      },
      list:{
  type:Array,
        default(){
   return[
   1,2,3
          ]
        }
      }
    }

3、使用自定义函数验证

props:{
  address:{
  validator(value){
          return ['黑龙江','吉林','辽宁'].indexOf(value) !== -1
        }
      }
    }

4、非prop的特性:若一个属性传向一个组件,但是该组件并没有定义相应 prop。则该属性称为非prop特性。非prop特性会作用到组件的根元素上。

若非prop中含有组件跟元素定义的属性。则非prop中的值会覆盖组件定义的值(这种情况称作 非prop继承)。style和class例外,它们会发生合并。

详情看这里

不希望非prop继承该怎么办?

如果不希望非prop自动作用到组件的根元素上可以在vue的组件选项里添加 inheritAttrs选项(此选项无法影响class和style的绑定)。

inheritAttrs:false

inheritAttrs属性可以和$attrs配合可以是非prop作用到开发者想作用到的元素上。而不作用的根元素上。例:

<template>
  <div>
    <input type="text" v-bind="$attrs">  <!--将非prop绑定到此元素-->
  </div>
</template>
<script>
 export default {
 name: "sg-test",
    inheritAttrs:false,//禁止 非prop继承
 }
</script>

以上这篇vue prop传值类型检验方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 播放器 控制
Jan 22 Javascript
JS中获取数据库中的值的方法
Jul 14 Javascript
node.js使用nodemailer发送邮件实例
Mar 10 Javascript
Javascript基础知识(一)核心基础语法与事件模型
Sep 29 Javascript
用jquery模仿的a的title属性的例子
Oct 22 Javascript
js实现继承的5种方式
Dec 01 Javascript
jQuery操作基本控件方法实例分析
Dec 31 Javascript
深入浅析JavaScript中的作用域和上下文
Mar 26 Javascript
jQuery通过ajax快速批量提交表单数据
Oct 25 Javascript
js的OOP继承实现(必看篇)
Feb 18 Javascript
vue watch深度监听对象实现数据联动效果
Aug 16 Javascript
ant design 日期格式化的实现
Oct 27 Javascript
Vue(定时器)解决mounted不能获取到data中的数据问题
Jul 30 #Javascript
vue setInterval 定时器失效的解决方式
Jul 30 #Javascript
vue 解决setTimeOut和setInterval函数无效报错的问题
Jul 30 #Javascript
浅谈vue 组件中的setInterval方法和window的不同
Jul 30 #Javascript
详解JavaScript自定义函数
Jul 29 #Javascript
深入了解JavaScript词法作用域
Jul 29 #Javascript
vue监听dom大小改变案例
Jul 29 #Javascript
You might like
php小技巧 把数组的键和值交换形成了新的数组,查找值取得键
2011/06/02 PHP
php学习笔记 php中面向对象三大特性之一[封装性]的应用
2011/06/13 PHP
浅谈php函数serialize()与unserialize()的使用方法
2014/08/19 PHP
php中mail函数发送邮件失败的解决方法
2014/12/24 PHP
Smarty最简单实现列表奇偶变色的方法
2015/07/01 PHP
基于thinkPHP类的插入数据库操作功能示例
2017/01/06 PHP
Laravel框架之解决前端显示图片问题
2019/10/24 PHP
javascript预加载图片、css、js的方法示例介绍
2013/10/14 Javascript
各浏览器对document.getElementById等方法的实现差异解析
2013/12/05 Javascript
jquery实现一个简单好用的弹出框
2014/09/26 Javascript
jQuery原型属性和原型方法详解
2015/07/07 Javascript
jQuery获取字符串中出现最多的数
2016/02/22 Javascript
微信小程序 WXDropDownMenu组件详解及实例代码
2016/10/24 Javascript
Node.js 实现简单小说爬虫实例
2016/11/18 Javascript
微信小程序 缓存(本地缓存、异步缓存、同步缓存)详解
2017/01/17 Javascript
vue项目中公用footer组件底部位置的适配问题
2018/05/10 Javascript
react-native android状态栏的实现
2018/06/15 Javascript
详解vue中组件参数
2018/07/09 Javascript
Vue export import 导入导出的多种方式与区别介绍
2020/02/12 Javascript
[05:17]DOTA2誓师:今天我们在这里 明天TI4等我!
2014/03/26 DOTA
Python编程实现的简单神经网络算法示例
2018/01/26 Python
Python学习工具jupyter notebook安装及用法解析
2020/10/23 Python
如何在windows下安装配置python工具Ulipad
2020/10/27 Python
HTML5本地数据库基础操作详解
2016/04/26 HTML / CSS
有影响力的品牌之家:Our Social Collective
2019/06/08 全球购物
SmartBuyGlasses德国:购买太阳镜和眼镜
2019/08/20 全球购物
英国时尚首饰品牌:Missoma
2020/06/29 全球购物
简历中个人自我评价范文
2013/12/26 职场文书
新闻学专业个人求职信写作
2014/02/04 职场文书
大学应届毕业生求职信
2014/05/24 职场文书
建党伟业观后感
2015/06/01 职场文书
《我们的民族小学》教学反思
2016/02/19 职场文书
浅谈redis整数集为什么不能降级
2021/07/25 Redis
Python OpenCV实现图形检测示例详解
2022/04/08 Python
Tomcat项目启动失败的原因和解决办法
2022/04/20 Servers
详解SQL的窗口函数
2022/04/21 Oracle