zoukankan      html  css  js  c++  java
  • Vue笔记之props验证

    使用props

    在Vue中父组件向子组件中传送数据是通过props实现的,一个简单的使用props的例子:

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: ['fooMessage'],
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 123
    		}
    	});
    
    </script>
    </body>
    </html>

    为什么要有props验证

    但是上面这种方式是建立在大家都很遵守约定的情况下的,想象一下当有一个人要使用foo-component组件的时候,他可能对于其要接受的参数有什么要求并不是很清楚,因此传入的参数可能会在开发子组件的人的意料之外,程序就会发生错误,就像我们在函数调用之前先检查一下函数一样,props也可以进行一个预先检查。

    平时调用函数的时候在函数开头的地方都是一坨糊糊的参数检查,这种写法很不好了,所有后来就有了校验器模式(别去百度了,我随口取的名字),校验器模式就是指把在函数开头的对参数校验的部分提取出来作为一个公共的部分来管理,让一个什么东西来专门负责校验,当类型不正确的时候就抛个异常根本不去调用这个函数,很多框架设计时都是这么设计的(Spring MVC、Struts2等等),props也提供了这个功能,想一下如果没有这个功能的话,为了保证正确性我们可能需要在每次使用props属性之前都写一坨代码来检查。校验器最大的好处就是大多数情况下我们只需要声明我需要什么样的数据,让校验器检查好了再塞给我。

    type

    可以使用type来声明这个参数可以接受的数据的类型,当检查规则只有一个的时候type可以略写:

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: Number
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 123
    		}
    	});
    
    </script>
    </body>
    </html>

    当传入的参数类型不正确的时候Vue会发出提示:

    image

    type接受多个类型

    当参数可以是多种类型的其中一个的时候,使用数组来表示。

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: [Number, String]
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 123
    		}
    	});
    
    </script>
    </body>
    </html>

    type能够指定的类型

    type可以是以下原生类型:

    String

    Number

    Boolean

    Function

    Object

    Array

    Symbol

    required

    可以使用required选项来声明这个参数是否必须传入。

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				type: Number,
    				required: true
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 256
    		}
    	});
    
    </script>
    </body>
    </html>

    当未传入参数时:

    image

    default

    使用default选项来指定当父组件未传入参数时props变量的默认值:

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				type: Number,
    				default: 128
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 256
    		}
    	});
    
    </script>
    </body>
    </html>

    当父组件未传入参数时子组件的值是128,当父组件传入参数时是其指定的参数,比如这里可以是256。

    当type的类型为Array或者Object的时候default必须是一个函数:

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				type: Array,
    				default: function(){
    					return ['foo', 'bar'];
    				}
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: ['f', 'o', 'o']
    		}
    	});
    
    </script>
    </body>
    </html>

    required && default ???

    那么required和default是否能同时出现在一个props变量中呢?

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				type: Number,
    				required: true,
    				default: 128
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 256
    		}
    	});
    
    </script>
    </body>
    </html>

    渲染结果:

    image

    尽管控制台上Vue报了错误,但是props变量fooMessage还是使用了设置的default值。

    事情不会这么简单,再测试一下其它的情况,比如当传入的参数验证不通过的时候:

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				type: Number
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 'foobar'
    		}
    	});
    
    </script>
    </body>
    </html>

    渲染结果:

    image

    fooMessage要求的类型是Number,传入了一个String类型的,尽管在控制台提示报了错,但是仍然将其渲染了出来。

    由此可以得出一个结论:Vue的props校验只是提供一个参考,并不是强制性的。

    validator

    当校验规则很复杂,默认提供的校验规则无法满足的时候可以使用自定义函数来校验。

    <!DOCTYPE html>
    <html>
    <head>
    	<meta charset="utf-8">
    	<title>Vue Study</title>
    </head>
    <body>
    
    	<div id="app">
    		<foo-component :foo-message="fooMessage"></foo-component>	
    	</div>
    
    <script type="text/javascript" src="lib/vue.js"></script>
    <script type="text/javascript">
    
    	var fooComponent = {
    		props: {
    			fooMessage: {
    				validator: function(value){
    					return value>=0 && value<=128;
    				}
    			}
    		},
    		template: '<div> {{ fooMessage }} </div>'
    	};
    
    	var vm = new Vue({
    		components: {
    			'foo-component': fooComponent
    		},
    		el: '#app',
    		data: {
    			fooMessage: 100
    		}
    	});
    
    </script>
    </body>
    </html>

    一个综合的例子

    props: {
    	// fooA只接受数值类型的参数
    	fooA: Number,
    	// fooB可以接受字符串和数值类型的参数
    	fooB: [String, Number],
    	// fooC可以接受字符串类型的参数,并且这个参数必须传入
    	fooC: {
    		type: String,
    		required: true
    	},
    	// fooD接受数值类型的参数,如果不传入的话默认就是100
    	fooD: {
    		type: Number,
    		default: 100
    	},
    	// fooE接受对象类型的参数
    	fooE: {
    		type: Object,
    		// 当为对象类型设置默认值时必须使用函数返回
    		default: function(){
    			return { message: 'Hello, world' }
    		}
    	},
    	// fooF使用一个自定义的验证器
    	fooF: {
    		validator: function(value){
    			return value>=0 && value<=100;
    		}
    	}
    }

    .

  • 相关阅读:
    CodeSmith注册错误的解决方法
    我是“坚守者”还是"背叛者"?
    拿什么留住你,我的程序员
    去除HTML代码得函数
    页面之间传递参数得几种方法
    nhibernate source code analyzed (abstract classes in nhibernate2.0)
    Web 2.0时代RSS的.Net实现
    Visual Studio.net 2003安装提示重启问题
    开放思路,综合考虑,心胸开阔,做一个合格的项目经理
    了解实际开发中 Hashtable 的特性原理 .NET, JAVA, PHP
  • 原文地址:https://www.cnblogs.com/cc11001100/p/7192544.html
Copyright © 2011-2022 走看看