


How to implement dynamic binding of Class and Style in React-JSX (with examples)
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={ 'box-color':this.state.isError }>hello world</p> }
Can be achieved The syntax is as follows:
1. Use logical operators
css file
.box-color { color:red; }
js file
render(){ return <p className={ this.state.isError && 'box-color' }>hello world</p> }
2. Use ternary operator
css file
.box-show { display: block; } .box-hide { display: none; }
render(){ return <p className={ this.state.isShow ? 'box-show' : 'box-hide' }>hello world</p> }
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> }
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> }
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; }
js file
this.state = {isShow: false} render(){ return <p className={ this.state.isShow ? 'box-color' : [ 'box-color', 'box-hide'] }>hello world</p> }
Console display result (invalid, there is an extra comma in the middle):
<p class="box-color, box-hide">hello world</p>
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: 'inline-block'} : { display: 'none'} }>hello world</p> }
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: 'red'} : [{color: 'red'}, {display: 'inline-block'}] }></p> }
The console displays the result (invalid):
<p></p>
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!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

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.

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.

AnexampleofastartingtaginHTMLis,whichbeginsaparagraph.StartingtagsareessentialinHTMLastheyinitiateelements,definetheirtypes,andarecrucialforstructuringwebpagesandconstructingtheDOM.

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

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

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 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.

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...
