IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue小案例---记事本(全选) -> 正文阅读

[JavaScript知识库]vue小案例---记事本(全选)

效果图:?

????????

vuex:

import Vue from "vue";
import Vuex from "vuex";

Vue.use(Vuex);

export default new Vuex.Store({
  state: {
    list: [],
  },
  mutations: {
    add(state, data) {
      state.list.unshift({ name: data, com: false, id: new Date().getTime() });
    },
    qh(state, data) {
      state.list.map((item) => {
        if (item.id == data) {
          // console.log(item.com);
          item.com = !item.com;
        }
      });
    },
    qbxz(state, data) {
      state.list.map((item) => {
        item.com = data;
      });
    },
    del(state, data) {
      // console.log(data);
      // console.log(state.list);
      state.list.splice(data, 1);
    },
    ck(state) {
      state.list = [];
    },
  },
  actions: {},
  modules: {},
});

HTML:

<template>
  <div class="home">
    <div class="zt">
      <div class="header">
        <div class="qx">
          <input
            type="checkbox"
            :checked="qx"
            @click="qxss()"
            v-show="$store.state.list.length"
          /><span v-show="$store.state.list.length">全选</span>
        </div>
        <div class="add">
          <input
            @keyup.enter="add()"
            v-model="sr"
            type="text"
            placeholder="请输入......"
          />
        </div>
      </div>
      <div class="content" v-for="(items, keys) in showlist" :key="keys">
        <div class="nr">
          <div class="xz">
            <input type="checkbox" :checked="items.com" @click="xs(items.id)" />
          </div>
          <div class="context" v-if="!items.com">{{ items.name }}</div>
          <div class="context" v-if="items.com">
            <del style="color: #ccc">{{ items.name }}</del>
          </div>
        </div>
        <div class="del" @click="delc(keys)"><span>×</span></div>
      </div>
      <div
        style="
          width: 100%;
          height: 50px;
          line-height: 50px;
          text-align: center;
          border-bottom: 1px solid #ccc;
          background: #fff;
        "
        v-if="!$store.state.list.length"
      >
        暂无内容~~~~~
      </div>
      <div class="foot">
        <div class="ts">一共{{ $store.state.list.length }}条</div>
        <div class="sx">
          <router-link
            tag="div"
            :class="{ active: mr == 'all' }"
            :to="{ name: 'Home', query: { tab: 'all' } }"
            >全部</router-link
          >
          <router-link
            tag="div"
            :class="{ active: mr == 'yes' }"
            :to="{ name: 'Home', query: { tab: 'yes' } }"
            >已完成</router-link
          >
          <router-link
            tag="div"
            :class="{ active: mr == 'no' }"
            :to="{ name: 'Home', query: { tab: 'no' } }"
            >未完成</router-link
          >
        </div>
        <div
          class="all"
          style="cursor: pointer"
          @click="$store.commit('ck'), (qx = false)"
        >
          删除全部
        </div>
      </div>
    </div>
  </div>
</template>

CSS:


.active {
  color: #007fff;
}
.zt {
  width: 600px;
  height: auto;
  background: #eee;
  margin: 0 auto;
  border: 1px solid #ccc;
}
.zt > .header {
  width: 100%;
  height: 50px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-around;
  /* overflow:hidden; */
  border-bottom: 1px solid #ccc;
  /* box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box; */
}
.header > .qx {
  width: 50px;
  height: 100%;
  /* background:steelblue; */
  display: flex;
  align-items: center;
  justify-content: space-around;
}
.header > .add {
  width: 500px;
  height: 100%;
  /* background:springgreen; */
}
.header > .add > input {
  height: 100%;
  width: 100%;
  border: 0px;
  outline: 0px;
  font-size: 20px;
}
.content {
  width: 100%;
  height: 50px;
  background: #fff;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
}
.content > .nr {
  width: 100px;
  height: 100%;
  display: flex;
  justify-content: space-around;
  align-items: center;
  /* background:red; */
}
.content > .del {
  width: 50px;
  height: 50px;
  /* background:red; */
  text-align: center;
  line-height: 50px;
  font-size: 20px;
}
.content > .del > span {
  opacity: 0;
}
.content > .del:hover {
  font-size: 25px;
  font-weight: bold;
  cursor: pointer;
}
.content:hover > .del > span {
  opacity: 1;
}
.foot {
  width: 100%;
  background: #fff;
  height: 50px;
  display: flex;
  justify-content: space-between;
}
.ts {
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  font-size: 12px;
}
.sx {
  width: 200px;
  height: 50px;
  /* background:teal; */
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sx > div {
  cursor: pointer;
}
.all {
  width: 100px;
  height: 50px;
  text-align: center;
  line-height: 50px;
}
.context {
  font-size: 17px;
}

JS:

export default {
  data() {
    return {
      sr: "",
      mr: "all",
      qx: false,
    };
  },
  methods: {
    add() {
      if (this.sr.trim()) {
        this.$store.commit("add", this.sr);
        let res = this.$store.state.list.every((item) => item.com == true);
        this.qx = res;
      }
      this.sr = "";
    },
    xs(a) {
      this.$store.commit("qh", a);
      let res = this.$store.state.list.every((item) => item.com == true);
      this.qx = res;
    },
    qxss() {
      this.qx = !this.qx;
      this.$store.commit("qbxz", this.qx);
    },
    delc(a) {
      this.$store.commit("del", a);
      if (!this.$store.state.list.length) {
        this.qx = false;
      }
      let res = this.$store.state.list.every((item) => item.com == true);
      this.qx = res;
    },
  },
  computed: {
    showlist() {
      if (this.mr == "all") {
        return this.$store.state.list;
      }
      if (this.mr == "yes") {
        return this.$store.state.list.filter((item) => item.com);
      }
      if (this.mr == "no") {
        return this.$store.state.list.filter((item) => !item.com);
      }
    },
  },
  watch: {
    $route: {
      handler(value) {
        // console.log(value.query.tab);
        if (!value.query.tab) {
          this.mr = "all";
        } else {
          this.mr = value.query.tab;
        }
      },
      immediate: true,
    },
  },
  created() {
    console.log(new Date().getTime());
  },
};

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-04 12:46:00  更:2021-10-04 12:46:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 12:36:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码