前提・実現したいこと
現在、Chromeの拡張機能の開発をしており、プロトタイプが完成したため、webpackやbabelできちんと大規模に作成できるように移行をしています。
ファイル構成
現在ファイル構成は、ルートディレクトリが
. ├── dist ├── index.js ├── node_modules ├── package-lock.json ├── package.json ├── src └── webpack.config.js
上記のようになっており、さらに、srcフォルダの中は
src. ├── components ├── htmls │ └── atcoder.html ├── images │ ├── large_icon.png │ └── small_icon.png ├── manifest.json ├── scripts │ ├── background │ │ └── icon_click.js │ ├── background.js │ ├── options │ ├── options.js │ ├── popup │ ├── popup.js │ └── third │ └── jquery-3.3.1.min.js └── styles
上記の様になっています。
webpackの設定
javascript
1const path = require('path'); 2const CopyWebpackPlugin = require('copy-webpack-plugin'); 3 4module.exports = { 5 entry: { 6 background: path.join(__dirname, 'src', 'scripts', 'background.js'), 7 popup: path.join(__dirname, 'src', 'scripts', 'popup.js'), 8 options: path.join(__dirname, 'src', 'scripts', 'options.js') 9 }, 10 output: { 11 path: path.join(__dirname, "dist"), 12 filename: 'scripts/[name].bundle.js', 13 }, 14 target: "web", 15 resolve: { 16 extensions: ['ts', '.js'], 17 modules: 18 [ 19 'node_modules', 20 path.resolve(__dirname, 'src') 21 ] 22 }, 23 devServer: { 24 contentBase: path.join(__dirname, 'dist'), 25 port: 26 9000, 27 hot: 28 true, 29 } 30 , 31 module: { 32 rules: [ 33 { 34 test: /.js$/, 35 use: {loader: 'babel-loader'} 36 } 37 ] 38 } 39 , 40 plugins: [ 41 new CopyWebpackPlugin( 42 [ 43 { 44 from: path.join(__dirname, 'src', 'manifest.json'), 45 to: path.join(__dirname, 'dist'), 46 }, 47 { 48 from: path.join(__dirname, 'src', 'htmls'), 49 to: path.join(__dirname, 'dist/htmls') 50 }, 51 { 52 from: path.join(__dirname, 'src', 'images'), 53 to: path.join(__dirname, 'dist/images') 54 }, 55 { 56 from: path.join(__dirname, 'src', 'components'), 57 to: path.join(__dirname, 'dist/components') 58 }, 59 { 60 from: path.join(__dirname, 'src', 'styles'), 61 to: path.join(__dirname, 'dist/styles') 62 } 63 ] 64 ) 65 ] 66} 67
package.jsonの設定
json
1{ 2 "name": "atcoder_save", 3 "version": "1.0.0", 4 "description": "", 5 "main": "index.js", 6 "scripts": { 7 "build": "webpack --mode=development", 8 "start": "webpack --watch --mode=development" 9 }, 10 "author": "", 11 "license": "ISC", 12 "dependencies": { 13 "babel-core": "^6.26.3", 14 "babel-loader": "^7.1.5", 15 "babel-preset-env": "^1.7.0", 16 "copy-webpack-plugin": "^4.5.2", 17 "webpack": "^4.16.3", 18 "webpack-cli": "^3.1.0" 19 } 20} 21
発生している問題・エラーメッセージ
src/scrpits/background.jsから、src/scripts/background/icon_click.jsを読み込もうと考えています。(background.jsがentryで、backgroundフォルダの中のソースコードが実際の実装。)
しかし、以下のようなエラーが表示されてしまいます。
ERROR in ./src/scripts/background.js Module not found: Error: Can't resolve 'background/icon_click' in '/Users/ganariya/Desktop/AtCoder_Save/src/scripts' @ ./src/scripts/background.js 3:15-47 npm ERR! code ELIFECYCLE npm ERR! errno 2 npm ERR! atcoder_save@1.0.0 build: `webpack --mode=development` npm ERR! Exit status 2 npm ERR! npm ERR! Failed at the atcoder_save@1.0.0 build script. npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
webpackがなにかエラーをやらかしているのだと考えます。
該当のソースコード
background.js
javascript
1const {func} = require('background/icon_click'); 2func();
background/icon_click.js
javascript
1function func() { 2 console.log("func"); 3} 4 5module.exports.func = func;
試したこと
いろいろと、ネットを調べて、モジュールを最新にしたり、よくあるエラーミスを試したのですが、治すことができませんでした。
補足情報(FW/ツールのバージョンなど)
OS:Mac
IDE: WebStorm
フレームワーク: Webpack + babel + chrome extension
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/07/27 23:28
2018/07/27 23:45