Categories: react native

JSX for HTML Addicts

JSX stands for Javascript Extension (although most sites like W3 schools refer to it as Javascript XML).

JSX is used by transpilers like babel to transform HTML-like syntax into standard JavaScript objects that a JavaScript engine can parse.

With JSX, it is more convenient to write HTML-like syntax in React or React Native. It essentially converts HTML tags into React elements. And for the purpose of this article to be actualised, we shall be focusing on React Native.

React Native is a lot like React in some respects, but the clear difference between the two is that React Native makes use of native components instead of web components as its building blocks.

To fully comprehend the basic structure of a React Native app, it is paramount that you first understand some of the basic React concepts, like JSX.

Here is a simple Hello World app in React Native:

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

class App extends Component {
render(){
return(
<View>
<Text>Hello World!</Text>
</View>
)
}
}
export default App;

The import statement at the top is what enables JSX in the project and helps transform the written codes to native components of each platform.

Next is the render function which helps to mount the component. Our JSX is written inside the return function. in React Js, the “View” will be replaced with “div”.

Then other components follow suit. For instance you can add TextInput, Image, ImageBackground, etc, just like you would do in HTML. But also notice the camel-case-like syntax.

Styling JSX

JSX components can be styled much in the same way like HTML. You could follow an inline styling method, embedded or just have a dedicated style sheet as you would normally do in CSS.

For you to use the styling component in React Native, you have to first import StyleSheet. Also the styling pattern follows a strict camel-case pattern.

Here’s what I mean:

<background-image> becomes <ImageBackground>
<image> becomes <Image>
<input /> becomes <TextInput />
<p> becomes <Text>

Summary

Understanding these basic concepts help you get started on your React Native project.

JSX helps you write HTML/XML-like structures (e.g., DOM-like tree structures) in the same file where you write JavaScript code, which the preprocessor will transform into actual JavaScript code.

Recent Posts

JavaScript Memoization

In JavaScript, it’s commonly used for: Recursive functions (like Fibonacci) Heavy calculations Repeated API/data processing…

3 weeks ago

CSS Container Queries: Responsive Design That Actually Makes Sense

For years, responsive design has depended almost entirely on media queries. We ask questions like: “If…

3 weeks ago

Cron Jobs & Task Scheduling

1. What is Task Scheduling? Task scheduling is the process of automatically running commands, scripts,…

3 weeks ago

Differences Between a Website and a Web App

Here’s a comprehensive, clear differentiation between a Website and a Web App, from purpose all the…

1 month ago

Essential VS Code Extensions Every Developer Should Use

Visual Studio Code (VS Code) is powerful out of the box, but its real strength…

1 month ago

JavaScript Variables

1. What Is a Variable in JavaScript? A variable is a named container used to store data…

1 month ago