首頁  >  文章  >  web前端  >  為什麼react要用專門的元件來渲染列表

為什麼react要用專門的元件來渲染列表

WBOY
WBOY原創
2022-05-05 10:33:151894瀏覽

因為react在渲染大型資料集合時,協調器必須評估每個變化的集合所產生的的元件,效率非常低;而使用專門的元件來渲染列表,就可以提高渲染大型資料集合的表現,並且不再渲染其他元件。

為什麼react要用專門的元件來渲染列表

本教學操作環境:Windows10系統、react17.0.1版、Dell G3電腦。

為什麼react要用專門的元件來渲染清單

在專用元件中渲染清單

這一點在渲染大型資料集合的時候尤其重要。 React在渲染大型資料集時表現的非常差,因為協調器必須評估每個變化的集合所產生的元件。因此,建議使用專門的元件來映射集合(數組)並且渲染這個元件,切不再渲染其他元件:

不好的:

class MyComponent extends Component {
    render() {
        const {todos, user} = this.props;
        return (<div>
            {user.name}
            <ul>
                {todos.map(todo => <TodoView todo={todo} key={todo.id} />)}
            </ul>
        </div>)
    }
}

在上面範例中,當user. name 改變時,React 會不必要的協調所有的TodoView 元件. 儘管TodoView元件不會重新渲染,但是協調的過程本身就非常昂貴.

好的:

class MyComponent extends Component {
    render() {
        const {todos, user} = this.props;
        return (<div>
            {user.name}
            <TodosView todos={todos} />
        </div>)
    }
}
class TodosView extends Component {
    render() {
        const {todos} = this.props;
        return <ul>
            {todos.map(todo => <TodoView todo={todo} key={todo.id} />)}
        </ul>)
    }
}

React中的列表渲染

Vue.js中使用v-for 實作範本中的列表項目循環渲染;

小程式中使用wx:for 實作範本中的列表項目循環渲染;

React中沒有模板(即不需要v-for),也沒有指令系統(即沒有提供類似的機制)。

方法1:for循環遍歷

import React, { Component } from &#39;react&#39;
export default class App extends Component {
// 假设服务器端返回如下
state={books:[&#39;巴黎圣母院&#39;,&#39;悲惨世界&#39;,&#39;爱的教育&#39;,&#39;简·爱&#39;,&#39;钢铁是怎样炼成的&#39;,&#39;安徒生童话&#39;]}
booklist(){
// 把服务器端返回的字符串数组转换为JSX数组
let arr=[]
for(let i=0;i<this.state.books.length;i++){
arr.push( <li key={i}>《{this.state.books[i]}》</li> )
}
return arr
}
render() {
return (
<div>
<ul>
{this.booklist()}
</ul>
</div>
)
}
}

方法2:建立函數傳回映射後的JSX陣列

showList(){
return   this.state.list.map( (e,i)=>JSX )
}
{this.showList() }
import React, { Component } from &#39;react&#39;
export default class App extends Component {
// 假设服务器端返回如下
state={books:[&#39;巴黎圣母院&#39;,&#39;悲惨世界&#39;,&#39;爱的教育&#39;,&#39;简·爱&#39;,&#39;钢铁是怎样炼成的&#39;,&#39;安徒生童话&#39;]}
booklist(){
// 把服务器端返回的字符串数组转换为JSX数组
return this.state.books.map( (b,i)=> <li key={i}>《{b}》</li> )
}
render() {
return (
<div>
<ul>
{this.booklist()}
</ul>
</div>
)
}
}

方法3:直接綁定映射後的JSX陣列

{
this.state.list.map( (e,i)=>JSX )
}
import React, { Component } from &#39;react&#39;
export default class App extends Component {
// 假设服务器端返回如下
state={books:[&#39;巴黎圣母院&#39;,&#39;悲惨世界&#39;,&#39;爱的教育&#39;,&#39;简·爱&#39;,&#39;钢铁是怎样炼成的&#39;,&#39;安徒生童话&#39;]}
render() {
return (
<div>
<ul>
{/*this.booklist()*/}
{
/*此处不能急 编写for循环——for不是表达式*/
this.state.books.map( (b,i)=> <li key={i}>《{b}》</li> )
}
</ul>
</div>
)
}
}

以上幾種方法出來的結果都是一樣的,如下圖所示

為什麼react要用專門的元件來渲染列表

##推薦學習:《

react影片教學

以上是為什麼react要用專門的元件來渲染列表的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn