I am working on a React Native project that requires that I fetch posts from a WordPress website,
this is my code
render() {
if (this.state.isLoading){
return(
<View style={{flex: 1, justifyContent: 'center',}}>
<ActivityIndicator />
</View>
)
}
else{
let posts = this.state.data.map((post, index) => {
function strip_html_tags(str)
{
if ((str===null) || (str===''))
return false;
else
str = str.toString();
return str.replace(/<[^>]*>/g, '');
}
return (
<ListItem thumbnail key={index}>
<Left>
<Thumbnail square source={{ uri: post.jetpack_featured_media_url != null ? post.jetpack_featured_media_url : '' }} />
</Left>
<Body>
<Text>{strip_html_tags(post.title.rendered)}</Text>
<Text note numberOfLines={2}>{strip_html_tags(post.excerpt.rendered)}</Text>
</Body>
<Right>
<Button transparent>
<Text>View</Text>
</Button>
</Right>
</ListItem>
);
});
The post rendered with some HTML special characters and I used this code to remove some
function strip_html_tags(str)
{
if ((str===null) || (str===''))
return false;
else
str = str.toString();
return str.replace(/<[^>]*>/g, '');
}
But some won't go out. I still get this:
Solution is to use react-native-render-html or react-native-webview library. Wordpress rest api response contains some html tags so it need to remove this on App.