> 웹 프론트엔드 > View.js > Vue가 TodoList를 캡슐화하는 방법

Vue가 TodoList를 캡슐화하는 방법

醉折花枝作酒筹
풀어 주다: 2021-04-22 09:40:44
앞으로
2323명이 탐색했습니다.

이 글에서는 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 tutorial

위 내용은 Vue가 TodoList를 캡슐화하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿