- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 react 性新手
我正在使用FlatList
与 app.js
并使用 StackNavigator
用于像这样的场景之间的导航:
class HomeScreen extends React.Component {
static navigationOptions = {
title: 'Content',
};
render() {
const { navigate } = this.props.navigation;
return (
<View style={styles.container}>
<FlatList
data = {myData}
renderItem={({item}) =>
<Text style={styles.someStyle}
onPress={()=>
navigate("Detail",
{item: item});}>
{item.text}</Text>
}
/>
</View>
);
}
}
上面的代码可以正常工作:当我按下列出的项目之一时,将加载另一个场景以显示项目内容的详细信息。
但是由于我想要列出的项目具有复杂的样式,因此我认为在 subview 中定义列出的项目会很方便,如下所示:
class MyHomeListItem extends React.PureComponent {
render(){
return (
<View style={styles.item}>
<Image
source={require('./assets/book.png')}
style={styles.listImageIcon}
/>
// as you can see the following `onPress` was intended for
// the same poperse which should load another secene to show the detail.
<Text onPress={()=>
{this.props.ref("Detail",
{item: this.props.item});}}
style={styles.listItemHomeText}>
{this.props.chapterName}: {this.props.chapterTitle}
</Text>
</View>
);
}
}
我想传递FlatList
中的数据作为属性,例如:
<FlatList
data = {myData}
renderItem={({item}) => <MyHomeListItem chapterName={item.chapterName} chapterTitle={item.chapterTitle} ref={navigate} /> }
/>
如果我没有通过navigate
函数到 subview ,事情将无法工作,我认为这很好,所以我到目前为止通过ref
传递它这是 navigate
的引用功能(我认为)或只是通过 ref={this}
并使用 this.props.ref.navigate(...)
在 subview 中,但两者都不起作用。
它将显示:
_this3.props.ref is not a function....'_this3.props.ref' is undefined
那么我该怎么做呢?
此外,我实际上希望整个 subview 都听 onPress
但我没有找到onPress
<View>
的属性
最佳答案
我相信 ref
是一个保留的 prop,用于将子组件分配给父组件的 ref,以便父组件可以轻松引用子组件。尝试直接通过 navigation={navigate}
此外,如果您希望整个 View
具有 onPress
,请尝试将 View
包装在 Touchable
之一中> 的,即 TouchableHighlight
、TouchableOpacity
或 TouchableWithoutFeedback
。并将 onPress
函数作为 prop 传递给 Touchable
组件。
此外,就我个人而言,我更喜欢在主页中定义导航逻辑,而项目组件中的 onPress 函数只会传回相应的对象以进行行备份通过从 HomeScreen 组件传递下来的 onRowPress
属性。这样,导航逻辑就不会到处都是,并且行项目组件可以足够通用,以便 onPress 函数始终只传回相应的对象。
关于javascript - react native 传递导航到 subview ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45239775/
我在自定义表格单元格中长按时添加 subview ,但是当我滚动表格时, subview 消失。 p> 我应该怎么做,以便当我向后滚动时,该 subview 仍然显示/出现在该单元格上,或者换句话说,
如何遍历 UIView 的所有 subview ,以及它们的 subview 和它们的 subview ? 最佳答案 使用递归: // UIView+HierarchyLogging.h @inter
如果我有 contentView 和 2 个 subview 。我想根据subviewB居中subviewA subviewA 和 subviewB 有相同的父 View 。 这就是我现在正在做的,将
我想向 self.view 添加一个覆盖整个区域的 subview (如调光 View )。但在它下面,有一些 View 我不希望受到添加的 subview 的影响(我不希望这些 View 具有变暗的
我正在尝试向 UITabBar 添加 subview ,它应该位于其他 UITabBar subview 之后。 我在 UITabBarController 的子类中添加了这样的 subview :
图像描述了我必须将这种 subview 添加到我现有的单元格中,并且在多次单击“添加”图标时还要添加相同的 subview 。 我在添加 subview 时遇到困难。如果有人能为我提供处理此结构的正确
我添加了一个 subview ,如下所示: func showPlayerView2() { self.view.frame = CGRect(x: 0, y: 0, width: view.
我的问题是关于 UIView/CALayer: Transform triggers layoutSubviews in superview 据报道,来自苹果的 TSI 回复: Generally,
我试图为我的主视图创建一个辅助 View 。这个 subview 需要很小的高度,它需要适合另一个带有标签的大 UIView。 问题是当我使用 UIView addSubview 时,第三个 UIVi
我正在尝试淡出整个 View ,但只有一个特定的 subview , 这将强调 subview更清晰的外观。假设 self.view 有 5 textfields和 2 UIView如subviews
我确信我在这里错过了一些愚蠢的东西,但我有 mainView、subviewA 和 subviewB。我试图将 subviewB 添加到 subviewA 并将其锚定在 subviewA 内部,但是它
我有一个包含 3 个 subview 的 View ,分别称为 view A、view B、view C。 当我删除 subview 时,意味着我需要自动设置边距以进行调整。 当我删除 view A
我有两个加载的 subview 。一个是位于 View Controller 内部的选项卡栏,它很早就加载,第二个是按下选项卡栏项目时出现的 View 。 但是,当添加此 subview 时,它会加载
在 iOS 应用中,我在主视图中添加了一个 subview : [self.view addSubview:firstUIImageSubview]; 但是在 subview 类 firstUIIma
我正在制作一个球程序,您可以通过长按手势将球 UIView subview 添加到 super View 。点击 View 会将其从父 View 中移除。 添加所有 View 效果很好,重新添加 Vi
我使用以下代码在单击按钮时将日期选择器 View 添加到我的应用程序主视图。 - (IBAction)CalenderButton_Click:(id)sender { // code to add
我正在努力向 View 添加 subview 。进度变量在其 View Controller 的 viewDidLoad() 中设置。 progressView frame size 设置正确,只是添
这是我的代码 var button = [UIButton?](count:3, repeatedValue: UIButton()) for i in 0...2{
我有一个 UIViewController,里面有几个不同的 UIView subview 。当用户调用某个 Action 时,我手动更改每个的大小、比例和位置。我想更新其中一个 UILabel( s
我的屏幕有一个主视图模型。它由 2 个 subview 模型组成。 其中一个负责注册部分。其中一个处理登录部分。其中一个负责处理菜单部分(如果经过身份验证,可以显示哪些菜单项,以及“欢迎“用户名”类型
我是一名优秀的程序员,十分优秀!