defineProps 实现父子组件传值 将todoList组件化

defineProps 实现父子组件传值 将todoList组件化

哈喽哈喽,我是金樽清酒,昨天我不是用ref响应式数据源写一个todoList表单嘛,今天呀,我要升级一下,将tidoList做成一个组件。

为什么要做成组件?

在Vue中采用组件化的方法有很多好处,这些好处使得Vue成为一个强大而灵活的前端框架。以下是一些主要的原因:

  1. 可维护性: 组件化使得代码更易维护。每个组件都是独立的单元,可以独立开发、测试和维护。这降低了代码复杂性,使得整体项目更易于理解和管理。
  2. 可重用性: 组件可以在多个地方重复使用。这样一来,你可以在不同的页面或应用中使用相同的组件,减少了代码冗余,提高了开发效率。
  3. 分离关注点: 组件化允许你将界面的不同部分拆分成独立的组件,每个组件关注特定的功能或视图。这种分离关注点的方法使得代码更清晰,降低了不同部分之间的耦合度。
  4. 提高可测试性: 每个组件都是相对独立的,这使得单元测试和集成测试更加容易。你可以更轻松地测试每个组件的功能,确保其正常工作,并且在整个应用中保持一致性。
  5. 更好的团队协作: 组件化使得多个开发者能够并行工作,因为他们可以独立地开发和测试各自的组件。这样一来,团队协作更加高效,每个成员都能够专注于自己负责的部分。
  6. 提高可维护性: 组件化使得代码更易维护。每个组件都是独立的单元,可以独立开发、测试和维护。这降低了代码复杂性,使得整体项目更易于理解和管理。

总的来说,Vue中采用组件化的方式可以使前端开发更加模块化、灵活和可维护,同时提高了代码的可重用性和可测试性,有助于构建更大型、复杂的应用。

组件能让我们的功能模块化,提高了可维护性和复用性,但是问题也随之而来,我们如何将父组件的值,传递到子组件当中呢?比如我要做一个todoList列表。数据源在父组件里面,靠input框输入到响应式数据ref里面,姑且取名为data。那如何把data传递到子组件里面去呢?

defineProps传值

关于上述的问题,我们可以用defineProps来解决。defineProps就是用来解决父子组件传值的。如何去使用呢?我们从下面的代码进行分析。

js 复制代码
//子组件
<template>
    <div>
        <ul>
            <li v-for="(item, index) of tidoListData" :key="index">
                {{ index }}: {{ item }}
            </li>
        </ul>
    </div>
</template>
  
<script setup>
import { defineProps } from 'vue';

let props = defineProps({
    tidoListData: {
        type: Array,
        default: () => [] // 默认值可以是一个空数组
    }
});
</script>
  
<style lang="scss" scoped></style>

怎么用呢?首先子组件要import从vue中引用defineProps,然后实例化defineProps。在代码15行,我定义了一个tidoListData数据,它的类型是数组,并且设置了一个默认值为空。然后在第5到6行用v-for循环遍历这个数组,并动态绑定index的值为key。进行list的循环,接下来我们就只需要将父组件的数组绑定这个tidoListData进行传值就行了。注意,我这里使用的是单文件组件。

js 复制代码
//父组件
<template>
  <div>
    <hello :msg="'钟氏珠宝店'" class="header" />
    <input v-model="inputValue" />
    <button @click="handleAddItem">添加商品
    </button>
    <button @click="deleteAddItem">删除商品
    </button>
    <div id="app">
      <ul>
        <list :tidoListData="data" />
      </ul>
    </div>
  </div>
</template>
<script setup>
import { ref } from 'vue'
import hello from "./components/hello.vue"
import list from "./components/list.vue"

const inputValue = ref('')
const data = ref([])


const handleAddItem = () => {//往数组里面添加数据
  data.value.push(inputValue.value)
  console.log(data.value)
  inputValue.value = ''
}
const deleteAddItem = () => {//往数组里面删除数据
  data.value = data.value.filter(item => item !== inputValue.value);
  console.log(data.value)
  inputValue.value = ''
}


</script> 

<style lang="less" scoped>
.header {
  text-align: center;
}
</style>

在代码12行,我们把子组件的todoListData绑定父组件的data数组,就完成了父子组件的传值。注意,父组件要引入组件哦。

代码效果

总结

组件化的思想可以提高代码的维护性和复用性。可以实现多人协作的完成一个项目,类似于函数功能模块化。用vue自带的defindProps可以实现父子组件传值。注意引入的是defineProps哦,小编我刚开始打成了definedProps,心态都快崩了,希望友友们不要犯这个错误。

相关推荐
JokerLee...3 分钟前
【Vtable自定义样式】
前端·javascript·vtable
老华带你飞4 分钟前
医院挂号|基于Java医院挂号管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
PyHaVolask8 分钟前
XSS跨站脚本攻击
前端·xss·web漏洞
K3v8 分钟前
【nvm安装14.x失败】nvm设置国内镜像源 npm设置全局缓存以及全局包目录
前端·缓存·npm
DsirNg27 分钟前
Vue 3 Keep-Alive 深度实践:从原理到最佳实践
前端
拾忆,想起30 分钟前
Dubbo序列化异常终结指南:从精准诊断到根治与防御
开发语言·前端·微服务·架构·php·dubbo·safari
yzx99101335 分钟前
基于Flask+Vue.js的智能社区垃圾分类管理系统 - 三创赛参赛项目全栈开发指南
vue.js·分类·flask
+VX:Fegn08951 小时前
人力资源管理|基于springboot + vue人力资源管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
不如摸鱼去1 小时前
uni-app 也能远程调试?使用 PageSpy 打开调试的新大门!
前端·小程序·uni-app
姓蔡小朋友1 小时前
Redis内存回收
前端·数据库·redis