How to switch between Vue production and development environments and use filters

How to switch between Vue production and development environments and use filters

1. Switch between production environment and development environment

Development environment: The development environment is to configure proxyTable under /config/index.js
Production environment: The proxy becomes invalid after the project is packaged, so it needs to be reconfigured in the production environment

The first method: by configuring the .env file

Reference: https://cli.vuejs.org/zh/guide/mode-and-env.html

Second method

Step 1: Create different environment js files and switch them through cross-env

 config
    dev.js    
    prod.js
  
dev.js
module.exports = {
  BASE_URL: "https://test.365msmk.com"
};

prod.js

module.exports = {
  BASE_URL: "https://www.365msmk.com"
};

Step 2: Install cross-env and configure the parameters to be passed in package.json

Installation instructions: npm install cross-env -D

Configuration in package.json

"scripts": {
    "serve": "cross-env BUILD_ENV=dev vue-cli-service serve",
    "build": "cross-env BUILD_ENV=prod vue-cli-service build"
  }

Step 3: Modify vue.config.js to add configuration for webpack

module.exports = {
 .....
  chainWebpack: config => {
    config.plugin("define").tap(args => {
      args[0]['process.env'].BUILD_ENV = JSON.stringify(process.env.BUILD_ENV);
      return args;
    });
  }
};

Switch the environment in the business code

//Read BUILD_ENV in the process.env constant object
const envType = process.env.BUILD_ENV;

const urlObj = require(`../config/${envType}.js`);

//Create an axios instance const service = axios.create({
  baseURL: urlObj.BASE_URL + vipUrl
});

2. Filters

1. Global filter definition:

Vue.filter('filter name',function(a,b,c) {
  //....
  
 return ...

})

use:

{{ num | filter name (v1, v2) }}

2. Local filter

3. Summary: Filter usage scenarios: used to process background data into the data format that users will eventually display

For example: gender, payment status, logistics status, timestamp. . . . . .

3. Use of moment time library

moment official website: momentjs.cn/docs/

Installation instructions: npm i moment

Format: moment(timestamp).format("YYYY year MM month DD day, HH hour mm minute SS second");

Format display: http://momentjs.cn/docs/#/displaying/

I am currently working hard to learn the development environment and production environment, summarizing every day, making progress every day, and becoming a leader in the IT industry as soon as possible.

This concludes this article on how to switch between Vue production and development environments and the use of filters. For more information on switching between Vue production and development environments, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue global environment switching problem

<<:  MySQL 8.0.17 decompression version installation and configuration method graphic tutorial

>>:  Steps to install RocketMQ instance on Linux

Recommend

Detailed explanation of MySQL backup and recovery practice of mysqlbackup

1. Introduction to mysqlbackup mysqlbackup is the...

MySQL Error 1290 (HY000) Solution

I struggled with a problem for a long time and re...

JavaScript Html to implement the mobile red envelope rain function page

This article example shares the specific code of ...

Vue implements sample code to disable browser from remembering password function

Find information Some methods found on the Intern...

Analysis of Context application scenarios in React

Context definition and purpose Context provides a...

Analysis of the cause of docker error Exited (1) 4 minutes ago

Docker error 1. Check the cause docker logs nexus...

Windows system mysql5.7.18 installation graphic tutorial

MySQL installation tutorial for Windows system do...

Trash-Cli: Command-line Recycle Bin Tool on Linux

I believe everyone is familiar with the trashcan,...

MySQL restores data through binlog

Table of contents mysql log files binlog Binlog l...

Problems and solutions of using jsx syntax in React-vscode

Problem Description After installing the plugin E...