Table of Contents
Binding HTML Class
Object syntax
1. Use logical operators
2. Use ternary operator
3. Data objects bound using functions
Array syntax
Bind inline style
Ternary operator
Home Web Front-end HTML Tutorial How to implement dynamic binding of Class and Style in React-JSX (with examples)

How to implement dynamic binding of Class and Style in React-JSX (with examples)

Aug 08, 2018 pm 02:34 PM

The content of this article is about how to implement dynamic binding of Class and Style in React-JSX (with examples). It has certain reference value. Friends in need can refer to it. I hope it will be useful to you. helped.

Abstract: Manipulating the class list and inline style of elements is a common requirement for data binding. Frequent manipulation of dom elements will reduce JavaScript performance. In order to achieve high-performance js, dynamic binding of classes and styles is a high level of literacy. A must for programmers. This article is based on React-JSX syntax and combined with the implementation methods of other frameworks to introduce how to implement dynamic binding of ClassName and Style.

Note: The examples in this article have been verified. If there are any errors, please criticize and correct them.

Binding HTML Class

Object syntax

We can pass Give className an object to dynamically switch classes:

Note: Using object syntax like vue, applet, etc. is not supported

Error example:

render(){
  return <p className={ &#39;box-color&#39;:this.state.isError }>hello world</p>
}
Copy after login

Can be achieved The syntax is as follows:

1. Use logical operators

css file

.box-color {
  color:red;
}
Copy after login

js file

render(){
  return <p className={ this.state.isError && &#39;box-color&#39; }>hello world</p>
}
Copy after login
2. Use ternary operator

css file

.box-show {
  display: block;
}

.box-hide {
  display: none;
}
Copy after login
render(){
  return <p className={ this.state.isShow ? &#39;box-show&#39; : &#39;box-hide&#39; }>hello world</p>
}
Copy after login
3. Data objects bound using functions

do not have to be defined inline in the template: you can define a function, similar to the computed hook function in vue

js file

getIsError() {
  return this.state.isError ? 'box-color' : '';
}

render(){
  return <p className={ this.getIsError() }>hello world</p>
}
Copy after login

Note: The following way of writing object variables is not supported and no error will be reported. The console className is displayed as [object object], which is invalid.

const classObj = {
  'box-show': this.state.isShow,
  'box-color': this.state.isError
}

render(){
  return <p className={ classObj }>hello world</p>
}
Copy after login

Generally, the function binding method is used in scenarios with complex project logic. If used too much, the view layer and logic layer will be confused and difficult to read and maintain. It is recommended to use logical operators and ternary operations. Character method dynamically binds Class.

Array syntax

React-JSX syntax does not support className array syntax, try the example:

css file

.box-hide {
  display: none;
}

.box-color {
  color:red;
}
Copy after login

js file

this.state = {isShow: false}

render(){
  return <p className={ this.state.isShow ? &#39;box-color&#39; : [ &#39;box-color&#39;, &#39;box-hide&#39;] }>hello world</p>
}
Copy after login

Console display result (invalid, there is an extra comma in the middle):

<p class="box-color, box-hide">hello world</p>
Copy after login

Note: Since array syntax is not supported, you can only reuse the styles in "box-color" to "box-hide" ", use the ternary operator to represent it, which virtually increases the amount of css code.

Bind inline style

Object syntax

The style object syntax is more intuitive than the clasName object, and the processing functions are simpler. The logical operator method and function binding method can Referring to the implementation of className, the following only introduces the use of the ternary operator:

Ternary operator

is similar to Vue's vue-if and WeChat applet's wx-if instruction. You can use style Dynamic implementation of ternary operator

js file

render(){
  return <p style={ this.state.isShow ? {display: &#39;inline-block&#39;} : { display: &#39;none&#39;} }>hello world</p>
}
Copy after login

Array syntax

React-JSX syntax also does not support style array syntax, try the example:

js file

render(){
  return <p style={ this.state.isShow ? {color: &#39;red&#39;} : [{color: &#39;red&#39;}, {display: &#39;inline-block&#39;}] }></p>
}
Copy after login

The console displays the result (invalid):

<p></p>
Copy after login

In short, in order to complete the project requirements with high quality and cope with increasingly complex business scenarios, which involves a large number of dom elements, It is not recommended to name a style variable arbitrarily and then bind it to class and style.

Recommended related articles:

html implements a simple registration page (with code)

link tag link CSS and @import loading What's the difference?

The above is the detailed content of How to implement dynamic binding of Class and Style in React-JSX (with examples). For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is HTML easy to learn for beginners? Is HTML easy to learn for beginners? Apr 07, 2025 am 12:11 AM

HTML is suitable for beginners because it is simple and easy to learn and can quickly see results. 1) The learning curve of HTML is smooth and easy to get started. 2) Just master the basic tags to start creating web pages. 3) High flexibility and can be used in combination with CSS and JavaScript. 4) Rich learning resources and modern tools support the learning process.

The Roles of HTML, CSS, and JavaScript: Core Responsibilities The Roles of HTML, CSS, and JavaScript: Core Responsibilities Apr 08, 2025 pm 07:05 PM

HTML defines the web structure, CSS is responsible for style and layout, and JavaScript gives dynamic interaction. The three perform their duties in web development and jointly build a colorful website.

What is an example of a starting tag in HTML? What is an example of a starting tag in HTML? Apr 06, 2025 am 12:04 AM

AnexampleofastartingtaginHTMLis,whichbeginsaparagraph.StartingtagsareessentialinHTMLastheyinitiateelements,definetheirtypes,andarecrucialforstructuringwebpagesandconstructingtheDOM.

Understanding HTML, CSS, and JavaScript: A Beginner's Guide Understanding HTML, CSS, and JavaScript: A Beginner's Guide Apr 12, 2025 am 12:02 AM

WebdevelopmentreliesonHTML,CSS,andJavaScript:1)HTMLstructurescontent,2)CSSstylesit,and3)JavaScriptaddsinteractivity,formingthebasisofmodernwebexperiences.

Gitee Pages static website deployment failed: How to troubleshoot and resolve single file 404 errors? Gitee Pages static website deployment failed: How to troubleshoot and resolve single file 404 errors? Apr 04, 2025 pm 11:54 PM

GiteePages static website deployment failed: 404 error troubleshooting and resolution when using Gitee...

How to implement adaptive layout of Y-axis position in web annotation? How to implement adaptive layout of Y-axis position in web annotation? Apr 04, 2025 pm 11:30 PM

The Y-axis position adaptive algorithm for web annotation function This article will explore how to implement annotation functions similar to Word documents, especially how to deal with the interval between annotations...

HTML, CSS, and JavaScript: Essential Tools for Web Developers HTML, CSS, and JavaScript: Essential Tools for Web Developers Apr 09, 2025 am 12:12 AM

HTML, CSS and JavaScript are the three pillars of web development. 1. HTML defines the web page structure and uses tags such as, etc. 2. CSS controls the web page style, using selectors and attributes such as color, font-size, etc. 3. JavaScript realizes dynamic effects and interaction, through event monitoring and DOM operations.

How to use CSS3 and JavaScript to achieve the effect of scattering and enlarging the surrounding pictures after clicking? How to use CSS3 and JavaScript to achieve the effect of scattering and enlarging the surrounding pictures after clicking? Apr 05, 2025 am 06:15 AM

To achieve the effect of scattering and enlarging the surrounding images after clicking on the image, many web designs need to achieve an interactive effect: click on a certain image to make the surrounding...

See all articles