{"id":19926141,"url":"https://github.com/ittokunvim/learning-webpack","last_synced_at":"2025-03-01T10:41:59.468Z","repository":{"id":142957465,"uuid":"396880212","full_name":"ittokunvim/learning-webpack","owner":"ittokunvim","description":null,"archived":false,"fork":false,"pushed_at":"2021-08-19T15:56:51.000Z","size":3411,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-01-12T00:32:53.051Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ittokunvim.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2021-08-16T16:36:50.000Z","updated_at":"2024-05-15T10:51:54.000Z","dependencies_parsed_at":"2023-05-12T18:16:16.544Z","dependency_job_id":null,"html_url":"https://github.com/ittokunvim/learning-webpack","commit_stats":null,"previous_names":["ittokunvim/webpack-tutorial","ittokunvim/learning-webpack"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ittokunvim%2Flearning-webpack","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ittokunvim%2Flearning-webpack/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ittokunvim%2Flearning-webpack/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ittokunvim%2Flearning-webpack/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ittokunvim","download_url":"https://codeload.github.com/ittokunvim/learning-webpack/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241354990,"owners_count":19949291,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-11-12T22:28:08.839Z","updated_at":"2025-03-01T10:41:59.442Z","avatar_url":"https://github.com/ittokunvim.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# webpack-tutorial\n\nhttps://webpack.js.org/guides/\n\n## Getting started\n\n1. npm init -y\n2. npm install webpack webpack-cli --save-dev\n3. npm install --save lodash\n4. npx webpack\n5. open dist/index.html\n6. npx webpack --config webpack.config.js\n7. npm run build\n8. open dist/index.html\n9. npm run build -- --color\n\n### memo\n\n- unpkg.com (https://unpkg.com/)\n  - CDN services, npmに登録されているパッケージを手軽に利用できる\n\n```shell\n# usage: \n# 最新のバージョンを指定する場合 * 最新バージョンにリダイレクトされます\nhttps://unpkg.com/パッケージ名/ファイル\n\n# バージョンを指定する場合\nhttps://unpkg.com/パッケージ名@バージョン/ファイル\n\n# ディレクトリ構造がある場合\nhttps://unpkg.com/パッケージ名@バージョン/ディレクトリ/ファイル\n```\n\n- import _ from 'lodash'\n  - 便利な関数をまとめて提供しているライブラリらしい。(https://lodash.com/)\n- --save-dev, --save\n  - --saveは本番用、--save-devは開発用、依存関係\n- `npm webpack`の後に`--`をつけると引数を渡せる\n\n## Assets Management\n\n1. npm install --save-dev style-loader css-loader\n2. npm run build\n3. open dist/index.html\n4. npm install --save-dev csv-loader xml-loader\n5. npm install --save-dev yamljs json5\n6. npm install toml yamljs json5 --save-dev\n\n### memo\n\n- /src/assetsにまとめて入れるより、/src/components/my-componentsに分けて入れると管理しやすい。\n\n## Output Management\n\n1. npm install --save-dev html-webpack-plugin\n\n### memo\n\n- html-webpack-pluginはhtmlを出力する\n- 詳細 -\u003e https://github.com/jantimon/html-webpack-plugin\n\n- output: { clean: true }を指定すると./dist/以下のファイルを綺麗にしてくれる\n\n## Development\n\n1. npm install --save-dev webpack-dev-server\n2. npm install --save-dev express webpack-dev-middleware\n\n### memo\n\n- devtool: 'inline-source-map'でエラーを追跡できる\n\n1. webpack's Watch Mode\n   - ブラウザをリフレッシュすると内容が変わる\n\n2. webpack-dev-server\n   - `localhost:8000`でサーバーが立ち上がる\n\n3. webpack-middleware\n   - サーバの設定を幅広く変更できる\n\n## Code Splitting\n\n- dependOnオプションはchunk間でモジュールを共有できる\n- 1つのHTMLページで複数のエントリーポイントを使用する場合は、最適化.runtimeChunk: single」も必要です。\n- SplitChunksPluginを使うと、既存のentry chunkや全く新しいchunkに共通の依存関係を抽出することができます\n- returnにインポートを書いてそのまま返すDynamic Importsというやり方もあるhttps://webpack.js.org/guides/code-splitting/#dynamic-imports\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fittokunvim%2Flearning-webpack","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fittokunvim%2Flearning-webpack","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fittokunvim%2Flearning-webpack/lists"}