12、vue项目部署到服务器

简介: 12、vue项目部署到服务器

1、配置文件


  • 我们写Vue项目与后台数据交互是跨域的,vue项目部署到服务器之后就不是跨域的,需要修改路径(开发环境一个路径,生产环境又是另一个路径),所以就要配置以下两个文件,一起进行打包


配置文件
开发环境 .env.development
生产环境 .env.production


注意:命名变量必须以VUE_APP_XXX命名


.env.development文件:


VUE_APP_BASE_URL="http://127.0.0.1:3000"


.env.production文件:


VUE_APP_BASE_URL=""


APP.vue:


<script>
import axios from "axios";
export default {
  created() {
    this.getUserList();
  },
  methods: {
    // 1、获取用户列表
    getUserList() {
      axios.get(`${process.env.VUE_APP_BASE_URL}/user/`).then((res) => {
        this.userList = res.data;
      });
    },
    // 2、删除用户信息
    del(id) {
      this.$confirm("此操作将永久删除该文件, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        // 删除成功
        .then(() => {
          axios
            .delete(`${process.env.VUE_APP_BASE_URL}/user/${id}`)
            .then(() => {
              this.getUserList();
            });
          this.$message({
            type: "success",
            message: "删除成功!",
          });
        })
        // 删除失败
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
    // 3、添加用户信息
    add() {
      axios
        .post(`${process.env.VUE_APP_BASE_URL}/user/`, {
          user: this.userAddForm,
        })
        .then(() => {
          this.getUserList();
          this.dialogVisible = false;
          this.$message({
            type: "success",
            message: "添加成功!",
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消添加",
          });
        });
    },
  },
  data() {
    return {
      // 显示用户信息
      userList: [],
      // 添加用户信息弹出框按钮
      dialogVisible: false,
      // 添加用户信息表单
      userAddForm: { id: "", name: "", age: "" },
    };
  },
};
</script>


2、vue项目打包( npm run build


  • 打包之后会生成dist文件,里面的静态资源就打包好了


11b139c299ca47d8a5294f0b319cba4e.png


3、把打包好的文件放到服务器的public文件夹中,运行服务器即可


667d0ae29f674231aec7eba9db5d43da.png


server.js:

const Koa = require('koa');
// 获取post请求数据
const parser = require('koa-parser');
// 设置路由
const Router = require('koa-router')
const router = new Router();
// 允许跨域
const cors = require("koa2-cors");
// 引入静态文件
const static = require("koa-static");
const app = new Koa();
// 引入中间键
app.use(cors({
  origin: function (ctx) {
    var allowCors = ['http://localhost:8080', 'http://localhost:8081'];
    return allowCors.indexOf(ctx.header.origin) > -1 ? ctx.header.origin : '';
  },
  exposeHeaders: ['WWW-Authenticate', 'Server-Authorization'],
  maxAge: 5,
  credentials: true,
  allowMethods: ['GET', 'POST', 'DELETE'],
  allowHeaders: ['Content-Type', 'Authorization', 'Accept'],
}))
app.use(parser());
app.use(router.routes());
app.use(static(__dirname + "/public"));
// 模拟数据
const userList = [
  { id: 1, name: "jasmine", age: 18 },
  { id: 2, name: "qiqi", age: 20 },
  { id: 3, name: "jasmine_qiqi", age: 22 },];
// get方法:获取userList列表
router.get("/user", async ctx => {
  ctx.body = userList;
})
// post方法:添加user信息
router.post("/user", async ctx => {
  // request:请求响应数据
  let user = ctx.request.body.user;
  userList.push(user);
  ctx.body = true;
})
// put方法:修改数据
router.put("/user/:id", ctx => {
  let index = ctx.params.id;
  let user = ctx.request.body.user;
  userList.splice(index, 1, user);
  // splice(要删除元素的索引,删除几个元素,将删除的元素替换)
  ctx.body = userList;
})
// delete方法:删除user信息列表
router.delete("/user/:id", async ctx => {
  let id = ctx.params.id;
  userList.map((value, index) => {
    if (value.id == id) {
      userList.splice(index, 1);
    }
  })
  ctx.body = true;
})
app.listen(3000, () => {
  console.log("server is running...")
})


相关文章
|
2月前
|
JavaScript 搜索推荐 UED
描述 Vue 的服务器端渲染(SSR)。
描述 Vue 的服务器端渲染(SSR)。
23 3
|
17天前
|
JavaScript 前端开发 UED
Vue工具和生态系统: Vue.js和服务器端渲染(SSR)有关系吗?请解释。
Vue.js是一个渐进式JavaScript框架,常用于开发单页面应用,但其首屏加载较慢影响用户体验和SEO。为解决此问题,Vue.js支持服务器端渲染(SSR),在服务器预生成HTML,加快首屏速度。Vue.js的SSR可手动实现或借助如Nuxt.js的第三方库简化流程。Nuxt.js是基于Vue.js的服务器端渲染框架,整合核心库并提供额外功能,帮助构建高效的应用,改善用户体验。
15 0
|
22天前
|
关系型数据库 MySQL 数据库连接
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
75 11
|
1月前
|
JavaScript API
本地开发环境请求服务器接口跨域的问题(vue的问题)
本地开发环境请求服务器接口跨域的问题(vue的问题)
18 1
|
2月前
|
Linux Docker Python
如何将本地的python项目部署到linux服务器中
如何将本地的python项目部署到linux服务器中
108 1
|
2月前
|
前端开发 NoSQL 关系型数据库
服务器项目部署总结(超详细)
服务器项目部署总结(超详细)
|
2月前
|
NoSQL 关系型数据库 应用服务中间件
Linux服务器软件安装教程及项目部署【建议收藏】
Linux服务器软件安装教程及项目部署【建议收藏】
|
4月前
|
Java Maven Docker
SpringBoot项目打包部署到阿里云服务器、通过Maven插件制作Docker镜像、部署项目容器、配置生产环境
SpringBoot项目打包部署到阿里云服务器、通过Maven插件制作Docker镜像、部署项目容器、配置生产环境
139 0
|
3天前
|
存储 弹性计算 固态存储
阿里云服务器CPU内存配置详细指南,如何选择合适云服务器配置?
阿里云服务器配置选择涉及CPU、内存、公网带宽和磁盘。个人开发者或中小企业推荐使用轻量应用服务器或ECS经济型e实例,如2核2G3M配置,适合低流量网站。企业用户则应选择企业级独享型ECS,如通用算力型u1、计算型c7或通用型g7,至少2核4G配置,公网带宽建议5M,系统盘可选SSD或ESSD云盘。选择时考虑实际应用需求和性能稳定性。
|
5天前
|
域名解析 弹性计算 Linux
阿里云购买云服务器、注册域名、备案及绑定图文教程参考
本文为大家介绍了2024年购买阿里云服务器和注册域名,绑定以及备案的教程,适合需要在阿里云购买云服务器、注册域名并备案的用户参考,新手用户可通过此文您了解在从购买云服务器到完成备案的流程。
阿里云购买云服务器、注册域名、备案及绑定图文教程参考