4

当尝试设置 SCSS 以使用 Webpack 在我的 React 应用程序上运行样式时,我遇到了错误:

Module not found: Error: Can't resolve 'style' in '/Users/sachinkaria/Workspace/GC' @ ./app/index.js 4:0-29 @ multi ./app/index.js'

在浏览器中:

Uncaught Error: Cannot find module "/styles/main.scss"

我的 webpack.config.js 配置如下:

var HtmlWebpackPlugin = require('html-webpack-plugin');-
var HTMLWebpackPluginConfig = new HtmlWebpackPlugin({
  template: __dirname + '/app/index.html',
  filename: 'index.html',
  inject: 'body'
});

module.exports = {
  entry: [
    './app/index.js'
  ],
  output: {
    path: __dirname + '/dist',
    filename: "index_bundle.js"
  },
  module: {
    loaders: [
      {test: /\.js$/, exclude: /node_modules/, loader: "babel-loader"},{
            test: /\.scss$/,
            loaders: ['style', 'css', 'sass']
        }
    ]
  },
  plugins: [HTMLWebpackPluginConfig]
};

我的 package.json:

    {
  "name": "get-cooked",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "start": "webpack-dev-server",
    "prod": "webpack -p"
  },
  "author": "Sachin Karia",
  "license": "ISC",
  "dependencies": {
    "classnames": "^2.2.5",
    "react": "^0.14.6",
    "react-bootstrap": "^0.30.7",
    "react-dom": "^0.14.6",
    "react-router": "^2.0.0-rc5"
  },
  "devDependencies": {
    "babel-core": "^6.4.5",
    "babel-loader": "^6.2.1",
    "babel-preset-react": "^6.3.13",
    "html-webpack-plugin": "^2.7.1",
    "node-sass": "^4.5.0",
    "sass-loader": "^6.0.2",
    "webpack": "2.2.1",
    "webpack-dev-server": "^1.14.1"
  }
}

我要导入 main.scss 的 index.js (产生错误):

var React = require('react');
var ReactDOM = require('react-dom');
var routes = require('./config/routes');
require('./styles/main.scss');

ReactDOM.render(routes, document.getElementById('app'));

我所有的 scss 文件都在我的样式文件夹中,但是,我似乎无法将它们导入我的 index.js 并返回“找不到模块”错误。

这是我的文件夹结构:

- app
  - components
    - Home.js
  - config
    - routes.js
  - containers
  - styles
    - components
    - main.scss
  - index.html
  - index.js
- nodemodules
webpack.config.js
package.json

任何帮助表示赞赏!

4

5 回答 5

4

替换/styles

./styles 

如果index.jsstyles在同一个文件夹中

编辑:如果你来自谷歌 - 结果style-loadercss-loader没有安装,请确保这一点。

于 2017-02-26T22:55:34.123 回答
4

原来这是一个加载程序问题,并且没有正确的节点模块。只需运行以下脚本即可解决问题:

npm install style-loader css-loader --save-dev 

以及使用将“style-loader”、“css-loader”和“sass-loader”添加到 Webpack 而不是“style”、“css”、“sass”。

于 2017-02-27T10:25:18.420 回答
2

/styles/main.scss是一个绝对路径,因此它将在文件系统的根目录中查找。您想使用相对路径:

require('./styles/main.scss');

这需要stylesindex.js. 因此,如果您的项目结构如下所示:

- styles/
  - main.scss
- app/
  - index.js

您需要上一个目录:

require('../styles/main.scss');

如果您想使用相对于项目根目录的路径,可以使用webpack 配置中的解析选项。

于 2017-02-26T22:56:28.083 回答
0

这主要是与 webpack 相关的问题,可以出现在任何与 webpack 相关的应用程序中只需包含"css-loader": "^0.28.6", "style-loader": "^0.18.2"在您的 package.json"devDependencies": {...}文件中并运行npm update

于 2017-08-30T20:27:32.377 回答
0

我在 VSTS for ReactJS 中玩 CI 和自动化,并自动部署到 SharePoint Online Web 部件让我更新 VS Code IDE、编辑 Gulp 文件、CD、MK 等。重新打开 VS Code 后,我没有注意到我我现在在我的终端窗口中显示的差异目录中。更糟糕的是?我在一个不在我的根 node_modules 文件夹附近的不同目录中!我最初在这里:../node_modules/ - << This is my initial Node mod root!!!

../src/webparts/az

而现在我在:

../node_modules/
../src/webparts\SPWPTest\src\webparts\az

注意:在继续之前记下你的节点、IDE、反应、ES、模块版本等,以防你需要回滚。

解决方案?

  1. CD 更正目录
  2. 做你的CleansBuilds希望得到Served。吞下那些。
  3. 如果仍然无法正常工作,则从新目录中运行:npm update

现在您将 node_modules 添加到本地。是好是坏?我不知道,但它有效!:-)

于 2018-01-24T12:52:56.820 回答