React.js:組件帆吻,事件域那,state,props

我們來(lái)寫(xiě)上次提到的組件猜煮,計(jì)數(shù)器次员。

組件

/src 下新建一個(gè)文件 Counter.js

import React, {Component} from 'react'
import './Counter.css' 

class Counter extends Component{
    render(){
        return(
            <div>
                <div className="counter">
                <input type="button" className="counterLeftButton" value="-" />
                <input type="text" value="0" />
                <input type="button" className="counterRightButton" value="+" />
            </div>
        )
    }
}

export default Counter
  1. 這里沒(méi)有用到元素渲染,就不用引入ReactDOM 了王带。我們統(tǒng)一在 index.js 中渲染淑蔚。這里還引入了一個(gè)對(duì)應(yīng)的 CSS 文件,稍微修飾一下愕撰。
  2. 注意 render 方法只能返回一個(gè)JSX元素刹衫,有多個(gè)并列元素時(shí),外層用 <div> 包一下就好搞挣。
  3. 最后一行用于導(dǎo)出類(lèi)带迟,這樣在別的 js 文件中就可以引入了。如果不想寫(xiě)最后一行囱桨,可以在定義的時(shí)候直接這樣寫(xiě):
export default class Counter extends Component

嵌套

接下里仓犬,讓這個(gè) Counter 在頁(yè)面中顯示出來(lái),兩個(gè)辦法:

  1. public/index.html 中加入一個(gè) HTML 元素舍肠,在 src/index.js 中引入 Counter 并渲染到上面的 HTML元素中搀继。
<div id="counter"></div>
...
import Counter from './Counter'
...
ReactDOM.render(<Counter />, document.getElementById('counter'));
...
  1. 直接把 <Counter /> 嵌套到之前 hello 所在的JSX元素中:
...
import Counter from './Counter'
...
render(){
    return(
        <div>
            hello
            <Counter />
        </div>
    )
}

emmm...就這樣吧。

當(dāng)然如果你愿意翠语,多放幾個(gè)也是沒(méi)問(wèn)題的叽躯。

...
render(){
    const counters = []
    for(var i = 0; i < 5; i++){
        counters.push(<Counter/>)
    }
    return(
        <div>
            {counters}
        </div>
    )
}
...

事件

到現(xiàn)在為止,按鈕點(diǎn)了沒(méi)反應(yīng)啡专,也不能自己輸入數(shù)字险毁。是的制圈,React.js 中無(wú)法直接更改 input 元素的值们童。不過(guò)使用 React.js 提供的監(jiān)聽(tīng)事件機(jī)制,很容易就能做到鲸鹦,把 onChange慧库,onClick 等等, 像是 onXxx 這種事件當(dāng)做屬性馋嗜,添加上對(duì)應(yīng)的處理方法齐板,設(shè)置到 JSX 元素上就可以了。
但是有一點(diǎn),React.js 會(huì)直接調(diào)用這個(gè)方法甘磨,并沒(méi)有通過(guò)對(duì)象調(diào)用橡羞,所以,如果要在方法中用 this 關(guān)鍵字济舆,需要自己綁定 bind 卿泽。

<input type="text" value="0" onChange={this.handleInputValueChange.bind(this)}/>

Counter 類(lèi)中加上 handleInputValueChange 方法

handleInputValueChange(event){
    console.log(event.target.value)
}

然后,去修改 input 中的值滋觉,你就能在控制臺(tái)看到了……
摔签夭,要直接在頁(yè)面上讓我看到啊混蛋,能不能給點(diǎn)力啊椎侠。

state

emmm...

看起來(lái)我們沒(méi)辦法直接在函數(shù)里訪問(wèn) JSX 元素啊第租,不過(guò),要是把 inputvalue 值設(shè)置為變量我纪,在函數(shù)里修改再體現(xiàn)在頁(yè)面上不就可以了慎宾。等同于,我們直接改了元素的 數(shù)據(jù)狀態(tài)浅悉。React.js 為組件提供了 state 機(jī)制璧诵,我們?cè)诶锩娲娣乓粋€(gè)變量 count 就好。

constructor () {
    super()
    this.state = { count: 0 }
}

handleInputValueChange(event){
    this.state.count = event.target.value
}

...
<input type="text" value={this.state.count} ... />
...

你會(huì)發(fā)現(xiàn)仇冯,還是不行…… emmm ...
自己直接修改 this.state 中的數(shù)據(jù)之宿, React.js 不會(huì)給渲染的,這里需要調(diào)用 setState

this.setState({count: event.target.value});

同樣的苛坚,給兩個(gè) button 加上 onClick 事件:

<input type="button"  value="-" onClick={this.handleCountDecrease.bind(this)}/>
...
<input type="button"  value="+" onClick={this.handleCountIncrease.bind(this)}/>

實(shí)現(xiàn)這兩個(gè)方法比被,加上數(shù)據(jù)驗(yàn)證什么的,到現(xiàn)在為止泼舱,看起來(lái)似乎還不錯(cuò)等缀。

props

但是,這個(gè)組件除了在購(gòu)物車(chē)界面中使用娇昙,還有可能用在其他的地方尺迂,并且或許有另外的文本要求,這里使用了“-”冒掌,“+”噪裕,或許別的需求里需要其他字符,像是“<” 和 “>”股毫,so膳音,到此為止它的擴(kuò)展性還是不夠,如果可以在使用的時(shí)候直接在外部設(shè)置某些屬性铃诬,就更好了祭陷。比如這樣用:

<Counter leftButtonText="<" rightButtonText=">" />

我們?cè)诮M件 Counter 中提前設(shè)置好默認(rèn)值苍凛,通過(guò) this.props.參數(shù)名 使用:

static defaultProps = {
    leftButtonText: "-",
    rightButtonText: "+"
}
...
<input type="button" value={this.props.leftButtonText} .../>
<input type="text" .../>
<input type="button" value={this.props.rightButtonText} .../>
...

ta-da


不過(guò)傳進(jìn)來(lái)的 props 不能在組件內(nèi)部修改,需要改變的時(shí)候兵志,可以通過(guò)父組件重新渲染醇蝴。當(dāng)然,如果需要想罕,直接傳函數(shù)進(jìn)來(lái)也是可以的哑蔫。在 index.js 中定義函數(shù)并傳入:

handleCounterClick(event){
    console.log("click handled by props")
}

render(){
    return(
        <Counter handleClick={this.handleCounterClick}/>
    )
}

組件 Counter.js 中直接使用就好:

<div className="counter" onClick={this.props.handleClick}>...</div>

這下勉強(qiáng)算得上是一個(gè)組件吧。任何需要它出現(xiàn)的地方弧呐,直接使用 <Counter />就OK了闸迷。

今天就到這里了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末俘枫,一起剝皮案震驚了整個(gè)濱河市腥沽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌鸠蚪,老刑警劉巖今阳,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異茅信,居然都是意外死亡盾舌,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)蘸鲸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)妖谴,“玉大人,你說(shuō)我怎么就攤上這事酌摇∠ゾ耍” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵窑多,是天一觀的道長(zhǎng)仍稀。 經(jīng)常有香客問(wèn)我,道長(zhǎng)埂息,這世上最難降的妖魔是什么技潘? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮千康,結(jié)果婚禮上享幽,老公的妹妹穿的比我還像新娘。我一直安慰自己吧秕,他們只是感情好琉闪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著砸彬,像睡著了一般颠毙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上砂碉,一...
    開(kāi)封第一講書(shū)人閱讀 51,578評(píng)論 1 305
  • 那天蛀蜜,我揣著相機(jī)與錄音,去河邊找鬼增蹭。 笑死滴某,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的滋迈。 我是一名探鬼主播霎奢,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼饼灿!你這毒婦竟也來(lái)了幕侠?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤碍彭,失蹤者是張志新(化名)和其女友劉穎晤硕,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體庇忌,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡舞箍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了皆疹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疏橄。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖略就,靈堂內(nèi)的尸體忽然破棺而出软族,到底是詐尸還是另有隱情,我是刑警寧澤残制,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布立砸,位于F島的核電站,受9級(jí)特大地震影響初茶,放射性物質(zhì)發(fā)生泄漏颗祝。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一恼布、第九天 我趴在偏房一處隱蔽的房頂上張望螺戳。 院中可真熱鬧,春花似錦折汞、人聲如沸倔幼。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)咧最。三九已至慈鸠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間膏燃,已是汗流浹背茂卦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留组哩,地道東北人等龙。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像伶贰,于是被迫代替她去往敵國(guó)和親蛛砰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 深入JSX date:20170412筆記原文其實(shí)JSX是React.createElement(componen...
    gaoer1938閱讀 8,065評(píng)論 2 35
  • 3. JSX JSX是對(duì)JavaScript語(yǔ)言的一個(gè)擴(kuò)展語(yǔ)法黍衙, 用于生產(chǎn)React“元素”泥畅,建議在描述UI的時(shí)候...
    pixels閱讀 2,827評(píng)論 0 24
  • 本筆記基于React官方文檔,當(dāng)前React版本號(hào)為15.4.0们豌。 1. 安裝 1.1 嘗試 開(kāi)始之前可以先去co...
    Awey閱讀 7,709評(píng)論 14 128
  • 原教程內(nèi)容詳見(jiàn)精益 React 學(xué)習(xí)指南涯捻,這只是我在學(xué)習(xí)過(guò)程中的一些閱讀筆記,個(gè)人覺(jué)得該教程講解深入淺出望迎,比目前大...
    leonaxiong閱讀 2,837評(píng)論 1 18
  • 文/孤鳥(niǎo)差魚(yú) 現(xiàn)在的我 活的糟糕的樣子 都怕把鬼嚇著
    孤鳥(niǎo)差魚(yú)閱讀 191評(píng)論 0 2