{"id":24961805,"url":"https://github.com/vansosnin/webpack-dll-example","last_synced_at":"2026-05-18T19:35:54.005Z","repository":{"id":86083286,"uuid":"121539923","full_name":"vansosnin/webpack-dll-example","owner":"vansosnin","description":"🔧 Пример конфигурации webpack.DllPlugin и webpack.DllReferencePlugin","archived":false,"fork":false,"pushed_at":"2018-03-14T07:51:22.000Z","size":129,"stargazers_count":3,"open_issues_count":0,"forks_count":1,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-07-17T07:46:38.920Z","etag":null,"topics":["config","dll-plugin","example","webpack"],"latest_commit_sha":null,"homepage":"","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/vansosnin.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":"2018-02-14T17:30:39.000Z","updated_at":"2018-09-26T21:09:19.000Z","dependencies_parsed_at":null,"dependency_job_id":"2d771842-c0f3-478f-b3d5-7a989cdfcef3","html_url":"https://github.com/vansosnin/webpack-dll-example","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/vansosnin/webpack-dll-example","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/vansosnin%2Fwebpack-dll-example","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/vansosnin%2Fwebpack-dll-example/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/vansosnin%2Fwebpack-dll-example/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/vansosnin%2Fwebpack-dll-example/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/vansosnin","download_url":"https://codeload.github.com/vansosnin/webpack-dll-example/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/vansosnin%2Fwebpack-dll-example/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273886630,"owners_count":25185509,"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","status":"online","status_checked_at":"2025-09-06T02:00:13.247Z","response_time":2576,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"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":["config","dll-plugin","example","webpack"],"created_at":"2025-02-03T08:57:26.268Z","updated_at":"2026-05-18T19:35:48.962Z","avatar_url":"https://github.com/vansosnin.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Webpack DllPlugin\n\nПример конфигурации [webpack.DllPlugin](https://webpack.js.org/plugins/dll-plugin/) для [статьи на habrahabr](https://habrahabr.ru/company/skbkontur/blog/351080/).\n\n## Запуск\n\nЧтобы локально запустить пример, выполните шаги:\n\n- Установите зависимости\n\n  ```\n  npm install\n  ```\n\n\n- Соберите development-версию:\n\n  ```\n  npm run build:dll\n  npm run build\n  ```\n\n  ​\n\n- Или соберите  production-версию:\n\n  ````\n  npm run deploy\n  ````\n\n\u003e Обратите внимание, что в данном случае не нужно собирать dll, потому что он уже собран и лежит в репозитории.\n\nЧто именно делает каждый из скриптов, можно посмотреть в [package.json](https://github.com/vansosnin/webpack-dll-example/blob/master/package.json) в разделе `scripts`.\n\n- Откройте index.html\n\n## Описание\n\nНа что нужно обратить внимание (кроме конфигов):\n\n- папка src — исходники, очевидно, они должны лежать в вашем репозитории;\n- папка [dist/dll/production](https://github.com/vansosnin/webpack-dll-example/tree/master/dist/dll/production) — это как раз предсобранный dll, который нужно положить в репозиторий. При деплое на production его пересобирать не нужно;\n- папка [example_dist](https://github.com/vansosnin/webpack-dll-example/tree/master/example_dist) — просто пример получившихся бандлов (их таскать в вашем репозитории не нужно).\n\n## [Optional] Копирование dll\n\nВ данном примере конфигурации DllPlugin, dll собираются отдельно для каждоый среды. Например потому, что в режиме разработке мы хотим видеть ошибки React, которые не показываются в production-версии. Ну и могут быть другие причины, в зависимости от стека — это не столь важно.\n\nВажно то, что у вас dll может лежать совершенно в другом месте, нежели ваши бандлы. Эту проблему можно решать несколькими способами. Я вижу 2:\n\n1. использовать [HtmlWebpackPlugin](https://github.com/jantimon/html-webpack-plugin): он сам добавляет в html нужные теги `script`;\n2. использовать [CopyWebpackPlugin](https://github.com/webpack-contrib/copy-webpack-plugin): он умеет копировать файлики.\n\nЯ выбрал второй вариант и пример его настройки можно увидеть в [основном конфиге](https://github.com/vansosnin/webpack-dll-example/blob/master/webpack.config.js). Таким образом я копирую dll для текущей среды в папку с бандлами и без труда могу сгенерировать нужную ссылку на dll в html.\n\n\u003e В данном примере в [index.html](https://github.com/vansosnin/webpack-dll-example/blob/master/index.html) ссылки написаны жестко, это сделано для простоты. На деле же их можно генерировать при рендеринге вьюшки.\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvansosnin%2Fwebpack-dll-example","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fvansosnin%2Fwebpack-dll-example","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvansosnin%2Fwebpack-dll-example/lists"}