IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vueCli2.0 和 vueCli3.0 项目中配置多环境运行打包 ? -> 正文阅读

[JavaScript知识库]vueCli2.0 和 vueCli3.0 项目中配置多环境运行打包 ?

本地 node 环境搭建?


  • ?本地安装?node

node 官网?下载并安装 node,安装步骤只需一路 next?即可,安装完成后,打开命令行工具输入 node -v ,若出现对应版本号则说明安装成功,输入 npm -v,显示 npm 版本信息。

  • 切换到淘宝镜像

当 node?环境安装完以后,由于 npm?包管理工具有些资源被堵,为了更快更稳定,需要切换到淘宝的 npm?镜像 cnpm 。输入如下命令进行安装和镜像切换,输入 cnpm -v ,可以查看当前 cnpm?版本用来检验安装是否成功?。

npm install -g cnpm --registry=https://registry.npm.taobao.org

vueCli2.0?中配置多环境运行打包


  • 安装 vue-cli2.0?

vue-cli?提供一个官方命令行工具,可用于快速搭建大型单页面应用。全局安装命令如下,这里脚手架安装的是指 vue-cli2.0?,命令中加 -g?则表示全局安装

cnpm i -g vue-cli
  • 基于 vue-cli2.0?新建项目

选定目录,命令行跳转到指定目录下,使用如下命令进行项目的创建 ,其中 my-project 为自定义项目名

vue init webpack my-project
// 或
vue init webpack-simple my-project

注意:这里是使用 vuecli2.0?新建项目的方法,目录结构和相关配置与 vuecli3.0?创建的项目不一致 。在 vuecli2.0?项目中存在 build?和 config?等配置目录,static?静态目录等 。而在 vuecli3.0?项目中将 webpack?配置项进行了高度融合,不在暴露出来,想要修改对应配置,需在根目录下新建 vue.config.js?文件中进行更改 。同时 vuecli3.0?也没有 build ,config,static?等目录

  • config?目录下新增文件

文件内容,如 ez.env.js?中 。

'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')

module.exports = merge(prodEnv, {
  NODE_ENV: '"ez"',
})
  • ?更改 package.json?文件

主要是更改文件中 scripts?模块?内容,修改如下 。

"scripts": {
    "dev-jz": "webpack-dev-server --env=jz --inline --progress --config build/webpack.dev.conf.js",
    "dev-ez": "webpack-dev-server --env=ez --inline --progress --config build/webpack.dev.conf.js",
    "dev-tm": "webpack-dev-server --env=tm --inline --progress --config build/webpack.dev.conf.js",
    "dev-hs": "webpack-dev-server --env=hs --inline --progress --config build/webpack.dev.conf.js",
    "dev-snj": "webpack-dev-server --env=snj --inline --progress --config build/webpack.dev.conf.js",
    "build-jz": "node build/build.js --env=jz",
    "build-ez": "node build/build.js --env=ez",
    "build-tm": "node build/build.js --env=tm",
    "build-snj": "node build/build.js --env=snj",
    "build-hs": "node build/build.js --env=hs"
 },
  • ?process.env.NODE_ENV?访问

通过?process.env,来判断当前模块的特有配置值,当运行 npm run dev-jz?或者 npm run build-jz?时,只会显示当前模块特有的配置值。还可以根据? process.env.NODE_ENV?属性来控制不同模块下的请求路径差异化,如示例 env?目录下文件。

main.js?中进行控制,在运行和打包当前模块的时候会读取当前模块请求路径等配置。?

const curEnv = process.env.NODE_ENV
let curEnvParam = require('../env/' + curEnv)
Vue.prototype.$globalEnv = {
  ...curEnvParam
};

?vueCli3.0?中配置多环境运行打包


  • 安装 vue-cli3.0?脚手架

安装 vue-cli3.0 ,可以使用下列任一命令安装此依赖包。注意:vue Cli?需要 Node?要 8.9?或者更高版本?

npm i -g @vue/cli
// 或者
yarn global add @vue/cli
  • 基于 vue-cli3.0 新建项目

打开终端,切换到目标目录下,输入如下?命令?进行项目新建。同时还可以使用?可视化面板?方式来新建项目,安装依赖。

// 命令行
vue create my-demo
// 面板
vue ui
  • 根目录下新建 .env.xx?文件

?文件内容,如 .env.hs?中 。

NODE_ENV = 'hs'
enableFaceID: true
  • 更改 package.json?文件

主要是更改文件中 scripts?模块?内容,修改如下 。

  "scripts": {
        "dev-jz": "vue-cli-service serve --mode jz",
        "dev-ez": "vue-cli-service serve --mode ez",
        "dev-tm": "vue-cli-service serve --mode tm",
        "dev-hs": "vue-cli-service serve --mode hs",
        "dev-snj": "vue-cli-service serve --mode snj",
        "build-jz": "vue-cli-service build --mode jz",
        "build-ez": "vue-cli-service build --mode ez",
        "build-tm": "vue-cli-service build --mode tm",
        "build-snj": "vue-cli-service build --mode snj",
        "build-hs": "vue-cli-service build --mode hs"
    },
  • vue.config.js?文件?

后续部分和 vuecli2.0?方式一致,需要注意的是,在 vuecli3.0?项目中由于将复杂的配置不在暴露,打包?时为了确保访问?静态资源路径正确,根目录下新增 vue.config.js?配置文件,进行根路径的相关配置 。

module.exports = {
    publicPath: "./", // 基本路径,可以设置成相对路径,这样所有的资源都会被链接为相对路径,打出来的包可以被部署在任意路径
    outputDir: "dist", //打包时生成的生产环境构建文件的目录
    assetsDir: 'public', // 放置生成的静态资源 (js、css、img、fonts) 的 (相对于 outputDir 的) 目录
    /*devServer: {
        proxy: 'http://localhost:8080'
    }*/
}

完整示例链接:vue-Cli-2.0: vue-Cli2.0 和 vue-Cli3.0 项目中多模式运行打包等配置示例

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-12 23:20:30  更:2021-10-12 23:21:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 0:05:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码