使用vue-cli编写todolist组件

工程结构

 

 启动工程

1
npm run dev

TodoList.vue

复制代码
<!--模板-->
<template>
  <div>
    <div>
      <input class="item" v-model="inputValue"/>
      <button @click="submit">提交</button>
      <ul>
        <todo-item v-for="(item,index) of list" :key="index" :content="item" :index="index" @delete="mydelete"></todo-item>
      </ul>
    </div>
  </div>

</template>

<script>
import TodoItem from './components/TodoItem'
// 此处用来写逻辑,必须空出一行去写
export default {
  // 这块必须用函数去操作,注意缩进,缩进不对的话各路报错
  components: {
    'todo-item': TodoItem
  },
  data () {
    return {
      inputValue: '',
      list: []
    }
  },
  methods: {
    submit () {
      this.list.push(this.inputValue)
      this.inputValue = ''
    },
    mydelete (index) {
      this.list.splice(index, 1)
    }
  }
}
</script>
<!--这个标签用于写样式-->
<style scoped>
</style>
复制代码

TodoItem.vue

复制代码
<template>
  <li class="item" @click="deleteItem">{{content}}</li>
</template>

<script>
export default {
  props: ['content', 'index'],
  methods: {
    deleteItem () {
      this.$emit('delete', this.index)
    }
  }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<!--scoped作用域,设置样式仅用于当前类,不加就是全局生效-->
<style scoped>
  .item {color: aqua}
</style>
复制代码

 

posted @   久曲健  阅读(460)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示