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,心态都快崩了,希望友友们不要犯这个错误。

相关推荐
云水一下2 小时前
从零开始!VMware安装Fedora Workstation 44桌面系统完整教程
前端
小码哥_常3 小时前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd3 小时前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码14 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen4 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦4 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen5 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
千寻girling5 小时前
《 Git 详细教程 》
前端·后端·面试
之歆6 小时前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css
yqcoder7 小时前
CSS Position 全解析:5 种定位模式详解
前端·css