vue中$children的理解

简介: vue中$children的理解

官网介绍 $children

$children 获取当前实例的直接子组件 。需要注意 $children 并不保证顺序,也不是响应式的。[特别重要]
如果你发现自己正在尝试使用 $children 来进行数据绑定,
考虑使用一个数组配合 v-for 来生成子组件,并且使用 Array 作为真正的来源。
注意1:注意当期实例是指这个文件下的实例。直接子组件是指这个文件下的直接子组件。
      如果子组件中还有子组件则孙子组件不能算直接子组件。
注意2:缺点:需要通过索引才能拿到自己想要的子组件,如果删除了某个子组件,会影响到子组件的结果,所以在实际的开发中比较少用
因此使用这个属性的时候一定要慎之又慎。

$children的简单使用

//childSon 子组件
<template>
  <div class="son-child-div">
    <h1>我是子组件:{{ msg}}</h1>
  </div>
</template>p
<script>
export default {
  data(){
    return {
      msg:'子组件的数据'
    }
  }
}
</script>
//父组件
<template>
  <div>
    <el-button @click="handlerMe">点我</el-button>
    <childSon></childSon>
  </div>
</template>
<script>
import childSon from "@/components/child/childSon.vue"
export default {
  components:{
    childSon
  },
  data() {
    return {
        info:'info'
    }
  },
  methods:{
    handlerMe(){
      console.log('==>',this.$children) //输出数组长度是2
    }
  }
};
</script>

为什么输出的数组长度是2?不应该是1嘛?

console.log('==>',this.$children) //输出数组长度是2
之所以是输出的长度是2。是因为children 获取当前实例的直接子组件。
此时可能会有小伙伴说:我不是子引入了一个 childSon 组件吗?是2 ? ???? 你怕不是在骗我不识数哦。
你好好在看看。
你的意思是说:    <el-button @click="handlerMe">点我</el-button> 也算一个组件吗? 是的。也是1个。
此时恍然大悟。 如果你把它改成普通的按钮 button, 不去使用 el-button 组件就是1个了。

$children修改子组件中的数据

//父组件
<template>
  <div>
    <button @click="handlerMe">点我</button>
    <childSon></childSon>
  </div>
</template>
<script>
import childSon from "@/components/child/childSon.vue"
export default {
  components:{
    childSon
  },
  data() {
    return {
      info:'info'
    }
  },
  methods:{
    handlerMe(){
      console.log('==>',this.$children) //输出数组长度为1了
      this.$children[0].msg = '我改了数据';
    }
  }
};
</script>

啰嗦一下:$children修改子组件中的数据

$children 修改数据的话,一定要慎之又慎。或者建议不要使用它来修改数据。【反正我不建议】
因为:需要通过索引才能拿到自己想要的子组件。
如果删除了某个子组件,会影响到子组件的结果,这样会导致修改失败。
所以在实际的开发中比较少用。或者不用它
因此使用这个属性的时候一定要慎之又慎。
其实我个人觉得这个属性挺鸡肋的。通信我们可以使用 props, project,...

遇见问题,这是你成长的机会,如果你能够解决,这就是收获。

相关文章
|
6天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
21 0
|
6天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
7天前
|
JavaScript 数据库
ant design vue日期组件怎么清空 取消默认当天日期
ant design vue日期组件怎么清空 取消默认当天日期
|
7天前
|
JavaScript C++
vue高亮显示组件--转载
vue高亮显示组件--转载
12 0
|
1天前
|
JavaScript Java 关系型数据库
基于SprinBoot+vue的租房管理系统2
基于SprinBoot+vue的租房管理系统2
9 0
|
2天前
|
自然语言处理 JavaScript 数据可视化
5个值得推荐的Vue后台管理框架
几个优秀好看的 Vue 后台管理框架,每个框架都有自己的特点和优势,开发者可以根据项目需求选择适合的框架。
14 0
|
6天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
13 1
|
6天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
6天前
|
JavaScript
Vue中避免滥用this去读取data中数据
Vue中避免滥用this去读取data中数据
|
6天前
|
JavaScript
vue中使用pinia及持久化
vue中使用pinia及持久化
12 0