vue3-登录小案例(借助ElementPlus+axios)

1.创建一个vue3的项目。

复制代码
npm create vue@latest

2.引入Elementplus组件库

链接:安装 | Element Plus

复制代码
npm install element-plus --save

在main.js中引入

复制代码
import ElementPlus from "element-plus";

import "element-plus/dist/index.css";

app.use(ElementPlus);

3.开始渲染页面

引入axios

链接:POST 请求 | Axios中文文档 | Axios中文网

引入步骤:

1.导入

复制代码
import axios from "axios";

2.调用axios.post

复制代码
const SubmitEvent = async () => {
  const { data } = await axios.post(
    "https://v5.crmeb.net/api/login",
    {
      account: acc.value,
      password: pwd.value,
    },
    {
      headers: {
        "Content-Type": "application/json",
      },
    }
  );

具体实现代码如下:

复制代码
<template>
  <div>
    <div class="box">
      <br />
      <el-input
        v-model="acc"
        style="width: 240px"
        placeholder="Please input"
        clearable
      />
      <br />
      <br />
      <el-input
        v-model="pwd"
        style="width: 240px"
        type="password"
        placeholder="Please input password"
        show-password
      />
      <br /><br />
      <el-button @click="SubmitEvent" type="primary" style="width: 240px"
        >login</el-button
      >
    </div>
  </div>
</template>

<style>
.box {
  width: 300px;
  height: 300px;
  background-color: antiquewhite;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
</style>

<script setup>
import { ref } from "vue";
import { ElMessage } from "element-plus";
import axios from "axios";
import { useRouter } from "vue-router";
const router = useRouter();
const acc = ref("");
const pwd = ref("");
const SubmitEvent = async () => {
  const { data } = await axios.post(
    "https://v5.crmeb.net/api/login",
    {
      account: acc.value,
      password: pwd.value,
    },
    {
      headers: {
        "Content-Type": "application/json",
      },
    }
  );
  if (data.status == 200) {
    ElMessage({
      message: "登录成功",
      type: "success",
    });
    // 保存到本地
    localStorage.setItem("token", data.data.token);
    // 跳转
    router.replace({
      name: "about",
    });
  } else {
    ElMessage.error("登录失败");
    acc.value = "";
    pwd.value = "";
  }
};
</script>

效果图:

输入信息错误会清空数据并提示登录失败:

输入信息正确会跳转到另外一个页面并提示登录成功:

相关推荐
moshuying8 小时前
别让AI焦虑,偷走你本该有的底气
前端·人工智能
GIS之路9 小时前
ArcPy,一个基于 Python 的 GIS 开发库简介
前端
可夫小子10 小时前
OpenClaw基础-为什么会有两个端口
前端
喝拿铁写前端10 小时前
Dify 构建 FE 工作流:前端团队可复用 AI 工作流实战
前端·人工智能
喝咖啡的女孩11 小时前
React 合成事件系统
前端
从文处安11 小时前
「九九八十一难」组合式函数到底有什么用?
前端·vue.js
前端Hardy11 小时前
面试官:JS数组的常用方法有哪些?这篇总结让你面试稳了!
javascript·面试
用户59625857360611 小时前
戴上AI眼镜逛花市——感受不一样的体验
前端
yuki_uix11 小时前
Props、Context、EventBus、状态管理:组件通信方案选择指南
前端·javascript·react.js
老板我改不动了11 小时前
前端面试复习指南【代码演示多多版】之——HTML
前端