首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >升级到v5后Vue CLI HMR不工作

升级到v5后Vue CLI HMR不工作
EN

Stack Overflow用户
提问于 2022-03-14 18:42:16
回答 1查看 999关注 0票数 1

我正在使用Django+Vue开发工具(Docker)开发一个VSCode应用程序。

最近,我从Vue CLI v4迁移到了迁移指南之后的Vue CLI v5。

迁移后,dev-server的HMR停止工作.

这是迁移之前的vue.config.js

代码语言:javascript
复制
const BundleTracker = require("webpack-bundle-tracker");

module.exports = {
  publicPath: process.env.NODE_ENV === "development" ? "http://localhost:8080/" : "/static/",
  devServer: {
    host: "0.0.0.0",
    port: 8080,
    public: "0.0.0.0:8080",
    https: false,
    headers: { "Access-Control-Allow-Origin": ["*"] },
    hotOnly: true,
    watchOptions: {
      ignored: "./node_modules/",
      aggregateTimeout: 300,
      poll: 1000,
    },
  },
  transpileDependencies: ["vuetify"],
  css: {
    sourceMap: true,
  },
  chainWebpack: (config) => {
    config.plugin("BundleTracker").use(BundleTracker, [
      {
        filename: `./config/webpack-stats-${process.env.NODE_ENV}.json`,
      },
    ]);
    config.resolve.alias.set("__STATIC__", "static");
  },
};

及之后:

代码语言:javascript
复制
const { defineConfig } = require("@vue/cli-service");
const BundleTracker = require("webpack-bundle-tracker");

module.exports = defineConfig({
  publicPath: process.env.NODE_ENV === "development" ? "http://localhost:8080/" : "/static/",
  devServer: {
    host: "0.0.0.0",
    port: 8080,
    client: {
      webSocketURL: "auto://0.0.0.0:8080/ws",
    },
    https: false,
    headers: { "Access-Control-Allow-Origin": ["*"] },
    hot: "only",
    static: {
      watch: {
        ignored: "./node_modules/",
        aggregateTimeout: 300,
        poll: 1000,
      },
    },
  },
  transpileDependencies: ["vuetify"],
  css: {
    sourceMap: true,
  },
  chainWebpack: (config) => {
    config.plugin("BundleTracker").use(BundleTracker, [
      {
        filename: `./config/webpack-stats-${process.env.NODE_ENV}.json`,
      },
    ]);
    config.resolve.alias.set("__STATIC__", "static");
  },
});

迁移之后,每次运行npm run serve时都会显示一个新的警告(但是devServer.public在v5中被删除了!):

代码语言:javascript
复制
  App running at:
  - Local:   http://localhost:8080/ 

  It seems you are running Vue CLI inside a container.

  Since you are using a non-root publicPath, the hot-reload socket
  will not be able to infer the correct URL to connect. You should
  explicitly specify the URL via devServer.public.

  Access the dev server via http://localhost:<your container's external mapped port>http://localhost:8080/

  Note that the development build is not optimized.
  To create a production build, run npm run build.

有什么想法吗?提前感谢!

EN

回答 1

Stack Overflow用户

发布于 2022-05-03 21:40:48

我的团队有类似的问题,正如你所描述的。我们可以通过将优化对象添加到Webpack配置(vue.config.js`)来修复它。

代码语言:javascript
复制
const {defineConfig} = require('@vue/cli-service');

module.exports = defineConfig({
    /* your config */
    configureWebpack: {
        optimization: {
            runtimeChunk: 'single',
        },
    },
    devServer: {
        // we need this for apollo to work properly
        proxy: `https://${process.env.SANDBOX_HOSTNAME}/`,
        host: '0.0.0.0',
        allowedHosts: 'all',
    },
});

optimization部分为我们修复了HMR。但是,如果您使用的是Firefox,那么您的控制台可能仍然会收到以下错误消息:

到wss://SANDBOX_HOSTNAME:8080/ws的连接在页面加载时被中断。

对于我们来说,这是vue 3的阻断剂,所以我希望它能有所帮助。✌️

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71472723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档