VUE实现todolist

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title></title>
    <script src="https://unpkg.com/vue@3"></script>

    <!-- 引入样式 -->
    <link rel="stylesheet" href="https://unpkg.com/element-plus/dist/index.css" />
    <!-- 引入组件库 -->
    <script src="https://unpkg.com/element-plus/dist/index.full.js"></script>

</head>
  <body>
    <div id="root"></div>
  </body>
  <script>
    const useInputEffect = ()=>{
        const{ref}=Vue;
        const inputValue = ref("111");
        const handleInputChange = (newValue) => {
          inputValue.value = newValue;
        };
        return {
            inputValue,
            handleInputChange,
        }
    }

    const useListEffect=()=>{
        let itemId=0;
        const{reactive,toRefs}=Vue;
        // const list = reactive([{content:"vue3"},{content:"yingyu"},{content:"shujujiegou"}]);
        let listObj = reactive({list:[]});
        let {list} = toRefs(listObj);
        let multiSelection = reactive([]);
        const addItemToList = (item)=>{
            listObj.list.push({ id:++itemId,content: item.value }); 
            item.value="";
        }
        const handlSelectionChange = (val)=>{
          multiSelection=val;
        }
        const handleDelete = ()=>{
          let list = listObj.list;
          if(multiSelection.length===0){
              alert("未选择");
              return;
          }
          multiSelection.forEach((selectedItem) => {
            list = list.filter((listItem)=>listItem.id!=selectedItem.id);
          });
          listObj.list = list;
        }
        return {
          list,
          addItemToList,
          handlSelectionChange,
          handleDelete,
          handlSelectionChange,
        };
    }

    const app = Vue.createApp({
      setup() {
        const{inputValue,handleInputChange}=useInputEffect();
        const{list,
          addItemToList,
          handlSelectionChange,
          handleDelete,
        }=useListEffect();
        const handleSubmit=()=>{
            addItemToList(inputValue)
        }
        return {
          inputValue,
          handleInputChange,
          handleSubmit,
          list,
          addItemToList,
          handlSelectionChange,
          handleDelete,
        };
      },
      template: `
        <div>
          <div>
              <el-input style="width:300px" :modelValue="inputValue" @input="handleInputChange"></el-input>
              <el-button @click="handleSubmit">提交</el-button>
          </div>
          <el-table
              border
              :data="list"
              @selection-change="handlSelectionChange"
              style="width: 200px;">
              <el-table-column
                type="selection"
                width="55">
              </el-table-column>
              <el-table-column
                prop="content"
                label="待办事项"
                width="199">
              </el-table-column>
            </el-table>
             <el-button @click="handleDelete">删除</el-button>
        </div>
      `,
    });
    
    app.use(ElementPlus);
    const vm = app.mount("#root");
  </script>
</html>
相关推荐
qq_1777673717 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头882120 分钟前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
天人合一peng3 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling4 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区4 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO4 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121385 小时前
Vuex介绍
前端·javascript·vue.js
We་ct5 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480065 小时前
【无标题】
开发语言·前端·javascript