qmzreact 1.0.10 → 1.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,11 +6,11 @@ var { merge } = require('webpack-merge');
6
6
  var { utils, processConfig } = require('../options');
7
7
  var sassGlobalStyles = '';
8
8
  processConfig.sassGlobalStyles.forEach((item) => {
9
- return sassGlobalStyles += `@import "${item}";`;
9
+ return sassGlobalStyles += `@use "${item}" as *;`;
10
10
  });
11
11
  try {
12
12
  fs.accessSync(utils.rootPath('src/global.scss'), fs.constants.F_OK);
13
- sassGlobalStyles += `@import "@/global.scss";`;
13
+ sassGlobalStyles += `@use "@/global.scss" as *;`;
14
14
  } catch (err) {
15
15
  // console.log(err);
16
16
  };
@@ -116,8 +116,25 @@ module.exports = [
116
116
  loader: 'css-loader',
117
117
  options: merge({
118
118
  modules: {
119
+ // 1. 开启“局部模式”(意味着:我要对类名进行处理)
120
+ mode: 'local',
121
+
122
+ // 2. 定义生成的规则(名字长什么样)
119
123
  localIdentName: '[name]__[local]___[hash:base64:5]',
120
- exportLocalsConvention: 'camelCase'
124
+ exportLocalsConvention: 'camelCase',
125
+
126
+ // 3. 自定义函数:遇到 node_modules 就“放行”,否则“使用上面的规则”
127
+ getLocalIdent: (context, localIdentName, localName, options) => {
128
+ // 如果是 node_modules 里的文件
129
+ if (context.resourcePath.includes('node_modules')) {
130
+ // 直接返回原始类名(相当于变相的 global 模式)
131
+ return localName;
132
+ }
133
+
134
+ // 如果是自己 src 里的文件
135
+ // 返回 null,告诉 css-loader:“请用 localIdentName 的规则去生成哈希”
136
+ return null;
137
+ }
121
138
  }
122
139
  }, processConfig.cssLoaderOptions)
123
140
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "qmzreact",
3
- "version": "1.0.10",
3
+ "version": "1.0.11",
4
4
  "description": "前端react本地启动服务和打包工具",
5
5
  "author": {
6
6
  "name": "qmz",