使用Vue完成一个checklist

创建一个项目

$ vue init webpack-simple vuedemo01
640?wx_fmt=jpeg
初始化项目

除了Use sass?选择N,其他默认

根据提示安装依赖并运行

$ cd vuedemo01
$ npm install
$ npm run dev

npm install可以使用淘宝的镜像cnpm

640?wx_fmt=jpeg
运行结果

使用编辑器打开该文件夹

640?wx_fmt=jpeg
文件夹

需求

差不多是要完成以下界面

640?wx_fmt=jpeg
目标

编码

去除App.vue多余部分,剩下如下部分即可

<template>
  <div id="app">
    {{msg}}
  </div>
</template>

<script>
export default {
  name: "app",
  data() {
    return {
      msg: "Welcome to Your Vue.js App"
    };
  }
};
</script>

<style>
</style>
640?wx_fmt=jpeg
当前页面

html部分

包含

  • 一个输入框,

  • 两个h2标签的文字

  • n个无序的项

  • 删除按钮

<template>
  <div id="app">
    <input type="text">
    <hr>
    <h2>进行中</h2>
    <ul>
      <li>1</li>
    </ul>
    <hr>
    <h2>已完成</h2>
    <ul>
      <li>2</li>
    </ul>
  </div>
</template>
640?wx_fmt=jpeg
初版

script数据部分

每次输入到输入框的内容需要一个变量来接收

存放的每个内容,以及与其对应的状态

<script>
export default {
  name: "app",
  data() {
    return {
      todo: "",
      list: [{ todo: "aa", checked: false }]
    };
  }
};
</script>

为了把数据渲染到页面上,需要修改html部分的li中的内容

使用v-for来循环输出list的索引和内容

使用v-if来判断:

  • 复选框没选中的内容会显示在进行中

  • 复选框选中的内容会显示在已完成

<ul>
  <li v-for="(item,key) in list" v-if="!item.checked">
    <input type="checkbox" v-model='item.checked' @change="saveList()">
      {{item.title}} ----- <button>删除</button>
  </li>
</ul>
<ul>
  <li v-for="(item,key) in list" v-if="item.checked" @change="saveList()">
    <input type="checkbox" v-model='item.checked'> {{item.title}} ----- <button @click='deleteDate(key)'>删除</button>
  </li>
</ul>

函数部分

在说函数部分前,还剩下顶部的输入框还没有增加方法的入口

<input type="text" v-model="todo" @keydown='doAdd($event)'>

v-model表明它接收的内容会修改todo

@keydown对应键盘操作

在date部分之后增加methods

640?wx_fmt=jpeg
image-20190421200514387
import storage from "./model/storage.js";
export default {
  data() {
    return {
      todo: "",
      list: [{ todo: "aa", checked: false }]
    };
  },
  methods: {
    doAdd(e) {
      if (e.keyCode == 13) { //按键13是回车
        this.list.push({//列表中插入对象
          title: this.todo,
          checked: false
        });
      }
      storage.set("list", this.list);
    },
    deleteDate(key) {
      this.list.splice(key, 1);//删除对应索引的内容
      storage.set("list", this.list);
    },
    saveList() {
      storage.set("list", this.list);
    }
  }
};

这里封装了一个storage.js,用于保存数据至本地,这样下次打开页面还是会恢复至上次关闭的时候。

640?wx_fmt=jpeg
封装
import { loadavg } from "os";

var storage={
    set(key,value){
        localStorage.setItem(key,JSON.stringify(value));
    },
    get(key){
        return JSON.parse(localStorage.getItem(key));
    },
    remove(key){
        localStorage.removeItem(key);
    }
}
export default storage

全代码

<template>
  <div id="app">
    <input type="text" v-model="todo" @keydown='doAdd($event)'>
    <hr>
    <br>
    <h2>进行中</h2>
    <ul>
      <li v-for="(item,key) in list" v-if="!item.checked">
        <input type="checkbox" v-model='item.checked' @change="saveList()">
        {{item.title}} ----- <button @click='deleteDate(key)'>删除</button>
      </li>
    </ul>
    <hr>
    <h2>已完成</h2>
    <ul>
      <li v-for="(item,key) in list" v-if="item.checked" @change="saveList()">
        <input type="checkbox" v-model='item.checked'> {{item.title}} ----- <button @click='deleteDate(key)'>删除</button>
      </li>
    </ul>


  </div>
</template>

<script>
  import storage from './model/storage.js'
  export default {
    data() {
      return {
        todo: "",
        list: []
      };
    },
    methods: {
      doAdd(e) {
        if (e.keyCode == 13) {
          this.list.push({
            title: this.todo,
            checked: false
          })
        }
        storage.set('list', this.list)
      },
      deleteDate(key) {
        this.list.splice(key, 1)
        storage.set('list', this.list)
      },
      saveList() {
        storage.set('list', this.list)
      }
    },
    mounted() {
      var list = storage.get('list', this.list);
      if (list) {
        this.list = list
      }
    }
  };
</script>

<style lang="scss"></style>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中,我们可以使用import语句来导入外部组件或工具类。如果要导入全部组件,可以使用以下语法: ```javascript import Vue from 'vue' import Router from 'vue-router' import Mint from 'mint-ui' Vue.use(Router) Vue.use(Mint) ``` 这里的`Vue.use()`用于全局注册插件。如果只需要按需引入部分组件,可以使用以下语法: ```javascript import { Cell, Checklist } from 'mint-ui' Vue.component(Cell.name, Cell) Vue.component(Checklist.name, Checklist) ``` 这样就可以在Vue组件中使用这些组件了。 如果要在.vue文件中导入样式文件,可以在组件的style标签中使用@import语句,例如: ```html <style> @import 'iview/dist/styles/iview.css'; </style> ``` 如果要导入工具类,有两种方式。第一种是导入单个方法,例如: ```javascript import { axiosfetch } from './util' export function axiosfetch(options) { // ... } ``` 第二种是导入成组的方法,例如: ```javascript import * as tools from './libs/tools' Vue.prototype.$tools = tools ``` 这样就可以在Vue组件中使用`this.$tools.method`来调用工具方法。 关于export和export default的区别,export用于导出多个变量或函数,需要使用花括号来导入,而export default用于导出默认的变量或函数,不需要使用花括号来导入。例如: ```javascript // util.js export function axiosfetch(options) { // ... } // main.js import { axiosfetch } from './util' // 需要加花括号 // util.js export default function axiosfetch(options) { // ... } // main.js import axiosfetch from './util' // 不需要加花括号 ``` 希望以上解答能够帮到你。 #### 引用[.reference_title] - *1* *2* [Vue中import用法](https://blog.csdn.net/fuhanghang/article/details/123836995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Vue几种import用法](https://blog.csdn.net/kun_931013/article/details/86620749)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值