網站首頁 編程語言 正文
最近遇到了一個需求
先簡單介紹下項目:該項目有一個父類組件,該組件用于提供頁面所需的公共數(shù)據(jù)及內容,后續(xù)所有的組件都需要繼承該組件獲得公共的數(shù)據(jù)。
現(xiàn)在遇到的問題是:我需要在某個組件中引入一個js配置文件,并且該配置文件中的數(shù)據(jù)又必須來子組件,因為該數(shù)據(jù)從父類組件中繼承下來。
那么思路是這樣的:首先我們將配置文件寫成導出一個方法,并且該方法返回配置數(shù)據(jù)的形式,然后在組件文件中引入該配置文件,然后在state中定義一個狀態(tài)存儲配置文件返回的數(shù)據(jù)(也就是調用配置文件導出的方法,并且將配置文件需要的值傳遞進去)
組件代碼
import React, { Component } from "react";
import { babel } from "./configOption";//引入配置文件
// 這部分原本應該是在繼承組件componentDidMount生命周期中通過請求接口獲取相應數(shù)據(jù)
// 這里為了方便,我直接使用變量定義一些數(shù)據(jù)
const data = {
female: "女",
male: "男",
};
export default class App extends Component {
state = {
sex: "",
source: babel(data),//將配置問價需要的參數(shù)傳遞進去,并且將配置好的對象返回,在頁面中使用
};
componentDidMount() {}
render() {
const options = this.state.source.sexList.map((it,i) => <option value={it.value} key={i}>{it.label}</option>)
return (
<div>
<select name="" id="">
{options}
</select>
</div>
);
}
}
配置文件configOption.js代碼
//將需要的數(shù)據(jù)對象傳入
export const babel = (location) => ({
sexList: [
{ label: location.male, value: "male" },
{ label: location.female, value: "female" },
],
});
原文鏈接:https://blog.csdn.net/huanan__/article/details/127250136
相關推薦
- 2023-04-19 nginx: [error] CreateFile() “D:\nginx-1.21.6/logs/
- 2022-09-03 Python實現(xiàn)計算AUC的三種方式總結_python
- 2022-07-20 Python3.7.2環(huán)境安裝
- 2022-08-15 springboot切換為redis緩存
- 2022-06-17 mongodb?數(shù)據(jù)塊的遷移流程分析_MongoDB
- 2023-04-18 MongoDB超大塊數(shù)據(jù)問題解決_MongoDB
- 2022-11-10 關于docker?cgroups資源限制的問題_docker
- 2023-09-12 過擬合(over fit)和欠擬合(under fit)
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支