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>

效果图:

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

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

相关推荐
一只小阿乐3 小时前
react 封装弹框组件 传递数据
前端·javascript·react.js
533_3 小时前
[element-plus] el-tree 动态增加节点,删除节点
前端·javascript·vue.js
禁止摆烂_才浅3 小时前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
wshzd3 小时前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客3 小时前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
q***71854 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
一只小阿乐4 小时前
vue3 使用v-model开发弹窗组件
javascript·vue.js·elementui
web加加4 小时前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
A尘埃5 小时前
大模型应用python+Java后端+Vue前端的整合
java·前端·python
遥遥晚风点点5 小时前
Spark导出数据文件到HDFS
前端·javascript·ajax