Vue 学习之一步一坑

1.在组件的data中的post已经声明成为prop(要从父组件中接收的数据),会使用prop默认值来代替,如果在data中也声明了一个数据,那么就会报错
–解决方法,删掉data 中key的值

vue.js:634 [Vue warn]: The data property "post" is already declared as a prop. Use prop default value instead.

found in

---> <BlogPost>
       <Root>

源码


<blog-post
  v-for="post in posts"
  v-bind:key="post.id"
  v-bind:post="post"
></blog-post>

'blog-post': {
	data: function() {
		return {
			//key: 0,
			//post: {}
		}
	},
	template: '#blog-post',
	props: ['keys', 'post'],
	methods: {
	}
}

2.如果v-bind 了原生默认的标签属性,就会报错
–解决办法 把key 改个名字

[Vue warn]: "key" is a reserved attribute and cannot be used as component prop.

源码

<blog-post
  v-for="post in posts"
  v-bind:key="post.id"
  v-bind:post="post"
></blog-post>

3.子组件修改父组件的值导致报错,应该避免直接修改父组件的值。
在vue2中,直接修改prop是被视作反模式的。由于在新的渲染机制中,每当父组件重新渲染时,子组件都会被覆盖,所以应该把props看做是不可变对象
–解决方法 不更改 quantity prop使其和父组件同步 , 而是让应该这个组件提交个事件给父组件,可以 watch quantity 变量

[Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop's value. Prop being mutated: "parentmsg"

源码

<template id="son-comp">
	<div>
		<h3>父组件接收到的数据: {{ parentmsg }}</h3>
		<button class="btn btn-success" @click="change">点击修改父组件数据</button>
		<h3>子组件自带的数据: {{ content }}</h3>
	</div>
</template>

change() {
		this.parentmsg = "确认将密码强制修改为999?";
	}

修改后

<son
v-bind:parentmsg="msg"
@button="msg = $event"
></son>

<template id="son-comp">
	<div>
		<h3>父组件接收到的数据: {{ parentmsg }}</h3>
		<!-- <button class="btn btn-success" @click="change">点击修改父组件数据</button> -->
		<button class="btn btn-success" @click="$emit('button','确认将密码强制修改为999?')">点击修改父组件数据</button>
		<h3>子组件自带的数据: {{ content }}</h3>
	</div>
</template>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值