91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React的三大核心屬性是什么

發布時間:2022-02-21 13:38:53 來源:億速云 閱讀:153 作者:iii 欄目:開發技術

今天小編給大家分享一下React的三大核心屬性是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

1、State 屬性

React 把組件看成是一個狀態機(State Machines)。通過與用戶的交互,實現不同狀態,然后渲染 UI,讓用戶界面和數據保持一致。

React 里,只需更新組件的 state,然后根據新的 state 重新渲染用戶界面(不要操作 DOM)。

import React from 'react ';
import ReactDom from 'react-dom';
 
 
class Student extends React.Component{
    constructor() {
        super();
        this.state={
            name:'花少北'
        }
    }
    render() {
        this.state.name='老番茄';
        return <h5>{this.state.name}</h5>
    }
}
ReactDOM.render(<Student/>,document.getElementById('root'))

在React中,一個組件中要讀取當前狀態需要訪問 this.state, 而 state 是可以被修改的,但是,要更新數據直接給 this.state 賦值是不可行的,必須要使用 setState()

 this.setState() {
        name:'某幻'
    }

(1)setState 不會立刻改變React組件中state的值.

(2)setState 通過觸發一次組件的更新來引發重繪.

(3)多次 setState 函數調用產生的效果會合并。

2、Props  屬性

react中說的單向數據流值說的就是props,根據這一特點它還有一個作用:組件之間的通信。props本身是不可變的,但是有一種情形它貌似可變,即是將父組件的state作為子組件的props,當父組件的state改變,子組件的props也跟著改變,其實它仍舊遵循了這一定律:props是不可更改的。

props屬性的特點

1.每個組件對象都會有props(properties的簡寫)屬性

2.組件標簽的所有屬性都保存在props中

3.內部讀取某個屬性值:this.props.propertyName

4.作用:通過標簽屬性從組件外 向組件內傳遞數據(只讀 read only)

5.對props中的屬性值進行類型限制和必要性限制

類組件:

import React from 'react ';
import ReactDom from 'react-dom';
// 函數組件
function  Student(props){
    return <p>{props.name} {props.address}</p>
}
 
const  Stu={
    name:'某幻',
        address:'青島'
}
 
ReactDOM.render(<Student{...Stu} ></Student>,document.getElementById('root'))

 函數組件:

import React from 'react ';
import ReactDom from 'react-dom';
class Student extends React.Component{
    render() {
     return(
         <p>{this.props.name} {this.props.address}</p>
     )
    }
}
const  Stu={
    name:'某幻',
        address:'青島'
}
ReactDOM.render(<Student{...Stu} ></Student>,document.getElementById('root'))

props 屬性 和 state 屬性的區別

  • props中的數據都是外界傳遞過來的;

  • state中的數據都是組件私有的;(通過Ajax獲取回來的數據,一般都是私有數據)

  • props中的數據都是只讀的,不能重新賦值;

  • state中的數據,都是可讀可寫的;

  • 子組件只能通過props傳遞數據;

3、Refs  屬性 

定義:組件內的標簽可以定義ref屬性類標識自己,有點類似與JS中的id

React文檔中再三強調,請不要過度使用refs,所以當我們可以用dom原生對象解決時,盡量不要使用refs 依照之前的寫法,首先是給出類組件和函數組件中refs的寫法

ref 的三種形式

(1)字符串形式

【官方不推薦】

class App extends React.Component{
    changeInput = ()=>{
        const {input} = this.refs
    }
    render() {
        return (
            <div>
                <input type="text" placeholder={"please input your value"} onBlur={this.changeInput} ref={"input"}/>
            </div>
        )
    }
}

(2)函數回調形式

class App extends React.Component{
    changeInput = ()=>{
        console.log(this.inputRef);
    }
    render() {
        return (
            <div>
                <input type="text" placeholder={"please input your value"} onBlur={this.changeInput} ref={(el)=>{this.inputRef = el}}/>
            </div>
        )
    }
}

(3)createRef 創建 ref 容器

【目前官方最推薦的一種】

class App extends React.Component{
    inputRef = React.createRef()
    changeInput = ()=>{
        console.log(this.inputRef.current);
    }
    render() {
        return (
            <div>
                <input type="text" placeholder={"please input your value"} onBlur={this.changeInput} ref={this.inputRef}/>
            </div>
        )
    }
}

函數組件的寫法

function App(){
    const inputRef = useRef("")
    return (
        <div>
            <input type="text" placeholder={"please input your value"} ref={inputRef}/>
        </div>
    )
}

以上就是“React的三大核心屬性是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平和县| 平南县| 平利县| 璧山县| 日土县| 抚松县| 武陟县| 海原县| 普兰店市| 凤山市| 襄樊市| 南召县| 彩票| 海门市| 新和县| 璧山县| 许昌县| 太保市| 平和县| 尖扎县| 如皋市| 揭阳市| 玛纳斯县| 绩溪县| 米脂县| 密云县| 南昌县| 儋州市| 安泽县| 阳信县| 武穴市| 天门市| 东至县| 濉溪县| 舒城县| 于都县| 金湖县| 舒兰市| 张家界市| 师宗县| 河南省|