react native

Guide to Using React Native WebView

WebView is essentially a component that is used to load a web pages in your React Native project.

WebView sometimes become necessary in your software development project, especially when you have a website that is already built and you would like to create an app off of it.

How to Use React Native WebView

To use WebView we have to first import it as a component.

yarn add react-native-webview

Next, we use the WebView component as follows.

import React, { Component } from 'react';
import {View} from 'react-native';
import { WebView } from 'react-native-webview';

class App extends Component {
render(){
return(
<WebView source={{ uri: 'https://theproli.com/index' }} 
  ref={(ref) => { this.webview = ref; }}
  scalesPageToFit={ true }
  renderError={ () => this.loadError() }
            />
)
}
}

export default App

If we run the above code, initially we might not really know if the page is loading or not.

So we want to show the use an activity, like a spinner, while the page loads.

This is so that the user will know that something is going on.

constructor(props){
    super(props);
    this.state = {
      visible: true
    }
  }

  hideSpinner() {
    this.setState({ visible: false });
  }

Then we need to call the function onLoad() in the WebView component.

Full code:

import React, { Component } from 'react';
import {View} from 'react-native';
import { WebView } from 'react-native-webview';

class App extends Component {

constructor(props){
    super(props);
    this.state = {
      visible: true
    }
  }

  hideSpinner() {
    this.setState({ visible: false });
  }

render(){
return(
<WebView source={{ uri: 'https://theproli.com/index' }} 
  ref={(ref) => { this.webview = ref; }}
  onLoad={() => this.hideSpinner()}
  scalesPageToFit={ true }
  renderError={ () => this.loadError() }
  />
{this.state.visible && (
 <ActivityIndicator
 style={{ position: "absolute", alignSelf:'center',         flexDirection:'row', top: 0, left: 0, right: 0, bottom:0 }}
 size="large"
 color="#0275d8"
  />
  )}
)
}
}

export default App

Read more on WebView in the React Native docs

Recent Posts

The Golden Ratio (φ)

1. What Is the Golden Ratio? The Golden Ratio, represented by the Greek letter φ (phi), is…

1 day ago

CSS Combinators

In CSS, combinators define relationships between selectors. Instead of selecting elements individually, combinators allow you to target elements based…

4 days ago

Boolean Algebra

Below is a comprehensive, beginner-friendly, yet deeply detailed guide to Boolean Algebra, complete with definitions, laws,…

5 days ago

Why It’s Difficult to Debug Other People’s Code (And what Can be Done About it)

Debugging your own code is hard enough — debugging someone else’s code is a whole…

6 days ago

Complete Git Commands

Git is a free, open-source distributed version control system created by Linus Torvalds.It helps developers: Learn how to…

1 week ago

Bubble Sort Algorithm

Bubble Sort is one of the simplest sorting algorithms in computer science. Although it’s not…

1 week ago