1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue组件中prop属性

vue组件中prop属性

时间:2022-10-22 16:46:34

相关推荐

vue组件中prop属性

Vue组件prop属性

prop大小写 单项数据流

所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。

每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你不应该在一个子组件内部改变 prop。

在组件中修改 prop 传递过来的数据 Vue 会发出警告,所以有两种常见的用法去修改 prop 传递过来的值

本地定义属性,并将 prop 作为初始值

prop 传入之后需要进行转换,这种情况使用 computed 来定义

prop验证

<test-prop-validate :prop-a="1" :prop-b="2" :prop-c="'3'" :prop-f="'success'"></test-prop-validate>ponent('test-prop-validate', {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 ['success', 'warning', 'danger'].indexOf(value) !== -1}}},data() {return {}},template: `<div>{{propD}}{{propE}}</div>`})

type可以是下列原生构造函数中的一个:

String,Number,Boolean,Array,Object,Date,Function,Symbol非prop特性

非 prop 特性,组件可以接受任意的特性,而这些特性会被添加到这个组件的根元素上

<style>.colorRed {color: red;}.defineSize {font-size: 20px;}</style><!-- 非prop属性 --><test-not-prop class="colorRed" my-self-define></test-not-prop>ponent('test-not-prop', {data() {return {}},template: `<div style="font-weight:bold;" class="defineSize">Test Not Prop</div>`})<!-- 渲染为 --><div class="defineSize colorRed" my-self-define="" style="font-weight: bold;">Test Not Prop</div>

对于绝大多数特性来说,从外部提供给组件的值会替换掉组件内部设置好的值。所以如果传入 type=“text” 就会替换掉 type=“date” 并把它破坏!庆幸的是,class 和 style 特性会稍微智能一些,即两边的值会被合并起来,从而得到最终的值:defineSize colorRed。

总结

prop 数据单项传递,父影响子,子不影响父不能在组件中直接修改 prop 传递过来的值,Vue 会给出警告prop 验证时,会在实例创建之前进行验证,所以实例的属性 (如 data、computed 等) 在 default 或

validator 函数中是不可用的非 prop 特性,组件可以接受任意的特性,而这些特性会被添加到这个组件的根元素上

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。