react警告之react-dom.development.js:86 Warning: ReactDOM.render is no longer supported in React 18.dva

在Dva中,将React从17版本升级到18版本时,需要更新启动代码。使用`ReactDOM.createRoot`来替代原来的`ReactDOM.render`进行应用的挂载。引入新版本的ReactDOM,并在容器上创建根组件,然后用`root.render(app.start()())`来启动应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

使用dva开发react项目时,使用react17版本的方式行不通。


问题描述

使用dva开发react项目时,使用react17版本,但目前需要使用18版本

import dva from "dva";
import router from "./router";

const app=dva()

app.router(router)
app.start()

原因分析:

react17版的dva开发不适用了


解决方案:

react18版本dva配置(这里使用了tsx,jsx类似)

import dva from "dva";
import router from "./router";
// import React from "react";
import ReactDOM from 'react-dom/client';
import './index.css'

const container:any=document.getElementById('root')
const root = ReactDOM.createRoot(container);

const app=dva()
app.router(router)

root.render(app.start()())

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

因忍而解

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值