子组件为何不可以修改父组件传递的propos?
如果修改了,Vue是如何监控到属性的修改并给出警告的?
按个人的理解的话:由于单向数据流,属性只能通过父组件传递到自组件,但是不能反过来,至于Vue监控属性的修改给出警告的话,应该回到我们的生命周期,在事件发生改变之后呢,Vue重新修改,更新DOM节点,发现属性值修改之后更新原有的DOM节点,但是在编译、渲染的时候发现不对了,然后就开始报错。
this.$emit的返回值?
感觉有个博客写的不错
https://www.cnblogs.com/padding1015/p/7878741.html
就是子组件提供给父组件使用的一个占位符,父组件中可以添加任何代码、数据放置在子组件的slot标签中
<tag1>插槽里面的东西</tag1> //将要写的内容写在标签内
var tag1mes = {
template:`<dl>
//在slot中可以添加属性值,也就是作为其默认值,在其后添加标签,可以修改原有的默认标签属性值
<dt><slot></slot></dt> //添加一个slot标签,定于的就是一个插槽
<dd>插槽插入内容之后的一段文字</dd>
</dl>`
}
<tag1 :fatherdata="fatherdata">
<template slot="tit">我的标题</template>
<template slot="mes">我的内容</template>
</tag1>
template:` <dl>
<dt><slot name="tit">默认标题</slot></dt>
<dd><slot name="mes">默认的内容</slot></dd>
</dl>`
通过slot的name属性,将slot与template对应起来
但是在2.6+的版本中,没有了slot方法,使用了v-slot,使用的时候必须放在template中使用
注:
都是通过父组件传递给子组件内容,然后子组件根据传递过来的内容来执行相应的行为
原文:https://www.cnblogs.com/Indomite/p/13264227.html