From ab27e0718a5e91255b9c6153f7f904c02eb03427 Mon Sep 17 00:00:00 2001 From: likui <2218301630@qq.com> Date: Tue, 26 May 2020 14:33:33 +0800 Subject: [PATCH 1/2] fix: css cache check --- src/node/server/serverPluginCss.ts | 36 +++++++++++++----------------- 1 file changed, 15 insertions(+), 21 deletions(-) diff --git a/src/node/server/serverPluginCss.ts b/src/node/server/serverPluginCss.ts index eccc6d20a92f3a..0a62f2886c3365 100644 --- a/src/node/server/serverPluginCss.ts +++ b/src/node/server/serverPluginCss.ts @@ -12,7 +12,6 @@ import { } from '../utils/cssUtils' import qs from 'querystring' import chalk from 'chalk' -import slash from 'slash' interface ProcessedEntry { css: string @@ -51,25 +50,22 @@ export const cssPlugin: ServerPlugin = ({ root, app, watcher, resolver }) => { } }) - watcher.on('change', (file) => { - /** filter unused files */ - if ( - !Array.from(processedCSS.keys()).some((processed) => - slash(file).includes(processed) - ) && - !srcImportMap.has(file) - ) { - return debugCSS( - `${basename(file)} has changed, but it is not currently in use` - ) - } + watcher.on('change', (filePath) => { + if (filePath.endsWith('.css') || cssPreprocessLangRE.test(filePath)) { + const publicPath = resolver.fileToRequest(filePath) - if (file.endsWith('.css') || cssPreprocessLangRE.test(file)) { - if (srcImportMap.has(file)) { + /** filter unused files */ + if (!processedCSS.has(publicPath) && !srcImportMap.has(publicPath)) { + return debugCSS( + `${basename(publicPath)} has changed, but it is not currently in use` + ) + } + + if (srcImportMap.has(filePath)) { // handle HMR for