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

Comment Vue encapsule une TodoList

醉折花枝作酒筹
Libérer: 2021-04-22 09:40:44
avant
2323 Les gens l'ont consulté

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;
Copier après la connexion

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>
Copier après la connexion

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!

Étiquettes associées:
source:csdn.net
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal