KEMBAR78
React Js Basics | PDF | Java Script | Software Engineering
0% found this document useful (0 votes)
88 views7 pages

React Js Basics

This document provides information about JSX syntax and usage in React, including: 1. JSX must have a single outermost element. Nested JSX elements are allowed. 2. JSX is a syntax extension of JavaScript that is used to create DOM elements rendered by React DOM. JSX code must be compiled before use in browsers. 3. Multiline JSX expressions must be wrapped in parentheses. JSX syntax closely resembles HTML with angle bracket tags. JavaScript expressions can be embedded within curly braces. 4. The ReactDOM library renders JSX to the actual DOM. The Virtual DOM improves efficiency by only updating changed elements. 5. The JSX "className" attribute replaces
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
88 views7 pages

React Js Basics

This document provides information about JSX syntax and usage in React, including: 1. JSX must have a single outermost element. Nested JSX elements are allowed. 2. JSX is a syntax extension of JavaScript that is used to create DOM elements rendered by React DOM. JSX code must be compiled before use in browsers. 3. Multiline JSX expressions must be wrapped in parentheses. JSX syntax closely resembles HTML with angle bracket tags. JavaScript expressions can be embedded within curly braces. 4. The ReactDOM library renders JSX to the actual DOM. The Virtual DOM improves efficiency by only updating changed elements. 5. The JSX "className" attribute replaces
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 7

Cheatsheets / Learn React

JSX
Nested JSX elements
In order for the code to compile, a JSX expression must
have exactly one outermost element. In the below const myClasses = (

block of code the <a> tag is the outermost element.   <a href="https://www.codecademy.com">

    <h1>

      Sign Up!

    </h1>

  </a>

);

JSX Syntax and JavaScript


JSX is a syntax extension of JavaScript. It’s used to
create DOM elements which are then rendered in the import React from 'react';

React DOM. import ReactDOM from 'react-dom';


A JavaScript file containing JSX will have to be

compiled before it reaches a web browser. The code

ReactDOM.render(<h1>Render me!</h1>,
block shows some example JavaScript code that will
document.getElementById('app'));
need to be compiled.

Multiline JSX Expression


A JSX expression that spans multiple lines must be
wrapped in parentheses: ( and ) . In the example const myList = (

code, we see the opening parentheses on the same line   <ul>


as the constant declaration, before the JSX expression

    <li>item 1</li>
begins. We see the closing parentheses on the line

    <li>item 2</li>
following the end of the JSX expression.

    <li>item 3</li>

  </ul>

);

JSX syntax and HTML


In the block of code we see the similarities between
JSX syntax and HTML: they both use the angle bracket const title = <h1>Welcome all!</h1>
opening and closing tags ( <h1> and </h1> ).

When used in a React component, JSX will be rendered


as HTML in the browser.

JSX attributes
The syntax of JSX attributes closely resembles that of
HTML attributes. In the block of code, inside of the const example = <h1 id="example">JSX
opening tag of the <h1> JSX element, we see an id Attributes</h1>;
attribute with the value "example" .

ReactDOM JavaScript library


The JavaScript library react-dom , sometimes called
ReactDOM , renders JSX elements to the DOM by taking ReactDOM.render(
a JSX expression, creating a corresponding tree of DOM   <h1>This is an example.</h1>,
nodes, and adding that tree to the DOM.   document.getElementById('app')
The code example begins with ReactDOM.render() . The );
first argument is the JSX expression to be compiled and
rendered and the second argument is the HTML
element we want to append it to.

Embedding JavaScript in JSX


JavaScript expressions may be embedded within JSX
expressions. The embedded JavaScript expression let expr = <h1>{10 * 10}</h1>;

must be wrapped in curly braces. // above will be rendered as <h1>100</h1>


In the provided example, we are embedding the

JavaScript expression 10 * 10 within the <h1> tag.


When this JSX expression is rendered to the DOM, the
embedded JavaScript expression is evaluated and
rendered as 100 as the content of the <h1> tag.

The Virtual Dom


React uses Virtual DOM, which can be thought of as a
blueprint of the DOM. When any changes are made to
React elements, the Virtual DOM is updated. The Virtual
DOM finds the differences between it and the DOM and
re-renders only the elements in the DOM that changed.
This makes the Virtual DOM faster and more efficient
than updating the entire DOM.

JSX className
In JSX, you can’t use the word class ! You have to use
className instead. This is because JSX gets translated // When rendered, this JSX expression...

into JavaScript, and class is a reserved word in const heading = <h1 className="large-
JavaScript. heading">Codecademy</h1>;
When JSX is rendered, JSX className attributes are

automatically rendered as class attributes.

// ...will be rendered as this HTML


<h1 class="large-heading">Codecademy</h1>

JSX and conditional


In JSX, && is commonly used to render an element
based on a boolean condition. && works best in // All of the list items will display if
conditionals that will sometimes do an action, but other // baby is false and age is above 25
times do nothing at all. const tasty = (
If the expression on the left of the && evaluates as   <ul>
true, then the JSX on the right of the && will be
    <li>Applesauce</li>
rendered. If the first expression is false, however, then
    { !baby && <li>Pizza</li> }
the JSX to the right of the && will be ignored and not
    { age > 15 && <li>Brussels
rendered.
Sprouts</li> }
    { age > 20 && <li>Oysters</li> }
    { age > 25 && <li>Grappa</li> }
  </ul>
);
JSX conditionals
JSX does not support if/else syntax in embedded
JavaScript. There are three ways to express // Using ternary operator
conditionals for use with JSX elements: const headline = (
  <h1>
1. a ternary within curly braces in JSX
    { age >= drinkingAge ? 'Buy Drink'
2. an if statement outside a JSX element, or : 'Do Teen Stuff' }
3. the && operator.   </h1>
);

// Using if/else outside of JSX


let text;

if (age >= drinkingAge) { text = 'Buy


Drink' }
else { text = 'Do Teen Stuff' }

const headline = <h1>{ text }</h1>

// Using && operator. Renders as empty


div if length is 0
const unreadMessages = [ 'hello?',
'remember me!'];

const update = (


  <div>
    {unreadMessages.length > 0 &&
      <h1>
        You have {unreadMessages.length}
unread messages.
      </h1>
    }
  </div>
);

Embedding JavaScript code in JSX


Any text between JSX tags will be read as text content,
not as JavaScript. In order for the text to be read as <p>{ Math.random() }</p>
JavaScript, the code must be embedded between curly
braces { } . // Above JSX will be rendered something
like this:
<p>0.88</p>
JSX element event listeners
In JSX, event listeners are specified as attributes on
elements. An event listener attribute’s name should be // Basic example
written in camelCase, such as onClick for an onclick const handleClick = () => alert("Hello
event, and onMouseOver for an onmouseover event. world!");
An event listener attribute’s value should be a function.
Event listener functions can be declared inline or as
const button = <button onClick=
variables and they can optionally take one argument
{handleClick}>Click here</button>;
representing the event.

// Example with event parameter


const handleMouseOver = (event) =>
event.target.style.color = 'purple';

const button2 = <div onMouseOver=


{handleMouseOver}>Drag here to change
color</div>;

Setting JSX attribute values with embedded JavaScript


When writing JSX, it’s common to set attributes using
embedded JavaScript variables. const introClass = "introduction";
const introParagraph = <p className=
{introClass}>Hello world</p>;

JSX .map() method


The array method map() comes up often in React. It’s
good to get in the habit of using it alongside JSX. const strings = ['Home', 'Shop', 'About
If you want to create a list of JSX elements from a given Me'];
array, then map() over each element in the array,
returning a list item for each one. const listItems = strings.map(string =>
<li>{string}</li>);

<ul>{listItems}</ul>

JSX empty elements syntax


In JSX, empty elements must explicitly be closed using
a closing slash at the end of their tag: <tagName /> . <br />
A couple examples of empty element tags that must <img src="example_url" />
explicitly be closed include <br> and <img> .
React.createElement() Creates Virtual DOM Elements
The React.createElement() function is used by React to
actually create virtual DOM elements from JSX. When // The following JSX...
the JSX is compiled, it is replaced by calls to const h1 = <h1 className="header">Hello
React.createElement() . world</h1>;
You usually won’t write this function yourself, but it’s
useful to know about.
// ...will be compiled to the following:
const h1 = React.createElement(
  'h1',
  {
    className: 'header',
  },
  'Hello world'
);

JSX key attribute


In JSX elements in a list, the key attribute is used to
uniquely identify individual elements. It is declared like <ul>
any other attribute.   <li key="key1">One</li>
Keys can help performance because they allow React   <li key="key2">Two</li>
to keep track of whether individual list items should be   <li key="key3">Three</li>
rendered, or if the order of individual items is
  <li key="key4">Four</li>
important.
</ul>

You might also like