Vuex實(shí)現(xiàn)記事本功能
本文實(shí)例為大家分享了Vuex實(shí)現(xiàn)記事本功能的具體代碼,供大家參考,具體內(nèi)容如下
首先:執(zhí)行命令 安裝Vuex
npm install vuex@next --save
在mian.js 中掛在vuex
import store from './store'
?
new Vue({
? store,
? render: h => h(App)
}).$mount('#app')這里使用的 Ant Design UI :
npm install ant-design-vue --save
在 main.js 中完整引入
import Antd from 'ant-design-vue' import 'ant-design-vue/dist/antd.css' Vue.use(Antd)
App.vue中
<template>
? <div id="app">
? ? <div>
? ? ? <a-input placeholder="請(qǐng)輸入任務(wù)" class="my_ipt" :value='inputVal'
? ? ? @change="handleInputChange"
? ? ? />
? ? ? <a-button type="primary" @click="addItem">添加事項(xiàng)</a-button>
?
? ? ? <a-list bordered :dataSource="infoList" class="dt_list">
? ? ? ? <a-list-item slot="renderItem" slot-scope="item">
? ? ? ? ? <!-- 復(fù)選框 -->
? ? ? ? ? <a-checkbox :checked='item.done' @change="changeItem(item.id,$event.target.checked)">{{ item.info }}</a-checkbox>
? ? ? ? ? <!-- 刪除鏈接 -->
? ? ? ? ? <a slot="actions" @click="deleteItemById(item.id)">刪除</a>
? ? ? ? </a-list-item>
?
? ? ? ? <!-- footer區(qū)域 -->
? ? ? ? <div class="footer" slot="footer">
? ? ? ? ? <span>{{unDoneNub}}條未完成</span>
? ? ? ? ? <a-button-group>
? ? ? ? ? ? <a-button :type="ViewType=='all'?'primary':''" @click="changeList('all')">全部</a-button>
? ? ? ? ? ? <a-button :type="ViewType=='undone'?'primary':''" @click="changeList('undone')">未完成</a-button>
? ? ? ? ? ? <a-button :type="ViewType=='done'?'primary':''" @click="changeList('done')">已完成</a-button>
? ? ? ? ? </a-button-group>
? ? ? ? ? <a @click="deleteDone">清除已完成</a>
? ? ? ? </div>
? ? ? </a-list>
? ? </div>
? </div>
</template>
<script>
import { mapState, mapGetters } from 'vuex'
export default {
? name: 'app',
? data () {
? ? return {
? ? ? // 模擬數(shù)據(jù)
? ? ? // list: []
? ? }
? },
? computed: {
? ? ...mapState(['list', 'inputVal', 'ViewType']),
? ? ...mapGetters(['unDoneNub', 'infoList'])
? },
? created () {
? ? this.$store.dispatch('getList')
? },
? methods: {
? ? handleInputChange (e) {
? ? ? console.log(e.target.value)
? ? ? // 拿到輸入框的值 ?保存到vuex中
? ? ? this.$store.commit('setInputVal', e.target.value)
? ? },
? ? // 向列表中添加事項(xiàng)
? ? addItem () {
? ? ? if (this.inputVal.trim().length <= 0) {
? ? ? ? return alert('文本框不能為空')
? ? ? }
? ? ? // 向store中調(diào)用函數(shù) ?來修改數(shù)據(jù) ?不可以直接修改
? ? ? this.$store.commit('addItem')
? ? },
?
? ? // 刪除
? ? deleteItemById (id) {
? ? ? // console.log(id);
? ? ? this.$store.commit('deleteItem', id)
? ? },
?
? ? // 改變狀態(tài)
? ? changeItem (id, e) {
? ? ? console.log(id, e)
? ? ? // 通過id改變狀態(tài)
? ? ? this.$store.commit('changeItem', id)
? ? },
?
? ? // 清除已完成
? ? deleteDone () {
? ? ? this.$store.commit('deleteDone')
? ? },
?
? ? changeList (type) {
? ? ? this.$store.commit('changeList', type)
? ? }
?
? }
}
</script>
<style scoped>
#app {
? padding: 10px;
? margin: 0 auto;
? display: flex;
? justify-content: center;
}
.my_ipt {
? width: 500px;
? margin-right: 10px;
}
.dt_list {
? width: 500px;
? margin-top: 10px;
}
.footer {
? display: flex;
? justify-content: space-between;
? align-items: center;
}
</style>store index.js 中
import Vue from 'vue'
import Vuex from 'vuex'
import axios from 'axios'
?
Vue.use(Vuex)
?
export default new Vuex.Store({
? state: {
? ? list: [],
? ? inputVal: '',
? ? id: 10,
? ? ViewType: 'all'
? },
? // 真正操作數(shù)據(jù)的地方
? mutations: {
? ? INITLIST (state, data) {
? ? ? state.list = data
? ? },
? ? setInputVal (state, data) {
? ? ? state.inputVal = data
? ? },
? ? addItem (state) {
? ? ? const obj = {
? ? ? ? id: state.id,
? ? ? ? info: state.inputVal.trim(),
? ? ? ? done: false
? ? ? }
? ? ? state.list.push(obj)
? ? ? state.id++
? ? ? state.inputVal = ''
? ? },
? ? // 刪除已完成
? ? deleteDone (state) {
? ? ? state.list = state.list.filter(item => {
? ? ? ? return item.done != true
? ? ? })
? ? },
? ? deleteItem (state, id) {
? ? ? state.list = state.list.filter(item => {
? ? ? ? // console.log(item.id);
? ? ? ? return item.id != id
? ? ? })
? ? },
? ? // 改狀態(tài)
? ? changeItem (state, id) {
? ? ? // 對(duì)應(yīng)id的done值取反 先拿索引 根據(jù)索引 取反對(duì)應(yīng)的狀態(tài) ?如果有多重狀態(tài) 則需要參數(shù)傳遞
? ? ? const index = state.list.findIndex(item => {
? ? ? ? return item.id === id
? ? ? })
? ? ? if (index !== -1) {
? ? ? ? state.list[index].done = !state.list[index].done
? ? ? }
? ? },
? ? // 改變列表
? ? changeList (state, type) {
? ? ? state.ViewType = type
? ? ? state
? ? }
? },
? actions: {
? ? //模仿發(fā)送請(qǐng)求
? ? getList (content) {
? ? ? axios.get('./list.json').then(res => {
? ? ? ? console.log(res.data)
? ? ? ? content.commit('INITLIST', res.data)
? ? ? })
? ? }
?
? },
? modules: {
? },
? getters: {
? ? // 未完成的數(shù)量
? ? unDoneNub (state) {
? ? ? return (state.list.filter(item => {
? ? ? ? return item.done == false
? ? ? })).length
? ? },
? ? // 根據(jù)列表類型 過濾不同的展示列表
? ? infoList (state) {
? ? ? if (state.ViewType == 'all') {
? ? ? ? return state.list
? ? ? }
? ? ? if (state.ViewType == 'undone') {
? ? ? ? return state.list.filter(item => !item.done)
? ? ? }
? ? ? if (state.ViewType == 'done') {
? ? ? ? return state.list.filter(item => item.done)
? ? ? }
? ? }
? }
})list.json
[
? ? {
? ? ? ? "id": 0,
? ? ? ? "info": "打籃球",
? ? ? ? "done": false
? ? },
? ? {
? ? ? ? "id": 1,
? ? ? ? "info": "打王者榮耀",
? ? ? ? "done": true
? ? },
? ? {
? ? ? ? "id": 2,
? ? ? ? "info": "學(xué)習(xí)",
? ? ? ? "done": false
? ? },
? ? {
? ? ? ? "id": 3,
? ? ? ? "info": "吃飯",
? ? ? ? "done": false
? ? },
? ? {
? ? ? ? "id": 4,
? ? ? ? "info": "睡覺",
? ? ? ? "done": false
? ? }
]結(jié)果圖:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue源碼學(xué)習(xí)記錄之手寫vm.$mount方法
在我們開發(fā)中,經(jīng)常要用到Vue.extend創(chuàng)建出Vue的子類來構(gòu)造函數(shù),通過new 得到子類的實(shí)例,然后通過$mount掛載到節(jié)點(diǎn),今天通過本文給大家講解手寫vm.$mount方法 ,感興趣的朋友一起看看吧2022-11-11
詳解在WebStorm中添加Vue.js單文件組件的高亮及語法支持
本篇文章主要介紹了詳解在WebStorm中添加Vue.js單文件組件的高亮及語法支持,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10
Vue?2?和?Vue?3?中?toRefs函數(shù)的不用用法
Vue?是一款流行的JavaScript?框架,用于構(gòu)建用戶界面,在Vue2和?Vue3中,都存在一個(gè)名為toRefs的函數(shù),但其行為在這兩個(gè)版本中有所不同,這篇文章主要介紹了Vue2和Vue3中toRefs的區(qū)別,需要的朋友可以參考下2023-08-08
解讀element?el-upload上傳的附件名稱不顯示?file-list賦值
這篇文章主要介紹了解讀element?el-upload上傳的附件名稱不顯示?file-list賦值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vue el-table實(shí)現(xiàn)行內(nèi)編輯功能
這篇文章主要為大家詳細(xì)介紹了vue el-table實(shí)現(xiàn)行內(nèi)編輯功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12

