t06_vue在mac操作系统中热更新失效问题包括cli与vite

1、问题原因

用vuecli与vite创建的vue项目,默认是没有热部署更新的。而且查阅大量资料后仍然找不到解决方法

这个我认为是mac的m系列芯片的问题

为什么我会这么认为,因为相同的项目,node_moudules我都没有变过,再win系统中与mac系统同时运行,只有win系统是可以正常热部署的,mac就跟死了一样。这个问题真的是令人抓耳挠腮,浪费了我两台时间没想到就加加几行代码。

2、解决方法

2.1 vuecli

修改 vue.config.js文件

最主要的是添加如下代码:

configureWebpack: 复制代码
  // 根级 watchOptions,作用于所有模块编译
  watchOptions: {
    poll: 1000,            // 轮询间隔 ms
    aggregateTimeout: 300, // 防抖时间 ms
    ignored: /node_modules/
  }
},

vue.config.js文件完整代码1(根据自己代码选择):

// 复制代码
module.exports = {
  // (一)Webpack 编译器监视改动
  configureWebpack: {
    // 根级 watchOptions,作用于所有模块编译
    watchOptions: {
      poll: 1000,            // 轮询间隔 ms
      aggregateTimeout: 300, // 防抖时间 ms
      ignored: /node_modules/
    }
  },

  devServer: {
    hot: true,
    // (二)静态资源监视(可选)
    static: {
      watch: true
    },
    // (三)额外路径监视(可选)
    watchFiles: {
      paths: ['src/**/*', 'public/**/*'],
      options: {
        usePolling: false   // 这一项只影响 dev-server 的额外监视,不影响 Webpack 编译
      }
    },
    // 网络 & WS 设置,确保 HMR 客户端能连上
    host: '0.0.0.0',
    allowedHosts: 'all',
    client: {
      webSocketURL: 'ws://0.0.0.0:8080/ws'
    }
  }
}

vue.config.js文件完整代码2(根据自己代码选择):

const 复制代码
module.exports = defineConfig({
  transpileDependencies: true,
  configureWebpack: {
    // 根级 watchOptions,作用于所有模块编译
    watchOptions: {
      poll: 1000,            // 轮询间隔 ms
      aggregateTimeout: 300, // 防抖时间 ms
      ignored: /node_modules/
    }
  },
})

2.2 vue-vite

vue.config.js文件中添加如下监听

watch: 复制代码
  usePolling: true, // 关键点!
}

vue.config.js文件完整代码

import 复制代码
import vue from '@vitejs/plugin-vue'

export default defineConfig({
  plugins: [vue()],
  server: {
    host: '0.0.0.0', // 或 'localhost'
    port: 5173,
    watch: {
      usePolling: true, // 关键点!
    }
  }
})
相关推荐
user20585561518131 小时前
Windows 项目安装时报 `node-sass` 错误,如何快速处理
前端
LiaCode1 小时前
Redis 在生产项目的使用
前端·后端
LiaCode2 小时前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战2 小时前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
风骏时光牛马2 小时前
# Ruby基于Rails框架实现多角色权限管理与数据分页查询完整实战代码案例
前端
weedsfly2 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
xiaodaoluanzha2 小时前
迄今為止,最簡單的編程語言 Nolang
前端·后端
Csvn2 小时前
Fetch 请求竞态终结者:AbortController 不只是用来"取消"的
前端
阡陌Jony2 小时前
关于前端路由中的参数问题的学习(一): params,query, hash(#)
前端
阡陌Jony2 小时前
缓存相关学习笔记(一):Service Worker 缓存
前端