Vue3.0实现todolist-实现todolist每个组件需要用到的方法

简介: Vue3.0实现todolist-实现todolist每个组件需要用到的方法

参考文档

参考文档:https://blog.csdn.net/ll666888999/article/details/123789098

参考视频:https://www.imooc.com/learn/1300

官方文档查看文档:https://v3.cn.vuejs.org/


NavHrader中绑定键盘事件

<div>
    <input placeholder="请输入任务名称" v-model="value"  @keydown.enter="enter"/>
  </div>

setup()里面定义方法

setup() {
    let value = ref("");
    let enter = () =>{
      console.log(value.value)
    }
    return {
      value,
      enter
    };
  },

运行结果

NavHeader.vue

<template>
  <div>
    <input placeholder="请输入任务名称" v-model="value"  @keydown.enter="enter"/>
  </div>
</template>
<script>
import { defineComponent, ref } from "vue";
export default defineComponent({
  name: "navHeader",
  setup() {
    let value = ref("");
    let enter = () =>{
      console.log(value.value)
    }
    return {
      value,
      enter
    };
  },
});
</script>
<style scoped>
</style>

NavMain中div取类名为item,button取类名为del,绑定点击事件

NavMain.vue

<template>
  <div>
    <div v-for="(item, index) in list" :key="index">
      <div class="item">
        <input type="checkbox" v-model="item.complete" />
        {{ item.title }}
        <button class="del"  @click="del(item,index)">删除</button>
      </div>
    </div>
  </div>
</template>
<script>
import { defineComponent, ref } from "vue";
export default defineComponent({
  name: "navMain",
  setup() {
    let list = ref([
      {
        title: "吃饭",
        complete: false,
      },
      {
        title: "睡觉",
        complete: false,
      },
      {
        title: "打豆豆",
        complete: false,
      },
    ]);
    //删除任务
    let del=(item,index) =>{
      console.log(item)
      console.log(index)
    }
    return {
      list,
      del
    };
  },
});
</script>
<style scoped  lang='scss'>
// .item{
//   height: 35px;
//   line-height: 35px;
//   position: relative;
//   width: 160px;
//   cursor: pointer;
//   button {
//     position: absolute;
//     right:20px;
//     top:6px;
//     display:none;
//     z-index:99;
//   }
// }
// &:hover{
//   background: #ddd;
//   button{
//     display: block;
//   }
// }
</style>

运行结果

依次删除

NavFooter 样式名起类名container,里面取类名btn

button绑定点击事件clear

<template>
  <div class="container">
    <div>已完成{{ isComplete }}/全部{{ all }}</div>
    <div v-if="isComplete > 0"  class="btn">
      <button  @click="clear">清除已完成</button>
    </div>
  </div>
</template>
<script>
import { defineComponent, ref } from "vue";
export default defineComponent({
  name: "navFooter",
  setup() {
    let isComplete = ref(1);
    let all = ref(3);
    //清除已完成
    let clear =() =>{
      console.log('clear')
    }
    return {
      isComplete,
      all,
      clear
    };
  },
});
</script>
<style scoped>
</style>
相关文章
|
5天前
|
JavaScript 数据库
ant design vue日期组件怎么清空 取消默认当天日期
ant design vue日期组件怎么清空 取消默认当天日期
|
5天前
|
JavaScript C++
vue高亮显示组件--转载
vue高亮显示组件--转载
9 0
|
5天前
|
JavaScript 前端开发 开发者
Vue的事件处理机制提供了灵活且强大的方式来响应用户的操作和组件间的通信
【5月更文挑战第16天】Vue事件处理包括v-on(@)指令用于绑定事件监听器,如示例中的按钮点击事件。事件修饰符如.stop和.prevent简化逻辑,如阻止表单默认提交。自定义事件允许组件间通信,子组件通过$emit触发事件,父组件用v-on监听并响应。理解这些机制有助于掌握Vue应用的事件控制。
18 4
|
5天前
|
JavaScript 前端开发 UED
Vue class和style绑定:动态美化你的组件
Vue class和style绑定:动态美化你的组件
|
5天前
|
JavaScript
vue封装面包屑组件
vue封装面包屑组件
8 0
|
5天前
|
JavaScript 前端开发 API
深入理解vue组件生命周期,你一定要看到最后,最后有深入探讨
深入理解vue组件生命周期,你一定要看到最后,最后有深入探讨
|
5天前
|
JavaScript Go
VUE3+vite项目中动态引入组件和异步组件
VUE3+vite项目中动态引入组件和异步组件
|
5天前
|
缓存 算法 JavaScript
vue中组件保活<keep-alive>的使用
vue中组件保活<keep-alive>的使用
|
5天前
|
JavaScript 前端开发 UED
教你用vue自定义指令做一个组件的遮罩层loading效果
教你用vue自定义指令做一个组件的遮罩层loading效果
|
5天前
|
存储 JavaScript 前端开发
用Vue写一个简单好看的菜单组件(Vue实战系列)
用Vue写一个简单好看的菜单组件(Vue实战系列)