标签:onchange 方向 nav basis 文档 extends 点击 letters osi
做前端开发,熟悉了HTML+CSS+JS的开发模式,如果不看RN原理,直接用老一套的逻辑思维上手RN,可能会大跌眼镜。高效开发的前提,需要学习并理解RN的原理。本文主要记录内容是,关于RN开发的HTML层面上的问题。
RN提供的组件(在HTML中叫标签)中常用的有:
可用属性
可用属性:
省略号
的形式显示可用属性:
可用属性:
const StylesComponent = StyleSheet.create({
text:{fontSize: 14},
textColor:{color:‘#fff‘}
});
<Text style={StylesComponent.text}></Text>
<Text style={{color:‘#fff‘}}></Text>
<Text style={[StylesComponent.text,{color:‘#fff‘}]}></Text>
<Text style={[StylesComponent.text,StylesComponent.textColor]}></Text>
width包括border和padding
在 React-Native 中的flexbox 是css3中flexbox的一个子集,并不支持所有的flexbox属性
React-native Valid style props: [
"alignContent",
"alignItems",//父元素的样式,子元素在当前侧轴方向上的对齐方式;如flexDirection为row时,center表示子元素垂直居中;子元素如果设置了alignSelf属性,则会重写该属性
"alignSelf",//子元素的样式,设置该元素单独在侧轴方向上的对齐方式
"aspectRatio",//元素宽高比,RN独有,设置了图片的宽度后,只需设置好这个属性,就不需要设置图片的高度
"backfaceVisibility",
"backgroundColor",
"borderBottomColor",
"borderBottomLeftRadius",
"borderBottomRightRadius",
"borderBottomWidth",
"borderColor",
"borderLeftColor",
"borderLeftWidth",
"borderRadius",
"borderRightColor",
"borderRightWidth",
"borderStyle",
"borderTopColor",
"borderTopLeftRadius",
"borderTopRightRadius",
"borderTopWidth",
"borderWidth",
"bottom",
"color",
"decomposedMatrix",
"direction",
"display",//控制组件显示与隐藏,隐藏后不占位
"elevation",
"flex",
"flexBasis",
"flexDirection",//默认为column,子元素垂直排列,可设置为row,子元素水平排列
"flexGrow",
"flexShrink",
"flexWrap",
"fontFamily",
"fontSize",
"fontStyle",
"fontVariant",
"fontWeight",
"height",
"includeFontPadding",
"justifyContent",
"left",
"letterSpacing",
"lineHeight",
"margin",
"marginBottom",
"marginHorizontal",
"marginLeft",
"marginRight",
"marginTop",
"marginVertical",
"maxHeight",
"maxWidth",
"minHeight",
"minWidth",
"opacity",
"overflow",
"overlayColor",
"padding",
"paddingBottom",
"paddingHorizontal",
"paddingLeft",
"paddingRight",
"paddingTop",
"paddingVertical",
"position",//RN元素定位类型只有两种:relative相对于正常文档流进行偏移;absolute相对于父元素进行绝对定位,不管父元素设置position属性与否;
"resizeMode”,(cover图片铺满)
"right",
"rotation",
"scaleX",
"scaleY",
"shadowColor",
"shadowOffset",
"shadowOpacity",
"shadowRadius",
"textAlign",
"textAlignVertical",
"textDecorationColor",
"textDecorationLine",
"textDecorationStyle",
"textShadowColor",
"textShadowOffset",
"textShadowRadius",
"tintColor",
"top",
"transform",transform:[{rotate:‘30deg‘},{translate:[-waterMarkW,0]}]
"transformMatrix",
"translateX",
"translateY",
"width",
"writingDirection",
"zIndex"
]
Label组件实现代码如下:
class Label extends Component {
constructor(props) {
super(props);
this.state = {
selected: false,
};
}
clicked() {
if (this.state.selected) {
this.setState({
selected: false,
});
} else {
this.setState({
selected: true,
});
}
}
render() {
return (
<TouchableOpacity onPress={() => { this.clicked(); }} activeOpacity={1}>
<View
style={{
borderWidth: D(1),
width: D(64),
height: D(24),
borderRadius: D(2),
alignItems: ‘center‘,
justifyContent: ‘center‘,
marginTop: D(16),
backgroundColor: this.state.selected ? ‘#fff‘ : ‘#f5f5f5‘,
borderColor: this.state.selected ? ‘#ff6700‘ : ‘#f5f5f5‘,
marginRight: (this.props.index + 1) % 3 == 0 ? D(10) : D(16),
}}
>
<Text
style={{
color: this.state.selected ? ‘#ff6700‘ : ‘#757575‘,
}}
>{this.props.item}
</Text>
</View>
</TouchableOpacity>
);
}
}
布局如下,maxWidth失效:
<View style={{ maxWidth: 100 }}>
<Text>123</Text>
</View>
改变方案如下,maxWidth生效:
<View style={{ flexDirection: ‘row‘, justifyContent: ‘flex-start‘ }}>
<View style={{ maxWidth: 100 }}>
<Text>123</Text>
</View>
</View>
生效原因,改变了主轴的方向
,flex水平布局时maxWidth才会生效,但flex默认为垂直布局;
<TextInput
onChange={(e) => { this.onChange(e); }}
ref="textInput"
/>
onChange(e) {
console.log(e);// {eventCount:‘‘,target:‘‘,text:‘‘}
}
react-native 获取组件的尺寸有两种方式:
但是这种方式有一个局限性:
初次渲染
的时候才会触发这个函数,组件相对于父组件的位置坐标
。这里封装一个layout的函数,当我们需要获取组件的宽度和高度或者位置信息时,就可以通过调用这个函数去获取。
layout
函数接受一个ref参数
,这个参数表示组件的实例,传入组件的实例后,然后通过findNodeHandle方法获取组件节点。UIManager.measure
接受两个参数,
findNodeHandle获取的组件节点
第二个参数是获取成功的回调
import { findNodeHandle, UIManager } from ‘react-native‘;
<TextInput
onChange={(e) => { this.onChange(e); }}
ref="textInput"
/>
onChange(e) {
this.layout(this.refs.textInput)
.then((item) => {
console.log(item);// 可以在then回调中同步获取数据{x,y,width,height,pageX,pageY}
});
}
layout(ref) {
const handle = findNodeHandle(ref);
return new Promise((resolve) => {
UIManager.measure(handle,
(x, y, width, height, pageX, pageY) => {
resolve({
x, y, width, height, pageX, pageY,
});
});
});
}
标签:onchange 方向 nav basis 文档 extends 点击 letters osi
原文地址:https://www.cnblogs.com/qiqi715/p/9404816.html