vue3 + element-plus 前端框架搭建

前言

来啦老铁!

前端框架 vue 已经到 vue3 版本了,今天我们一起来学习记录一下怎么将 vue3 前端框架搭建起来,其中组件库我会用到熟悉的 Element 家族的 element-plus 组件库;

学习路径

  1. 安装脚手架;
  2. 创建 vue 项目;
  3. 安装依赖;
  4. 使用 typescript;
  5. 修改项目;
  6. 业务开发;

1. 安装脚手架;

yarn global add @vue/cli
  • 检查安装成功与否:
vue -V
安装脚手架

2. 创建 vue 项目;

vue create math-games
创建 vue 项目
注意:这时候选择 vue3,然后跟随脚手架的指示进行项目的创建即可~

3. 安装依赖;

  • element-plus 模块;
yarn add element-plus
  • vue-router 模块;
yarn add vue-router
  • axios 模块,用于前后端交互;
yarn add axios

4. 使用 typescript;

由于笔者习惯使用带类型的 js 即 typescript,因此需要这个步骤;

vue add typescript

全部选择 Y/y 即可,最终会帮我们把所有 js 文件改为 ts 文件;

5. 修改项目;

  • 修改 App.vue
<template>
  <div id="app">
    <router-view></router-view>
  </div>
</template>

<script>
export default {
  name: "App",
  components: {},
};
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 5px;
}
</style>
  • 修改 main.ts
import { createApp } from "vue";
import ElementPlus from "element-plus";
import "element-plus/dist/index.css";
import App from "./App.vue";
import * as ElIcon from "@element-plus/icons-vue";
import router from "./router/index";

const app = createApp(App);

// 注册全局组件: icons
Object.keys(ElIcon).forEach((key) => {
  app.component(key, ElIcon[key as keyof typeof ElIcon]);
});
router.beforeEach((to: any, from: any, next) => {
  if (to.meta.title) {
    document.title = to.meta.title;
  }
  next();
});
app.use(ElementPlus);
app.use(router);
app.mount("#app");
  • 创建 src/router/index.ts
// 1. 引入创建路由需要的组件
import { createRouter, createWebHashHistory } from "vue-router";

// 2. 配置系统所有路由页面
const routes = [
  {
    path: "/",
    name: "home",
    component: () => import("../components/HomePage.vue"),
    meta: { title: "小学生数学游戏" },
    children: [],
  },
];

// 3. 创建路由实例
const router = createRouter({
  history: createWebHashHistory(),
  routes,
});

// 4. 声明, 为路由提供外部引用的入口
export default router;

  • 验证 element-plus 是否配置正确;

修改 src/components/HomePage.vue(这个文件也是先前自己创建的):

<template>
  <div>
    <el-button type="primary" @click="test" plain>刷新</el-button>
  </div>
</template>
<script>
export default {
  name: "HomePage",
  components: {},
  data() {
    return {};
  },
  created() {},
  methods: {
    test() {
      window.location.reload();
    },
  },
};
</script>

如下图就说明 element-plus 可以正常使用了~

element-plus 生效
  • 6. 业务开发;

如此,我们就可以进行业务开发了~

  • 在业务开发之前,我们还可以创建一个(或根据业务情况创建多个)请求的拦截器 src/utils/request.ts
import axios from "axios";
import { ElMessage } from "element-plus";

// 创建 axios 实例
const service = axios.create({
    baseURL: "http://localhost:80", // api的base_url
    timeout: 10000, // 请求超时时间
});

// request 拦截器
/*
service.interceptors.request.use(config => {
  if (store.getters.token) {
    config.headers['X-Token'] = getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
  }
  return config
}, error => {
  // Do something with request error
  console.log(error) // for debug
  Promise.reject(error)
})
*/

// respone 拦截器
service.interceptors.response.use(
    (response: { data: any; }) => {
        /**
         * code为非200是抛错 可结合自己业务进行修改
         */
        const res = response.data;
        if (res.code >= 400 && res.code < 500) {
            ElMessage({
                message: res.message,
                type: "error",
                duration: 5 * 1000,
            });
        }
        return res;
    },
    (error: { message: any; }) => {
        ElMessage({
            message: `服务错误:${error.message}`,
            type: "error",
            duration: 5 * 1000,
        });
        return Promise.reject(error);
    }
);

export default service;

  • 接着创建一个请求后端的 API 管理文件 src/api/game.ts
import request from "../utils/request";

export function randomizeGame() {
  return request({
    url: "/game/randomize",
    method: "post",
  });
}

export function getCalculationAnswer(userId:number, questionId: number) {
  return request({
    url: "/game/calculation/answer",
    method: "get",
    params: { userId, questionId },
  });
}

后续我们就可以在 .vue 文件中调用 src/api/game.ts 内的接口与后端进行交互了~

差不多就这样了,笔者不是专业的前端开发,能力有限,欢迎指正、互相交流,感谢~

如果本文对您有帮助,麻烦点赞、关注!

感谢~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,458评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,030评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,879评论 0 358
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,278评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,296评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,019评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,633评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,541评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,068评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,181评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,318评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,991评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,670评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,183评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,302评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,655评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,327评论 2 358

推荐阅读更多精彩内容