Maison >interface Web >Voir.js >Comment Vue encapsule une TodoList

Comment Vue encapsule une TodoList

醉折花枝作酒筹
醉折花枝作酒筹avant
2021-04-22 09:37:132329parcourir

Cet article vous donnera une introduction détaillée à la méthode d'encapsulation d'une TodoList dans Vue. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Comment Vue encapsule une TodoList

Comment Vue encapsule une TodoList

Utiliser Vue pour encapsuler un simple cas Todolist. En même temps, les moyens techniques de mise en cache locale du navigateur sont ajoutés.

Tampon local du navigateur :

  • Prémisse : Généralement, les variables que nous définissons, ou les données enregistrées avec Vuex, seront perdues lors de l'actualisation du navigateur, ce ne sera pas le cas. obtenir l'effet des enregistrements historiques, mais l'utilisation du cache du navigateur peut nous aider à résoudre ce problème...
  • Le cache du navigateur est divisé en deux types : sessionStorage et localStorage, les deux prototypes Les chaînes sont les suivantes :

Comment Vue encapsule une TodoList

Comment Vue encapsule une TodoList
On peut voir que leurs prototypes de chaînes sont fondamentalement les mêmes Oui, la seule différence est que

  • localStorage agit sur le cache local et est persistant À moins qu'il ne soit supprimé ou effacé manuellement, il existera toujours dans le navigateur

  • sessionStorage fonctionne comme. un cache de session. Le cycle de vie n'existe que lors de l'ouverture de la session du navigateur. Lorsque le navigateur est fermé, les informations seront perdues et les données seront toujours enregistrées en actualisant simplement la page.

Dans cet exemple, sessionStorage est utilisé et une petite encapsulation est effectuée.

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;

Exemple de code :

<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>

Apprentissage recommandé : tutoriel vue.js

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer