- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道 this.refs 已被弃用,可以使用 React.createRef 更改它,但在我的情况下是不同的
这是我们的代码
export default class ScrollableTabString extends Component {
static ITEM_PADDING = 15;
static defaultProps = {
tabs: [],
themeColor: '#ff8800',
};
static propTypes = {
tabs: PropTypes.any,
themeColor: PropTypes.string,
};
shouldComponentUpdate(nextProps, nextState) {
if (nextProps.tabs !== this.props.tabs || this.state !== nextState) {
return true;
}
return false;
}
constructor(props) {
super(props);
this.views = [];
this.state = {};
this.scrollableTabRef = React.createRef();
}
componentDidMount() {
setTimeout(() => {
this.select(this.props.defaultSelectTab ? this.props.defaultSelectTab : 0);
}, 300);
}
select(i, code) {
let key = 'tab ' + i;
for (let view of this.views) {
if (view) {
let isSelected = false;
if (view.key === key) {
isSelected = true;
}
// This refs is Object with many ref views
if (this.refs[view.key]) {
this.refs[view.key].select(isSelected);
}
this.scrollableTabRef.current.goToIndex(i);
}
}
if (this.props.onSelected) {
this.props.onSelected(code);
}
}
render() {
this.views = [];
if (this.props.tabs) {
let tabs = this.props.tabs;
for (let i = 0; i < tabs.length; i++) {
if (tabs[i]) {
let key = 'tab ' + i;
let view = (
<TabItem
column={tabs.length}
themeColor={this.props.themeColor}
useTabVersion2={this.props.useTabVersion2}
isFirstItem={i === 0}
isLastItem={i === tabs.length - 1}
ref={key}
key={key}
tabName={tabs[i].name}
onPress={() => {
this.select(i, tabs[i].code);
}}
/>
);
this.views.push(view);
}
}
}
let stypeTab = this.props.useTabVersion2
? null
: { borderBottomWidth: 0.5, borderColor: '#8F8E94' };
return (
<ScrollableTab
ref={this.scrollableTabRef}
style={Platform.OS === 'ios' ? stypeTab : null}
contentContainerStyle={Platform.OS === 'android' ? stypeTab : null}
>
{this.views}
</ScrollableTab>
);
}
}
我想修复来自 eslint 的警告,但在我们的例子中,我不能使用 React.createRef
最佳答案
第一个解决方案
如果您的代码工作正常并且只想抑制 eslint 警告,
请将此行放在文件的第一行:(我相信您的 eslint 警告应该是 react/no-string-refs )
/* eslint react/no-string-refs: 0 */
createRef()
,然后尝试像这样实现:
<ScrollableTab ref={(tab) => this.scrollableTab = tab} ...
然后像这样调用:
this.scrollableTab?.goToIndex(index);
import React, { Component } from 'react';
import { Platform } from 'react-native';
import PropTypes from 'prop-types';
class ScrollableTabString extends Component {
static ITEM_PADDING = 15;
state = { activeTab: null }; scrollableTab;
stypeTab = (!this.props.useTabVersion2 ? { borderBottomWidth: 0.5, borderColor: '#8F8E94' } : null);
shouldComponentUpdate(nextProps, nextState) {
return (nextProps.tabs !== this.props.tabs || this.state !== nextState);
}
componentDidMount() {
this.setState({ activeTab: this.props.defaultSelectTab || 0 });
}
/* If your second param - code is optional, add default value */
select = (index, code = null) => {
let key = `tab ${index}`;
/* Set activeTab state instead of calling function in every views */
this.setState({ activeTab: key });
this.scrollableTab?.goToIndex(index);
/* Not sure what are you archiving, but why don't you use component state and pass the isSelected into item */
/*for (let view of this.views) {
if (view) {}
}*/
this.props.onSelected && this.props.onSelected(code);
}
renderTabs = () => {
const { tabs, themeColor, useTabVersion2 } = this.props;
return tabs?.map((tab, index) => {
if (!tab) { return null; }
return (
<TabItem
key={`tab ${index}`}
column={tabs.length}
themeColor={themeColor}
useTabVersion2={useTabVersion2}
isFirstItem={index === 0}
isLastItem={index === (tabs.length - 1)}
tabName={tab.name}
onPress={() => this.select(index, tab.code)}
isSelected={this.state.activeTab === `tab ${index}`}
/>
);
});
};
render() {
return (
<ScrollableTab
ref={(tab) => this.scrollableTab = tab}
style={Platform.OS === 'ios' ? stypeTab : null}
contentContainerStyle={Platform.OS === 'android' ? stypeTab : null}
>
{this.renderTabs()}
</ScrollableTab>
);
}
}
ScrollableTabString.defaultProps = {
onSelected: null, /* Miss this props */
tabs: [],
themeColor: '#ff8800',
useTabVersion2: false /* Miss this props */
};
ScrollableTabString.propTypes = {
onSelected: PropTypes.func, /* Miss this props */
tabs: PropTypes.any,
themeColor: PropTypes.string,
useTabVersion2: PropTypes.bool /* Miss this props */
};
export default ScrollableTabString;
select()
使用 TabItem 可能会导致几个问题:
select()
将被调用与 TabItem 数量一样多的次数,以改变内部的每个状态)class ScrollableTabString extends Component {
state = { activeTab: null };
selectTab = (tabName) => { this.setState({ activeTab: tabName }); };
renderTabs = () => this.props.tabs?.map((tab, index) => (
<TabItem key={`tab ${index`} tabName={tab.name} onPress={this.selectTab} activeTab={this.state.activeTab} />
));
}
TabItem.js
class TabItem extends Component {
/* Use this function on Touchable component for user to press */
onTabPress = () => this.props.onPress(this.props.tabName);
render() {
const { activeTab, tabName } = this.props;
const isThisTabActive = (activeTab === tabName);
/* Use any props and functions you have to achieve UI, the UI will change according to parent state */
return (
<TouchableOpacity onPress={this.onTabPress} style={isThisTabActive ? styles.activeTab : styles.normalTab}>
<Text>{tabName}</Text>
</TouchableOpacity>
);
}
}
如果你真的有一些状态需要改变
TabItem
,尝试使用
componentDidUpdate()
在那里,但它也应该是一个冗余代码:
componentDidUpdate(prevProps) {
if (this.props.activeTab !== prevProps.activeTab) {
// change your state here
}
}
关于reactjs - 如何解决使用 this.refs 已被弃用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66240584/
@Cacheable在同一类中方法调用无效 上述图片中,同一个类中genLiveBullets()方法调用同类中的queryLiveByRoom()方法,这样即便标识了Cacheable标签,
目录 @Transaction注解导致动态切换更改数据库失效 使用场景 遇到问题 解决 @Transaction
@RequestBody不能class类型匹配 在首次第一次尝试使用@RequestBody注解 开始加载字符串使用post提交(貌似只能post),加Json数据格式传输的时候,
目录 @Autowired注入static接口问题 @Autowired自动注入普通service很方便 但是如果注入static修饰的serv
目录 @RequestBody部分属性丢失 问题描述 JavaBean实现 Controller实现
目录 解决@PathVariable参数接收不完整的问题 今天遇到的问题是: 解决办法: @PathVariable接受的参
这几天在项目里面发现我使用@Transactional注解事务之后,抛了异常居然不回滚。后来终于找到了原因。 如果你也出现了这种情况,可以从下面开始排查。 1、特性 先来了解一下@Trans
概述: ? 1
场景: 在处理定时任务时,由于这几个方法都是静态方法,在aop的切面中使用@Around注解,进行监控方法调用是否有异常。 发现aop没有生效。 代码如下:
最近做项目的时候 用户提出要上传大图片 一张图片有可能十几兆 本来用的第三方的上传控件 有限制图片上传大小的设置 以前设置的是2M&nb
我已经实现了这个SCIM reference code在我们的应用程序中。 我实现的代码确实通过了此postman link中存在的所有用户测试集合。 。我的 SCIM Api 也被 Azure 接受
我一直对“然后”不被等待的行为感到困扰,我明白其原因。然而,我仍然需要绕过它。这是我的用例。 doWork(family) { return doWork1(family)
我正在尝试查找 channel 中的消息是否仍然存在,但是,我不确定如何解决 promise ,查看其他答案和文档,我可以看到它可能是通过函数实现的,但我是不完全确定如何去做。我希望能在这方面获得一些
我有以下情况: 同一工作区中的 2 个 Eclipse 项目:Apa 和 Bepa(为简洁起见,使用化名)。 Apa 项目引用(包括)Bepa 项目。 我在 Bepa 有一个类 X,具有公共(publ
这个问题已经有答案了: Why am I getting a NoClassDefFoundError in Java? (31 个回答) 已关闭 6 年前。 我正在努力学习 spring。所以我输入
我正在写一个小游戏,屏幕上有许多圆圈在移动。 我在两个线程中管理圈子,如下所示: public void run() { int stepCount = 0; int dx;
我在使用 Sympy 求解方程时遇到问题。当我运行代码时,例如: 打印(校正(10)) 我希望它打印一个数字 f。相反,它给我错误:执行中止。 def correction(r): from
好吧,我制作的每个页面都有这个问题。我不确定我做错了什么,但我所有的页面都不适用于所有分辨率。可能是因为我使用的是宽屏?大声笑我不确定,但在小于宽屏分辨率的情况下,它永远不会看起来正确。它的某些部分你
我正在尝试像这样进行一个非常简单的文化 srting 检查 if(culture.ToUpper() == "ES-ES" || "IT-IT") { //do something } else
Closed. This question is off-topic. It is not currently accepting answers. Learn more。 想改进这个问题吗?Upda
我是一名优秀的程序员,十分优秀!