1、创建vue3的项目
(1)创建
vue create vue3_chen_multipage_test
(2)选择manual
(3)选项多选一些吧,哈哈
(4)后续一路回车
2、Keeplive的使用
(1)修改app.vue
注意使用了 :key="$route.name"
<template>
<nav>
<router-link to="/">Home</router-link> |
<router-link to="/about">About</router-link>
</nav>
<!-- <router-view/> -->
<!-- vue3.0配置 Component是固定写法-->
<router-view v-slot="{ Component }">
<keep-alive>
<component :is="Component" :key="$route.name" v-if="$route.meta.keepAlive"/>
</keep-alive>
<component :is="Component" :key="$route.name" v-if="!$route.meta.keepAlive"/>
</router-view>
</template>
(2)修改HomeView.vue
主要是添加了一个input测试一下
<template>
<div class="home">
<img alt="Vue logo" src="../assets/logo.png">
需要部分刷新的数据:<input type="text" v-model="newStr" />
<HelloWorld msg="Welcome to Your Vue.js + TypeScript App"/>
</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import HelloWorld from '@/components/HelloWorld.vue'; // @ is an alias to /src
import {ref} from 'vue'
export default defineComponent({
name: 'HomeView',
components: {
HelloWorld,
},
setup(){
let newStr = ref('');
return {
newStr
}
}
});
</script>
(3)修改AboutView
主要是添加了一个input测试一下
<template>
<div class="about">
<h1>This is an about page</h1>
about需要部分刷新的数据:<input type="text" v-model="aboutStr" />
</div>
</template>
<script lang="ts">
import {ref} from 'vue'
export default {
name: 'AboutView',
setup(){
let aboutStr = ref('');
return {
aboutStr,
}
}
}
</script>
(4)修改router
主要是添加了keepAlive: true
import { createRouter, createWebHistory, RouteRecordRaw } from 'vue-router'
import HomeView from '../views/HomeView.vue'
const routes: Array<RouteRecordRaw> = [
{
path: '/',
name: 'home',
component: HomeView,
meta:{
keepAlive: true
}
},
{
path: '/about',
name: 'about',
// route level code-splitting
// this generates a separate chunk (about.[hash].js) for this route
// which is lazy-loaded when the route is visited.
component: () => import(/* webpackChunkName: "about" */ '../views/AboutView.vue'),
meta:{
keepAlive: true
}
}
]
const router = createRouter({
history: createWebHistory(process.env.BASE_URL),
routes
})
export default router
3、测试一下页面的保存
(1)
(2)