최신 정보
html -webpack-plugin 과 함께 preload-webpack-plugin 을 사용할 수 있습니다 . 구성에서 사전로드 할 항목을 정의하고 청크를 사전로드하기 위해 자동으로 태그를 삽입합니다
현재 webpack v4를 사용하는 경우 다음을 사용 하여이 플러그인을 설치해야합니다. preload-webpack-plugin@next
예
plugins: [
new HtmlWebpackPlugin(),
new PreloadWebpackPlugin({
rel: 'preload',
include: 'asyncChunks'
})
]
chunk.31132ae6680e598f8879.js
and
와 같이 동적으로 생성 된 이름으로 두 개의 비동기 스크립트를 생성하는 프로젝트의 chunk.d15e7fdfc91b34bb78c4.js
경우 다음과 같은 사전로드가 문서에 삽입됩니다.head
<link rel="preload" as="script" href="chunk.31132ae6680e598f8879.js">
<link rel="preload" as="script" href="chunk.d15e7fdfc91b34bb78c4.js">
업데이트 2
모든 비동기 청크를 미리로드하지 않으려면 한 번만 특정로드하면됩니다.
migcoder의 babel 플러그인을 사용 하거나 preload-webpack-plugin
다음 과 같이 사용할 수 있습니다
먼저 webpack
magic comment
예제를 사용 하여 비동기 청크의 이름을 지정해야합니다
import(/* webpackChunkName: 'myAsyncPreloadChunk' */ './path/to/file')
그런 다음 플러그인 구성에서 다음과 같은 이름을 사용하십시오
plugins: [
new HtmlWebpackPlugin(),
new PreloadWebpackPlugin({
rel: 'preload',
include: ['myAsyncPreloadChunk']
})
]
먼저 스크립트를로드하기 위해 script
태그 또는 link
태그를 지정할 때 브라우저의 동작을 살펴 보겠습니다
- 브라우저가
script
태그를 발견 할 때마다 이를로드하여 구문 분석하고 즉시 실행합니다.
- 당신은 단지 파싱의 도움으로 평가 지연시킬 수
async
및
defer
태그 까지만DOMContentLoaded
이벤트
- 스크립트 태그를 삽입하지 않는 경우 실행 (평가)를 지연시킬 수 있습니다 (단지와 함께 미리로드
link
)
이제는 권장되지 않는 다른 해키 방법이 있습니다. 전체 스크립트를 배송하고 ( string
또는 comment
주석 또는 문자열의 평가 시간이 거의 무시할 수 있기 때문에) 실행해야 할 때 사용할 수 Function() constructor
있거나 eval
둘 다 권장하지 않습니다
다른 접근 서비스 작업자 : (이는 페이지를 다시로드 한 후 캐시 이벤트를 유지하거나 캐시가로드 된 후 사용자가 오프라인 상태가되도록합니다)
최신 브라우저에서는 service worker
recourse (JavaScript, image, css anything)를 가져오고 캐시하는 데 사용할 수 있으며 해당 recourse에 대한 기본 스레드 요청이 있으면 요청을 가로 채고 캐시에서 recourse를 반환 할 수 있습니다.이 방법으로 스크립트를 구문 분석하고 평가하지 않을 때 서비스 작업자에 대한 자세한 내용은 여기를 캐시에로드 하십시오.
예
self.addEventListener('install', function(event) {
event.waitUntil(
caches.open('v1').then(function(cache) {
return cache.addAll([
'/sw-test/',
'/sw-test/index.html',
'/sw-test/style.css',
'/sw-test/app.js',
'/sw-test/image-list.js',
'/sw-test/star-wars-logo.jpg',
'/sw-test/gallery/bountyHunters.jpg',
'/sw-test/gallery/myLittleVader.jpg',
'/sw-test/gallery/snowTroopers.jpg'
]);
})
);
});
self.addEventListener('fetch', function(event) {
event.respondWith(caches.match(event.request).then(function(response) {
// caches.match() always resolves
// but in case of success response will have value
if (response !== undefined) {
return response;
} else {
return fetch(event.request).then(function (response) {
// response may be used only once
// we need to save clone to put one copy in cache
// and serve second one
let responseClone = response.clone();
caches.open('v1').then(function (cache) {
cache.put(event.request, responseClone);
});
return response;
}).catch(function () {
// any fallback code here
});
}
}));
});
당신이 볼 수 있듯이 이것은 webpack 의존적 이지 않습니다. 이것은 webpack 의 범위를 벗어납니다.하지만 webpack의 도움으로 번들을 분할하여 서비스 작업자를 더 잘 활용할 수 있습니다
if (false) import(…)
-Webpack이 데드 코드 분석을 의심합니까?