首頁 > web前端 > Vue.js > 主體

Vue如何封裝一個TodoList

醉折花枝作酒筹
發布: 2021-04-22 09:40:44
轉載
2289 人瀏覽過

這篇文章要為大家詳細介紹Vue封裝一個TodoList的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

Vue如何封裝一個TodoList

Vue如何封裝一個TodoList

使用Vue封裝一個簡易的Todolist的小案例. 同時加入了瀏覽器本地快取的技術手段.

瀏覽器本地緩衝:

  • 前提: 一般我們定義的變量,或是用Vuex保存的數據, 當瀏覽器進行了一個刷新那麼這個數據就會丟失, 這樣就做不出歷史記錄的效果了, 但是, 使用瀏覽器快取就可以幫助我們解決這個問題…
  • 瀏覽器快取分為二種sessionStorage 和localStorage,二種原型鏈分別如下:

Vue如何封裝一個TodoList

Vue如何封裝一個TodoList
# 可以看得出, 他們的原型鏈上基本上都是一樣的, 唯一的區別在於

  • localStorage 作用於本地緩存, 時間是持久的,除非手動去刪除, 或者清空, 不然一直都存在瀏覽器中

  • #sessionStorage 作用與會話緩存, 生命週期只存在於本次打開瀏覽器會話, 當完成的關閉瀏覽器,那麼資訊就會丟失, 而僅僅刷新頁面, 資料仍然保存。

本次實例,使用的是sessionStorage, 並對此進行了一次小封裝.

const  storage = {
	set(key, value){
		window.sessionStorage.setItem(key, JSON.stringify(value));
	},
	get(key){
		return JSON.parse(window.sessionStorage.getItem(key));
	},
	remove(key){
		window.sessionStorage.removeItem(key);
	}}export default storage;
登入後複製

實例程式碼:

<template>
	<p class="todo">
		<header>
			<input type="text" placeholder="输入..." v-model="keyword" @keydown.enter="handleList">
			TodoList		</header>
		<!-- 正在进行 -->
		<h4>正在进行...{{dolistNumber}}</h4>
		<template v-for="(item, index) in dolist" :key="index">
			<p class="dolist" v-if="!item.checked">
				<label :for="index +&#39;l&#39;">
					<input type="checkbox" v-model="item.checked" :id="index +&#39;l&#39;" @change="handleChecked">
					{{item.title}}				</label>
				<span @click="cancalDo(index)">X</span>
			</p>
		</template>

		<!-- 已经完成 -->
		<h4>已经完成...{{dolist.length - dolistNumber}}</h4>
		<template v-for="(item, index) in dolist" :key="index">
			<p class="dolist" v-if="item.checked">
				<label :for="index +&#39;ll&#39;">
					<input type="checkbox" v-model="item.checked" :id="index +&#39;ll&#39;"  @change="handleChecked">
					{{item.title}}				</label>
				<span @click="cancalDo(index)">X</span>
			</p>
		</template>
	</p></template><script>
	import storage from &#39;../storage.js&#39;;
	export default {
		name: "todoList",
		data() {
			return {
				keyword: "", //  输入的选项
				dolist: [],
			}
		},
		computed:{
			dolistNumber(){
				return this.dolist.filter(item => item.checked === false).length;
			}
		},
		methods: {
			handleChecked(){
				//  当更改状态之后 重新刷新
				storage.set(&#39;dolist&#39;, this.dolist);
			},
			handleList() {
				if (this.keyword !== "") {
					this.dolist.push({
						title: this.keyword,
						checked: false,
					});
					this.keyword = "";
					storage.set(&#39;dolist&#39;, this.dolist);
				}
				
			},
			cancalDo(index) {
				// 删除这个
				this.dolist.splice(index, 1);
				storage.set(&#39;dolist&#39;, this.dolist);
			}
		},
		mounted(){
			let dolist = storage.get(&#39;dolist&#39;);
			if(dolist){
				this.dolist = dolist;
			}
		},

	}	</script><style>
	.todo {
		margin: 400px auto;
		min-height: 300px;
		width: 800px;
		background-color: #eee;
	}

	.todo header {
		position: relative;
		text-align: center;
		height: 60px;
		line-height: 60px;
		font-size: 20px;
		border-bottom: 2px solid #fff;
	}

	.todo header input {
		position: absolute;
		left: 40px;
		top: 50%;
		transform: translateY(-50%);

		outline: none;
		line-height: 30px;
		border-radius: 15px;
		padding-left: 30px;
		border: 1px solid #999;
		font-size: 16px;
		width: 100px;
		transition: all .6s linear;
	}

	.todo header input:focus {
		width: 200px;
	}

	.dolist {
		padding: 20px;
		font-size: 16px;

	}

	.dolist label {
		cursor: pointer;
	}

	.dolist input {
		margin-right: 10px;

	}

	.dolist span:last-child {
		float: right;
		border: 1px solid gray;
		background-color: #999;
		color: #fff;
		border-radius: 50%;
		padding: 5px;
	}

	h4 {
		padding-bottom: 20px;
		text-align: center;
	}</style>
登入後複製

推薦學習: vue.js教程

以上是Vue如何封裝一個TodoList的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板