React 項目引入 Dva

来源:https://www.cnblogs.com/wx1993/archive/2019/10/15/11677764.html
-Advertisement-
Play Games

背景 現在手上在做的 React 項目因為年代久遠,用的 "Redux" ,寫代碼的體驗不太好,所以想升級一下引入 dva。以往使用 dva 都是使用 "dva cli" 直接生成 dva 項目,或者在使用 "ant design pro" 的時候使用 umi 直接生成 react + antd + ...


file

背景

現在手上在做的 React 項目因為年代久遠,用的 Redux,寫代碼的體驗不太好,所以想升級一下引入 dva。以往使用 dva 都是使用 dva-cli 直接生成 dva 項目,或者在使用 ant design pro 的時候使用 umi 直接生成 react + antd + dva 項目,省去了大量配置的成本。但是這些案例都是在項目初期的時候直接引入了 dva,而針對已有的 react 項目,想要升級到 dva,應該如何引入呢?引入 dva 的過程又會遇到哪些問題?花了半天時間升級到 dva,這裡就講升級過程中遇到的問題做個彙總。

介紹

  • 項目情況:nw.js + react + redux + antd (客戶端應用)
  • 目標: redux -> dva

準備

  1. 首先安裝 dva (目前版本 2.4.1)
    npm install dva —save

  2. 參考官方文檔,改造項目為 dva 模式,在 src 下新增或修改入口文件 index.js

import dva from ‘dva’;
import createHistory from ‘history/createHashHistory’;

//1.Initialize
const app = dva({
history: createHistory(),
});

//2.Plugins
//app.use({});

//3.Model
//app.model(require(‘./models/app’).default);

//4.Router
app.router(require(‘./router’).default);

//5.Start
app.start(‘#root’);
  1. 然後在同級目錄下添加路由文件 router.js
import React from ‘react’;
import { Router, Route, Switch } from ‘dva/router’;

import App from ‘./containers/App’;
import{ Account, Articles, Channels, Editor } from ‘./containers’;
const { ArticleList } = Articles;

const RouterConfig = (({ history }) => (
    <Routerhistory={history}>
        <Switch>
            <Route path=‘/‘ component={App}>
                <IndexRoute component={Account} />
                <Route path=‘account’ component={Account} exact />
                <Route path=‘articles’ component={ArticleList
 exact />
                <Route path=‘channels’ component={Channels} exact />
                <Route path=‘editor’ component={Editor} exact />
            </Route>
        </Switch>
    </Router>
));

export default RouterConfig;

說明:App 組件是整個頁面的容器組件,包含了 menu、header、footer 和一些公用部分,通過切換菜單匹配對應路由,從而跳轉到各個子組件頁面,所以路由配置需要寫成嵌套形式。
更多路由配置,參考 react-router 官方文檔

到這裡,一個最簡單的 dva 模式已經配置好了,只要在對應組件裡面設置 model、reducer 併在頁面中 connect ,就可以使用 dva 來管理狀態了。

問題解決

配置完成後重新啟動一下項目,查看頁面效果如下:
file

發現容器部分渲染成功,但是子路由對應的頁面(預設是 Account)並沒有渲染,再看控制台發現報錯了。

  1. 首先是這樣一個警告信息:
Warning: Please use `require(“history”).createHashHistory` instead of `require(“history/createHashHistory”)`. Support for the latter will be removed in the next major release.

在 dva 的 issure 裡面查找到相同的問題,按照提示改成下麵的格式就可以了。

const createHistory = require(‘history’).createBrowserHistory;
  1. 然後是一個路由問題的警告:
Warning: You should not use <Route component> and <Route children> in the same route; <Route children> will be ignored

React-router 4.0 以上版本已經不建議像下麵這樣使用嵌套路由了

<Route path=‘/‘ component={App} >
    <Route path=‘account’ component={Account} />
</Route>

對應的,直接改成組件嵌套的形式(註意子路由的 path 要加上 /)就可以了。

<App>
    <Route path=‘/account’component={Account} />
</App>

改完之後然後重新,這兩個警告就沒有了。繼續看路由和渲染的問題。

  1. 按理來說,進入應用預設會顯示 Account 組件(因為配置了 IndexRoute),而且當修改文件刷新頁面時候,頁面直接報錯了,如下:
    file

由此猜想是頁面路由的配置出了問題,查找了相關的資料(React填坑之react-router刷新後報錯解決方法),發現原來是 dva 中使用 BrowserHistory 的問題,所以直接把 BrowserHistory 改成 HashHistory
就可以了。

//const createHistory = require(‘history’).createBrowserHistory;
const createHistory = require(‘history’).createHashHistory;

重新啟動項目,嘗試切換路由,發現一切正常了。
file

後面就可以在頁面中進行 dva 的改造了,dva 中 model 、reducer 的用法都比較簡單,根據文檔進行嘗試就可以了,這裡便不一一敘述了。

總結

總結一下項目引入 dva 遇到的幾個問題。

  1. import createHistory from ‘history/createHashHistory’; 寫法帶來 的警告
  2. 使用 createHashHistory 導致的頁面刷新失敗的問題。
  3. 嵌套路由配置的問題。

參考資料

  1. 基於create-react-app官方腳手架搭建dva模式的項目(一)
  2. React-Router 中文文檔
  3. DvaJS 文檔

file

本文由博客一文多發平臺 OpenWrite 發佈!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JavaScript概述 ECMAScript和JavaScript的關係 1996年11月,JavaScript的創造者 Netscape公司,決定將JavaScript提交給國際標準化組織ECMA,希望這門語言能夠成為國際標準。次年,ECMA發佈262號標準文件(ECMA 262)的第一版,規定 ...
  • call apply bind 返回的是一個修改後的函數。需要另外調用。 ...
  • 一、簡介、使用 1、簡介 Bootstrap 來源於 Twitter,是一款基於 Html、Css、JavaScript 的前端UI框架。可以方便、快速的開發web界面。 教程:https://www.runoob.com/bootstrap/bootstrap-tutorial.html 2、使用 ...
  • 一.父傳子( 父組件 子組件 二.子傳父 子組件 父組件 ...
  • 示例代碼托管在: "http://www.github.com/dashnowords/blogs" 博客園地址: "《大史住在大前端》原創博文目錄" 華為雲社區地址: "【你要的前端打怪升級指南】" [TOC] 一. CSS動畫 和 JS動畫 Web動畫的本質是元素 狀態改變造成的樣式變更 ,CS ...
  • 不知道你們有沒有發現,null和undefined竟然有這樣的關係~ ...
  • Vue.js是一套構建用戶界面的漸進式框架。與其他重量級框架不同的是,Vue 採用自底向上增量開發的設計。Vue 的核心庫只關註視圖層,並且非常容易學習,非常容易與其它庫或已有項目整合。另一方面,Vue 完全有能力驅動採用單文件組件和Vue生態系統支持的庫開發的複雜單頁應用。 那麼在windows系 ...
  • 一、回調函數 優點:簡單,方便,易用 缺點:易造成回調函數地獄,回調函數中嵌套多個回調函數,因為多個非同步操作造成強耦合,代碼亂做一團,無法管理。 二、事件監聽 優點:與回調函數相比,事件監聽實現了代碼的解耦,方便代碼管理 缺點:使用不方便,每次都要手動地綁定和觸發事件 三、Promise 優點:將回 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...