IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 利用umi.js 3.5+Dva.js 搭建React框架 -> 正文阅读

[JavaScript知识库]利用umi.js 3.5+Dva.js 搭建React框架

搭建umi基本框架

umi.js脚手架基本搭建
搭建完成后得到下图所示目录结构:
在这里插入图片描述
使用命令启动项目

yarn start

在这里插入图片描述

  1. 因为项目默认使用ts和React Hooks
  2. 没有引入 Dva.js

引入dva.js

找到项目目录下的 .umirc.ts 文件,加入如下配置项

 dva: {
    immer: true, // 表示是否启用 immer 以方便修改 reducer
    hmr: false, // 表示是否启用 dva model 的热更新
  },

在src下新建models文件夹,在pages下新建Demo1文件夹,在Demo1中新建models文件夹,如下图所示:
在这里插入图片描述

class组件写新页面

在上文中新建Demo1文件夹下建立 index.js 文件,内容如下:

import React, { Fragment } from 'react';

class Demo extends React.PureComponent {
    constructor(props) {
        super(props);
    }

    render() {
        console.log(this.props);
        return (
            <Fragment>
                <div>开始配置dva.js </div>
            </Fragment>
        )
    }
}

export default Demo;

定义Dva Models并建立连接

src/pages/Demo1/models 新建文件 DemoModel.js

export default {
    namespace: 'firstDemoModel',

    state: {
        data: [
            { text: 'fighting', value: 'nine' },
        ],
    },

    effects: {},

    reducers: {
        save(state, payload) {
            return {
                ...state,
                ...payload,
            };
        },
    },
};

输入以上的代码即建立了名称为firstDemoModel的model,
接下来在上文index.js中输入如下的代码建立与model的连接

import {connect} from 'dva'
@connect(({ firstDemoModel}) => ({
    firstDemoModel,
}))

class Demo extends React.PureComponent {

@connect为函数装饰必须写在class的前面,在index.js中的render函数中输入如下代码即可打印出在this.props可以访问basicDataModel
在这里插入图片描述

完整的Umi配置

修改 .umirc.ts文件夹中配置如下所示

import { defineConfig } from 'umi';

export default defineConfig({
  nodeModulesTransform: { //设置 node_modules 目录下依赖文件的编译方式
    type: 'none',
  },
  routes: [ //umi 的路由基于 react-router@5 实现,配置和 react-router 基本一致
    { path: '/', component: '@/pages/index' },
  ],
  fastRefresh: {}, //快速刷新(Fast Refresh),开发时可以保持组件状态,同时编辑提供即时反馈
  ignoreMomentLocale: true, //忽略 moment 的 locale 文件,用于减少尺寸
  hash: true, //配置是否让生成的文件包含 hash 后缀,通常用于增量发布和避免浏览器加载缓存
  targets: { //配置需要兼容的浏览器最低版本,会自动引入 polyfill 和做语法转换
    ie: 9,
  },
  dva: {
    immer: true,
    hmr: false,
  },
});

以上就是利用UmiJs 搭建React框架并配置Dva.js的全部内容
本项目的Gitee地址

参考文档

UmiJs整合 Dva数据流配置
React 官方文档
UmiJs配置

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:22:38  更:2022-03-10 22:24:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:20:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码