我有一个反应原生应用程序,我有一个搜索栏和一个FlatList。我的搜索逻辑如下
handleSearch(text) {
const newData = _.filter(this.state.temp, (item) => {
const itemData = item.Desc ? item.Desc.toUpperCase() : ''.toUpperCase();
const textParts = text.toUpperCase().split(' ');
let idx = itemData.indexOf(textParts);
let shouldInclude = true;
for (let i = 0; i < textParts.length; i++) {
const part = textParts[i];
shouldInclude = shouldInclude && (itemData.indexOf(part) > -1);
if (!shouldInclude) {
return false;
}
}
return true;
});
this.setState({
notifications: newData,
value: text
});
}
搜索栏:
<SearchBar
lightTheme
value= {value}
inputStyle={{margin: 0}}
placeholder="Search here...."
onChangeText={(text)=>{this.handleSearch(text,false)}}
onTouchStart={()=>{this.renderDropdown(true)}}
/>
FlatList:
render() {
return
<FlatList
keyExtractor={(item, id) => item.id}
data={notifications}
renderItem={this.renderItem.bind(this)}
/>
}
渲染项:
renderItem({item}) {
return <Item item={item}
onPress = {()=> {this.goToDetails()}
/>
}
项目组成部分:
export default class Item extends Component {
handlePress() {
return this.props.onPress();
}
render() {
const {
row,
textContainer,
id,
ordername,
desc,
seperator
} = styles;
const {
item
} = this.props;
const {
Id,
OrderName,
Desc
} = item;
return (
<View>
<TouchableOpacity onPress = {
() => {this.handlePress()>
<View style = {seperator}>
</View>
<View style = {row}>
<View style = {textContainer}>
<Text style = {id}>{Id}</Text>
<Text style = {ordername}>{OrderName}</Text>
<Text style = {desc}>{Desc}</Text>
</View>
<View style = {seperator}>
</View>
</View>
</TouchableOpacity>
</View>
)
}
}
const styles = StyleSheet.create({
row: {
flexDirection: 'row',
alignItems: 'flex-start',
marginLeft: 15,
marginRight: 15,
backgroundColor: 'white',
paddingTop: 5,
paddingBottom: 10
},
textContainer: {
flex: 3,
paddingLeft: 5,
fontWeight: 'bold',
fontSize: 8
},
id: {
flex: 1,
fontSize: 14,
color: 'black',
fontSize: 15
},
ordername: {
flex: 1,
fontSize: 14,
color: 'blue',
fontSize: 15
},
desc: {
flex: 1,
fontSize: 14,
color: 'blue',
fontSize: 15
},
seperator: {
padding: 20
}
})
我想要一个搜索过滤器高亮显示,如下所示,当我开始在搜索栏中键入文本时,平面列表中的文本必须高亮显示。
我如何实现这个??反应本族语突出词?有什么功能吗?请帮忙
它看起来像SearcBar
值存储为this.state.value
,将其传递给Item
并使用regex
来分割您的文本(使用Desc
作为参考,使用它作为适合你...(
renderItem({item}) {
return <Item
item={item}
onPress = {()=> {this.goToDetails()}
value={this.state.value}
/>
}
//Item.js
getHighlightedText = text => {
const { value } = this.props
const parts = text.split(new RegExp(`(${value})`, 'gi'));
return <Text style={desc}>
{parts.map(part => part.toLowerCase() === value.toLowerCase()
? <View style={{backgroundColor: 'red'}}>{part}</View>
: part)}
</Text>;
}
<View> {this.getHighlightedText(Desc)} </View>
问题内容: 我想使用jQuery / Java脚本搜索并突出显示文本。 示例HTML 1: 当我搜索字符串“ Good Morning”时,div1和div3中的内容都应突出显示。即。输出html应该是 我使用了插件https://raw.github.com/bartaz/sandbox.js/master/jquery.highlight.js将搜索到的内容包含在span中。但是只有div3高
问题内容: 我正在使用此代码突出显示搜索关键字: 但是,这仅突出显示一个关键字。如果用户输入多个关键字,则会缩小搜索范围,但不会突出显示任何单词。如何突出显示多个单词? 问题答案: 正则表达式是必经之路! 要以不区分大小写的方式进行匹配,请在正则表达式中添加“ i” 注意:对于像“ä”这样的非英语字母,结果可能会因地区而异。
问题内容: 如何突出显示使用php的mysql查询的搜索结果? 这是我的 [修改] 代码: 问题答案: 您可以使用preg_replace();,当它在文本中找到匹配项时,您可以在匹配词周围放置一个带有突出显示类别的div。然后,您可以向突出显示类添加背景颜色和边框,以使其突出显示 preg_replace期望3个参数; 第一个是您要寻找的 第二个是应该更改为 他应从中搜索并替换的文本字符串 例如
如果所有未分析的字段与搜索查询匹配,我希望突出显示它们。 索引实体如下所示: 假设我有一个,它带有,然后运行一个具有相同值的搜索查询,并使用以下代码突出显示搜索结果: 因此,我得到以下代码片段:. 这似乎是合理的,因为分析器将符号视为停止字,而将视为分隔符,并且不突出显示它们。但是我不知道如何在突出显示这个字段的同时避免使用analyzer。类中有一些方法需要而不是,但我不知道如何使用它们。 我想
搜索“adida shi”,应该会得到两个商品,一个是名称为“adidas shirts”,另一个是“adidas red shirts” 预期突出显示: 实际突出显示: 有什么想法让它工作吗?
问题内容: 我可以高亮显示一些文本,使其从一个值开始,然后从另一个值结束,如下所示,但颜色为黄色吗? “” JTextPane 高亮显示 文本“” 谢谢。 问题答案: 通常,有几种可能性,具体取决于您对“突出显示”的真正含义:-) 通过在文档级别更改任意文本部分的样式属性来突出显示,例如 通过textPane级别上的荧光笔突出显示: