手把手教Vue+elementUI搭建后台管理系统(四):自定义项目配置文件

本文介绍了如何在Vue项目中自定义配置文件vue.config.js,包括修改默认端口号、关闭ESLint、理解不同模式与环境变量配置,以及开发和生产环境的环境变量设置,通过.env.development和.env.production文件实现环境差异化配置。
摘要由CSDN通过智能技术生成
项目配置文件

【vue-cli 配置文件官方地址:】
https://cli.vuejs.org/zh/config

具体配置本文就不详细赘述了,vue相关官网说明是我见过唯一一个比书本还好的官方说明;想了解详细配置的,可以直接访问vue-cli的配置文件学习下。我们只配置项目流程中使用到的。

项目配置文件使用

首先需要在 项目的根目录下 创建一个 vue.config.js。填写如下内容,使用 json 格式进行配置。配置文件各属性可以自行查阅官方文档。
在这里插入图片描述

修改默认端口号

项目默认 使用 8080 端口访问项目,当 8080 被占用时,会自动选择新的端口打开。可以自定义端口访问,如下定义端口为 9527。

module.exports = {
    devServer: {
        port: 9527
    }
}

在这里插入图片描述
在这里插入图片描述

选择性关闭ESLint

因为我们之前在装脚手架的时候是装上了ESLint包的,ESLint可以统一代码规范,没有按照一定的规则编写代码,会有报错的情况,用不习惯的人可以给配置关掉。配置如下:
在这里插入图片描述

模式和环境变量配置
模式

模式是 Vue CLI 项目中一个重要的概念。默认情况下,一个 Vue CLI 项目有三个模式:

development 模式用于 vue-cli-service serve
test 模式用于 vue-cli-service test:unit
production 模式用于 vue-cli-service build 和 vue-cli-service test:e2e

你可以通过传递 --mode 选项参数为命令行覆写默认的模式。例如,如果你想要在构建命令中使用开发环境变量:

vue-cli-service build --mode development

当运行 vue-cli-service 命令时,所有的环境变量都从对应的环境文件中载入。如果文件内部不包含 NODE_ENV 变量,它的值将取决于模式,例如,在 production 模式下被设置为 “production”,在 test 模式下被设置为 “test”,默认则是 “development”。

NODE_ENV 将决定您的应用运行的模式,是开发,生产还是测试,因此也决定了创建哪种 webpack 配置。

例如通过将 NODE_ENV 设置为 “test”,Vue CLI 会创建一个优化过后的,并且旨在用于单元测试的 webpack 配置,它并不会处理图片以及一些对单元测试非必需的其他资源。

同理,NODE_ENV=development 创建一个 webpack 配置,该配置启用热更新,不会对资源进行 hash 也不会打出 vendor bundles,目的是为了在开发的时候能够快速重新构建。

当你运行 vue-cli-service build 命令时,无论你要部署到哪个环境,应该始终把 NODE_ENV 设置为 “production” 来获取可用于部署的应用程序。

注意:

NODE_ENV
如果在环境中有默认的 NODE_ENV,你应该移除它或在运行 vue-cli-service 命令的时候明确地设置 NODE_ENV。

环境变量

我们可以在你的项目根目录中放置下列文件来指定环境变量:

.env                # 在所有的环境中被载入
.env.local          # 在所有的环境中被载入,但会被 git 忽略
.env.[mode]         # 只在指定的模式中被载入
.env.[mode].local   # 只在指定的模式中被载入,但会被 git 忽略

一个环境文件只包含环境变量的“键=值”对:

FOO=bar
VUE_APP_NOT_SECRET_CODE=some_value

环境文件加载优先级
为一个特定模式准备的环境文件 (例如 .env.production) 将会比一般的环境文件 (例如 .env) 拥有更高的优先级。

此外,Vue CLI 启动时已经存在的环境变量拥有最高优先级,并不会被 .env 文件覆写。

.env 环境文件是通过运行 vue-cli-service 命令载入的,因此环境文件发生变化,你需要重启服务。

项目生产和开发环境配置

在当前项目的根目录下,创建 两个文件(.env.development、.env.production)。
其中:
  .env.development 是开发环境会加载的文件,即 npm run serve 时,会加载 .env.development。
  .env.production 是生产环境会加载的文件(打包后的文件),即 npm run build 时,会加载 .env.production。

在这里插入图片描述
接下来我们来测试下配置文件是否正确,我们分别配置下这两个文件,让开发环境和生产环境的程序运行起来看看效果。
给 .env.development 添加一个变量。命名规则: VUE_APP_ + 变量名 :

VUE_APP_URL=http://localhost:9527

在这里插入图片描述

也给 .env.production 添加一个变量。

VUE_APP_URL=http://localhost:9090

在这里插入图片描述

我们运行npm run build来打包下项目,根目录下生成了dist目录。
在这里插入图片描述
打包完成后,我们需要使用服务器启动才能访问dist里面的程序,如下操作:
全局安装 serve:

  npm install -g serve

运行程序:

进入 dist 目录,输出 serve
或者 直接 serve -s dist路径,比如 serve -s E:\vue\front\dist

运行效果如下,项目能正常跑起来:
在这里插入图片描述
配置中,除了走不同的端口外,开发环境和生产环境跑出来的程序效果一样。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为您提供一些基本的步骤: 1.创建一个 Vue 项目 您可以使用 Vue CLI 创建一个新的 Vue 项目: ``` vue create my-project ``` 2.安装 Element UI 使用 npm 或者 yarn 安装 Element UI: ``` npm install element-ui -S ``` 或者 ``` yarn add element-ui ``` 3.在 main.js 中引入 Element UI 在 main.js 中引入 Element UI 的 CSS 和 JS 文件: ```javascript import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` 4.创建一个基础布局 可以使用 Element UI 提供的布局组件来创建一个基础的后台管理系统布局: ```html <template> <div class="app-container"> <el-container> <el-header> <!-- Header content --> </el-header> <el-container> <el-aside> <!-- Sidebar content --> </el-aside> <el-main> <!-- Main content --> </el-main> </el-container> <el-footer> <!-- Footer content --> </el-footer> </el-container> </div> </template> <script> export default { name: 'App', data () { return { // ... } }, methods: { // ... } } </script> <style> .app-container { height: 100%; } </style> ``` 5.添加路由 使用 Vue Router 添加路由,以便在后台管理系统中切换页面: ```javascript import Vue from 'vue' import Router from 'vue-router' Vue.use(Router) export default new Router({ mode: 'history', routes: [ { path: '/', name: 'home', component: Home }, { path: '/about', name: 'about', component: About } ] }) ``` 6.创建页面组件 创建页面组件并在路由中使用它们: ```html <template> <el-container> <el-header> <!-- Header content --> </el-header> <el-container> <el-aside> <!-- Sidebar content --> </el-aside> <el-main> <h1>{{ title }}</h1> <p>{{ content }}</p> </el-main> </el-container> <el-footer> <!-- Footer content --> </el-footer> </el-container> </template> <script> export default { name: 'Home', data () { return { title: 'Home page', content: 'Welcome to the home page!' } }, methods: { // ... } } </script> ``` 7.添加导航菜单 使用 Element UI 的导航菜单组件创建一个侧边栏导航菜单: ```html <template> <el-container> <el-aside> <el-menu :default-active="activeIndex" class="el-menu-vertical-demo" @select="handleSelect"> <el-menu-item index="/"> <i class="el-icon-location"></i> <span slot="title">Home</span> </el-menu-item> <el-menu-item index="/about"> <i class="el-icon-menu"></i> <span slot="title">About</span> </el-menu-item> </el-menu> </el-aside> <el-container> <el-main> <router-view></router-view> </el-main> </el-container> </el-container> </template> <script> export default { name: 'App', data () { return { activeIndex: '/' } }, methods: { handleSelect (index) { this.activeIndex = index } } } </script> ``` 这样就可以创建一个基本的后台管理系统,您可以根据需要添加更多页面和功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

longerJue

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值