用Docker打包vue项目如何读取Docker环境变量?

需求,根据环境变量.vue打包不同接口?
我常规项目process.env.NODE_ENV就用这个,现在在Docker该怎么搞?

阅读 8.9k
2 个回答

在Vue里面环境变量必须由VUE_APP_ 开始

https://cli.vuejs.org/zh/guid...

你可以参考我的项目:

docker-compose.yml: https://gitlab.com/verbose-eq...

  frontend:
    container_name: frontend
    build:
      context: ./frontend
    volumes:
      - ./frontend:/app/
      - '/app/node_modules'
    ports:
      - "8080:8080"
    networks:
      - main
    depends_on:
      - backend
      - db
    environment:
      - NODE_ENV=development
      - VUE_APP_API_BASE_URL=http://localhost

api.js: https://gitlab.com/verbose-eq...

import axios from 'axios';

const apiCall = axios.create({
  baseURL: process.env.VUE_APP_API_BASE_URL,
});

export default apiCall;
docker run -e process.env.NODE_ENV=someValue --name container_name image
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题