首頁 web前端 js教程 react-router4 配合webpack require.ensure 實作非同步載入(詳細教學)

react-router4 配合webpack require.ensure 實作非同步載入(詳細教學)

Jun 11, 2018 pm 03:10 PM
webpack 非同步載入

本篇文章主要介紹了react-router4 配合webpack require.ensure 實現異步加載的示例,非常具有實用價值,需要的朋友可以參考下

實現異步加載的方法,歸根結底大都是根據webpack的require.ensure來實現

第一個是自己使用require.ensure實現,

第二種使用loader實作

今天我們說的是使用bundle- loader來實現,這樣程式碼更優雅些。

首先需要安裝bundle-loader ,具體使用npm還是yarn,就看你的套件管理使用的是啥了。

下面需要一個bundle.js

import React, { Component } from 'react';
export default class Bundle extends Component {
  constructor(props) {
    super(props);
    this.state = {
      mod: null
    };
  }

  componentWillMount() {
    this.load(this.props);
  }

  componentWillReceiveProps(nextProps) {
    if (nextProps.load !== this.props.load) {
      this.load(nextProps);
    }
  }

  load(props) {
    this.setState({
      mod: null
    });
    props.load(mod => {
      this.setState({
        mod: mod.default ? mod.default : mod
      });
    });
  }

  render() {
    return this.state.mod ? this.props.children(this.state.mod) : null;
  }
}
登入後複製

然後把bundle.js 引進來,同時也把需要做非同步的檔案引進來,但前面需要加上

bundle-loader?lazy&name=[name]!
登入後複製

例如:

import Bundle from './components/bundle.js';
import ListComponent from 'bundle-loader?lazy&name=[name]!./file/List.jsx';
登入後複製

下面就是新增路由這塊的設定:

<Route path="/list" component={List} />
登入後複製

以及設定output的chunkFilename

chunkFilename: &#39;[name]-[id].[chunkhash:4].bundle.js&#39;
登入後複製

chunkFilename配置好以後,異步載入進來的檔案名稱就會按照上面的命名方式來展示,如果不配置,就是webpack給生成的數字了。

上面的都配置好了以後,就是怎麼使用bundle了,你看到route上配置的component對應的是List,所以我們需要寫一個List:

const List = (props) => (
  <Bundle load={ListComponent}>
    {(List) => <List {...props}/>}
  </Bundle>
);
登入後複製

上面是我整理給大家的,希望未來會對大家有幫助。

相關文章:

使用JS如何實作瀑布流外掛程式

在JS如何實作將html轉換為pdf功能

使用JS如何實現貼上板複製功能

#在JS如何實作offset和勻速動畫

############################################################################################################################ #在Bootstrap中如何實現表格合併單元格############在JavaScript中如何實現獲取select下拉框中第一個值############在AngularJS中如何做到即時取得並顯示密碼#######

以上是react-router4 配合webpack require.ensure 實作非同步載入(詳細教學)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1668
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
揭露Ajax異常,解決錯誤的方法一覽 揭露Ajax異常,解決錯誤的方法一覽 Jan 30, 2024 am 08:33 AM

Ajax異常大揭秘,如何應對各種錯誤,需要具體程式碼範例2019年,前端開發已成為網路產業中不可忽視的重要職位。而Ajax作為前端開發中最常用的技術之一,能夠實現頁面異步加載和資料交互,其重要性不言而喻。然而,使用Ajax技術時經常會遇到各種錯誤和異常,如何應對這些錯誤是每位前端開發者必須面對的問題。一、網路錯誤在使用Ajax發送請求時,最常見的錯誤就是

c#什麼是委託解決什麼問題 c#什麼是委託解決什麼問題 Apr 04, 2024 pm 12:42 PM

委託是一種類型安全的參考類型,用於在物件之間傳遞方法指針,解決非同步程式設計和事件處理問題:非同步程式設計:委託允許在不同執行緒或進程中執行方法,提高應用程式回應能力。事件處理:委託簡化了事件處理,允許建立和處理事件,例如點擊或滑鼠移動。

提升網站速度的關鍵最佳化模式,每個前端開發者都必須掌握! 提升網站速度的關鍵最佳化模式,每個前端開發者都必須掌握! Feb 02, 2024 pm 05:36 PM

前端開發者必備:掌握這些最佳化模式,讓網站飛起來!隨著網路的快速發展,網站已成為企業宣傳和交流的重要管道之一。一個效能優良、載入迅速的網站不僅可以提升使用者體驗,還可以吸引更多的訪客。身為前端開發者,掌握一些最佳化模式是不可或缺的。本文將介紹一些常用的前端優化技術,幫助開發者更好地優化網站。壓縮檔案在網站開發中,經常使用的檔案類型包括HTML、CSS和J

有效應對jQuery .val()不起作用的情勢 有效應對jQuery .val()不起作用的情勢 Feb 20, 2024 pm 09:36 PM

標題:解決jQuery.val()不起作用的方法及程式碼範例在前端開發中,常會使用到jQuery來操作頁面元素。其中,取得或設定表單元素的值是常見的操作之一。通常,我們會使用jQuery的.val()方法來實作表單元素值的運算。然而,有時會遇到jQuery.val()不起作用的情況,這可能會導致一些問題。本文將介紹如何有效應對jQuery.val(

html怎麼讀取 html怎麼讀取 Apr 05, 2024 am 08:36 AM

雖然HTML 本身無法讀取文件,但可以透過以下方法實作文件讀取:使用JavaScript(XMLHttpRequest、fetch());使用伺服器端語言(PHP、Node.js);使用第三方函式庫(jQuery.get() 、axios、fs-extra)。

H5頁面製作的性能如何優化 H5頁面製作的性能如何優化 Apr 06, 2025 am 06:24 AM

通過網絡請求、資源加載、JavaScript執行和渲染優化等手段,可以提升H5頁面性能,打造流暢、高效的頁面:資源優化:壓縮圖片(如使用tinypng)、精簡代碼、啟用瀏覽器緩存。網絡請求優化:合併文件、使用CDN、異步加載。 JavaScript優化:減少DOM操作、使用requestAnimationFrame、善用虛擬DOM。進階技巧:代碼分割、服務端渲染。

PHP搜尋功能最佳化技巧分享 PHP搜尋功能最佳化技巧分享 Mar 06, 2024 am 11:12 AM

PHP搜尋功能一直是網站開發中非常重要的一環,因為使用者往往會透過搜尋框來尋找所需資訊。然而,不少網站在實現搜尋功能時存在效率低、搜尋結果不準確等問題。為了幫助大家優化PHP搜尋功能,本文將分享一些技巧,並提供具體的程式碼範例。 1.使用全文搜尋引擎傳統的SQL資料庫在處理大量文字內容時效率較低,因此建議使用全文搜尋引擎,如Elasticsearch、Solr等

html怎麼引入外部js html怎麼引入外部js Apr 11, 2024 am 06:18 AM

若要在 HTML 中引入外部 JS 文件,請使用 <script> 標籤並指定要載入的文件的 URL。也可以指定 type、defer 或 async 屬性來控制載入和執行方式。通常,<script> 標籤應放置在 <body> 部分的底部,以避免阻塞頁面渲染。

See all articles