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

不言
Release: 2018-08-08 14:34:30
Original
7821 people have browsed it

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!

Related labels:
source:php.cn
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template