1、components/Login.vue
html<template> <div class="common-layout"> <el-container> <el-header height="120px"> </el-header> <el-container> <el-aside width="36%"> </el-aside> <el-container> <el-main> <el-form :model="form" label-width="120px"> <el-form-item label="用户名:"> <el-input v-model="form.username" input-style="width:200px"/> </el-form-item> <el-form-item label="密  码:"> <el-input v-model="form.userPwd" type="password" placeholder="Please input password" show-password input-style="width:200px" /> </el-form-item> <el-form-item> <el-button type="primary" @click="doLogin">登录</el-button> <el-button>注册</el-button> </el-form-item> </el-form> </el-main> <el-footer> </el-footer> </el-container> </el-container> </el-container> </div> </template> <script lang="ts" setup> import {reactive} from 'vue' const form = reactive({ username: 'lina', userPwd: '123456', }) </script>2、App.vue
html<template> <div> <!--路由的出口--> <router-view/> </div> </template>3、安装路由器Vue Router,添加依赖
htmlnpm install vue-router@44、 package.json
javascript{ "name": "pro20-schedule", "private": true, "version": "0.0.0", "type": "module", "scripts": { "dev": "vite", "build": "vite build", "preview": "vite preview" }, "dependencies": { "axios": "^1.6.2", "element-plus": "^2.4.2", "vue": "^3.3.8", "vue-router": "^4.2.5" }, "devDependencies": { "@vitejs/plugin-vue": "^4.5.0", "vite": "^5.0.0" } }5、router/router.js
javascriptimport {createRouter, createWebHistory} from "vue-router"; import Login from "../src/components/Login.vue"; import Index from "../src/components/index.vue"; let router=createRouter({ history: createWebHistory(), routes:[ { path:'/', component:Login }, { path:'/login', redirect:'/' }, { path:'/index', component: Index, } ] }) export default router;6、main.js
javascriptimport { createApp } from 'vue' import App from './App.vue' import ElementPlus from 'element-plus' import 'element-plus/dist/index.css' import zhCn from 'element-plus/dist/locale/zh-cn.mjs' import router from "./router/router.js"; let app = createApp(App); app.use(router) app.use(ElementPlus, { locale: zhCn, }) app.mount('#app')7、createWebHistory()
在 Vue Router 4(Vue3的路由库)中,
createWebHistory()是一个工厂函数,用于创建一个 HTML5 history 对象。这个对象允许你在单页面应用(SPA)中管理浏览器的历史记录。具体来说,
createWebHistory()函数的作用是创建一个基于 HTML5 History API 的历史管理对象。这个对象有两个主要的方法:push和replace,分别对应于浏览器历史记录的前进和替换操作。
push方法:当你想要导航到一个新的页面时,你可以调用push方法,并传入一个表示新页面路径的字符串。这会在浏览器历史记录中添加一个新的记录,并且浏览器的地址栏会显示新的地址。replace方法:如果你不想在当前浏览器历史记录中添加一个新的记录,而是想要替换掉当前的记录,你可以使用replace方法。这在你初始化应用或者处理重定向时很有用。使用
createWebHistory()创建的历史对象,Vue Router 会自动处理 URL 的变化和导航。这意味着,当你的应用中的路由变化时,Vue Router 会自动更新浏览器的地址栏,并且当你的用户在浏览器中点击前进或后退按钮时,Vue Router 会自动导航到正确的页面。以下是一个简单的示例:
javascriptimport { createRouter, createWebHistory } from 'vue-router' const router = createRouter({ history: createWebHistory(), routes: [ // your routes here ], })在这个示例中,我们创建了一个使用 HTML5 history 模式的 Vue Router 实例。这意味着当用户导航到不同的页面时,浏览器的地址栏会显示新的 URL,并且用户可以使用浏览器的前进和后退按钮来导航。
SSM项目实战-编写路由规则以及登录页面实现,使用Vue3+Vite+Element-Plus+Axios技术
丁总学Java2023-12-07 8:32
相关推荐
2501_920931704 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航0思必得05 小时前
[Web自动化] Selenium处理动态网页东东5166 小时前
智能社区管理系统的设计与实现ssm+vuecatino6 小时前
图片、文件的预览2501_920931707 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜layman05288 小时前
webpack5 css-loader:从基础到原理半桔8 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典AI老李8 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法_OP_CHEN8 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!啊哈一半醒8 小时前
CSS 主流布局