vue组件拆分todolist简单demo

1、项目结构

2、TodoList组件

把自己定义为组件时需要name:TodoList,引用组件时需要imporrt 组件,然后components里注册该组件,才能使用它。

<template>
  <input  v-model="inputValue">
  <button @click="handleAdd" class="button">新增</button>
  <ul>
    <!-- <li v-for="(item,index) in list" :key="index">{{item}}</li> -->
    <ListItem v-for="(item,index) in list" :key="index" :msg="item"></ListItem>
  </ul>
</template>

<script>
import ListItem from "./components/ListItem.vue"
import {reactive,ref} from "vue"
export default {
  name:"TodoList",
  components:{
    ListItem
  },
  setup(){
    const inputValue=ref("")
    const list=reactive([])
    const handleAdd=()=>{
      list.push(inputValue.value)
      inputValue.value=""
    }
    return {handleAdd,inputValue,list}
  }
}
</script>

<style>
.button{
  margin-left: 20px;
}

</style>

3、ListItem组件

涉及组件的参数传递,用props来接收父组件传递的参数

<template>
  <li>{{ msg }}</li>
</template>

<script>
export default {
  name:"ListItem",
  props:{
    msg:String,
  }

}
</script>

<style>

</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值