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...")
})


相关文章
|
6月前
|
JavaScript 前端开发 应用服务中间件
【Vue面试题三十】、vue项目本地开发完成后部署到服务器后报404是什么原因呢?
这篇文章分析了Vue项目在服务器部署后出现404错误的原因,主要是由于history路由模式下服务器缺少对单页应用的支持,并提供了通过修改nginx配置使用`try_files`指令重定向所有请求到`index.html`的解决方案。
【Vue面试题三十】、vue项目本地开发完成后部署到服务器后报404是什么原因呢?
|
4月前
|
前端开发 JavaScript Java
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
121 4
|
4月前
|
关系型数据库 应用服务中间件 数据库
项目部署二:服务器和环境配置
项目部署二:服务器和环境配置
|
5月前
|
JavaScript 前端开发
vue配合axios连接express搭建的node服务器接口_简单案例
文章介绍了如何使用Express框架搭建一个简单的Node服务器,并使用Vue结合Axios进行前端开发和接口调用,同时讨论了开发过程中遇到的跨域问题及其解决方案。
89 0
vue配合axios连接express搭建的node服务器接口_简单案例
|
5月前
|
JavaScript Linux 开发工具
如何将nodejs项目程序部署到阿里云服务器上
该文章详细描述了将Node.js项目部署到阿里云服务器的步骤,包括服务器环境配置、项目上传及使用PM2进行服务管理的过程。
|
6月前
|
JavaScript 前端开发 UED
服务器端渲染新浪潮:用Vue.js和Nuxt.js构建高性能Web应用
【8月更文挑战第30天】在现代Web开发中,提升应用性能和SEO友好性是前端开发者面临的挑战。服务器端渲染(SSR)能加快页面加载速度并改善搜索引擎优化。Vue.js结合Nuxt.js提供了一个高效框架来创建SSR应用。通过安装`create-nuxt-app`,可以轻松创建新的Nuxt.js项目,并利用其自动路由功能简化页面管理。Nuxt.js默认采用SSR模式,并支持通过`asyncData`方法预取数据,同时提供了静态站点生成和服务器端渲染的部署选项,显著提升用户体验。
122 0
|
JavaScript 应用服务中间件 nginx
Vue项目部署问题及解决方案
Vue项目部署问题及解决方案 Vue-Router 有两种模式,默认是 hash 模式,另外一种是 history 模式。 hash:也就是地址栏里的 # 符号。比如 http://www.example/#/hello,hash 的值为 #/hello。
4432 0
|
2月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
139 1
|
1天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
29 12
|
18天前
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
48 8

热门文章

最新文章