国产精品美女久久久浪潮AV,国产精品三级一二三区,久久精品国产一区二区小说 ,依依成人影视国产精品,全部无卡免费的毛片在线看,日本一区二区三深夜不卡,国产精品女同一区二区久久,国产精品夜色一区二区三区

        react框架

        2020-3-18    seo達人

        環(huán)境準(zhǔn)備

        創(chuàng)建項目



        npx create-react-app my-react



        進入項目并啟動



        cd my-react && npm start

        1

        src/index.js

        先把src里面的東西全部刪掉,重寫了index.js



        import React from 'react';

        import ReactDOM from 'react-dom';



        class App extends React.Component{

        render(){

        return (

        <div>Hellow, World</div>

        )

        }

        }



        ReactDOM.render(<App/>, document.getElementById('root'));



        JSX

        一個React組件中,render方法中return出去的內(nèi)容就是這個組件將要渲染的內(nèi)容,然后Babel 會把 JSX 轉(zhuǎn)譯成一個名為 React.createElement() 函數(shù)調(diào)用。



        React.createElement(

          'div',

          {},

          'Hello, World'

        )



        React.createElement() 接收三個參數(shù):

        第一個參數(shù)是必填,傳入的是似HTML標(biāo)簽名稱: ul, li, div;

        第二個參數(shù)是選填,表示的是屬性: className;

        第三個參數(shù)是選填, 子節(jié)點: 要顯示的文本內(nèi)容;

        React.createElement() 會預(yù)先執(zhí)行一些檢查,以幫助你編寫無錯代碼,但實際上它創(chuàng)建了一個這樣的對象:



        // 注意:這是簡化過的結(jié)構(gòu)

        const element = {

          type: 'div',

          props: {

            className: '',

            children: 'Hello, world!'

          }

        };



        元素渲染

        與瀏覽器的 DOM 元素不同,React 元素是創(chuàng)建開銷極小的普通對象。React DOM 會負(fù)責(zé)更新 DOM 來與 React 元素保持一致。

        想要將一個 React 元素渲染到根 DOM 節(jié)點中,只需把它們一起傳入 ReactDOM.render():



        const element = <h1>Hello, world</h1>;

        ReactDOM.render(element, document.getElementById('root'));



        render方法接收兩個參數(shù),第一個參數(shù)為我們的 React 根級組件,第二個參數(shù)接收一個 DOM 節(jié)點,代表我們將把和 React 應(yīng)用掛載到這個 DOM 節(jié)點下,進而渲染到瀏覽器中。



        組件 & props

        組件,從概念上類似于 JavaScript 函數(shù)。它接受任意的入?yún)ⅲ?“props”),并返回用于描述頁面展示內(nèi)容的 React 元素。

        函數(shù)組件:



        function Welcome(props){

        renter (

        <h1> Hello, {props.name} </h1>

        )

        }

        <Welcome name="World"/>



        該函數(shù)是一個有效的 React 組件,因為它接收唯一帶有數(shù)據(jù)的 “props”(代表屬性)對象與并返回一個 React 元素。這類組件被稱為“函數(shù)組件”,因為它本質(zhì)上就是 JavaScript 函數(shù)。

        class組件:



        class Welcome extends React.Component {

        render(){

        renter (

        <h1> Hello, {thhis.props.name} </h1>

        )

        }

        }

        <Welcome name="World"/>



        組件名稱必須以大寫字母開頭。

        組件無論是使用函數(shù)聲明還是通過 class 聲明,都決不能修改自身的 props。



        State & 生命周期

        State 與 props 類似,但是 state 是私有的,并且完全受控于當(dāng)前組件。



        class Clock extends React.Component {

        constructor(props){

        super(props)

        this.state = {

        date : new Date()

        }

        }

        componentDidMount() {

        //這里是Clock組件第一次被渲染到DOM時會調(diào)用,也就是掛載

        }



        componentWillUnmount() {

        //當(dāng)DOM組件Clock被刪除時,會調(diào)用,也就是卸載

        }

        render(){

        return (

        <div>

        <h1>Hello, World</h1>

        <h2>It's {this.state.date.toLocaleTimeString()}</h2>

        </div>

        )

        }

        }



        修改state中數(shù)據(jù):



        class Clock extends React.Component {

        constructor(props){

        super(props)

        this.state = {

        date: new Date()

        }

        }

        componentDidMount() {

        //這里是Clock組件第一次被渲染到DOM時會調(diào)用,也就是掛載

        this.timer = setInterval(()=>{

        this.tick()

        },1000)

        }



        tick(){

        this.setState({

        date: new Date()

        })

        }



        componentWillUnmount() {

        //當(dāng)DOM組件Clock被刪除時,會調(diào)用,也就是卸載

        clearInterval(this.timer)

        }

        render(){

        return (

        <div>

        <h1>Hello, World</h1>

        <h2>It's {this.state.date.toLocaleTimeString()}</h2>

        </div>

        )

        }

        }



        不要直接修改 State,構(gòu)造函數(shù)是唯一可以給 this.state 賦值的地方



        this.setState({name: 'World'})

        1

        State 的更新可能是異步的,要解決這個問題,可以讓setState接受一個函數(shù)而不是一個對象,這個函數(shù)用上一個 state 作為第一個參數(shù),將此次更新被應(yīng)用時的 props 做為第二個參數(shù):



        this.setState((state, props) => ({

          counter: state.counter + props.increment

        }));



        事件處理

        React 事件的命名采用小駝峰式(camelCase),而不是純小寫。

        使用 JSX 語法時你需要傳入一個函數(shù)作為事件處理函數(shù),而不是一個字符串。

        在 React 中一個不同點是你不能通過返回 false 的方式阻止默認(rèn)行為。你必須顯式的使用 preventDefault 。例如,傳統(tǒng)的 HTML 中阻止鏈接默認(rèn)打開一個新頁面,你可以這樣寫:



        <a href="#" onclick="console.log('The link was clicked.'); return false">

          Click me

        </a>



        在 React 中,可能是這樣的:



        function ActionLink() {

          function handleClick(e) {

            e.preventDefault();

            console.log('The link was clicked.');

          }



          return (

            <a href="#" onClick={handleClick}>

              Click me

            </a>

          );

        }



        class函數(shù)中綁定this



        class LoggingButton extends React.Component {

          handleClick() {

            console.log('this is:', this);

          }



          render() {

            // 此語法確保 handleClick 內(nèi)的 this 已被綁定。

            return (

              <button onClick={() => this.handleClick()}>

                Click me

              </button>

            );

          }

        }



        在循環(huán)中,通常我們會為事件處理函數(shù)傳遞額外的參數(shù)



        <button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button>

        <button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>

        1

        2

        列表和key



        function ListItem(props) {

          return <li>{props.value}</li>;

        }



        function NumberList(props) {

          const numbers = props.numbers;

          const listItems = numbers.map((number) =>

            <ListItem key={number.toString()}  value={number} />

          );

          return (

            <ul>

              {listItems}

            </ul>

          );

        }



        const numbers = [1, 2, 3, 4, 5];

        ReactDOM.render(

          <NumberList numbers={numbers} />,

          document.getElementById('root')

        );



        語法

        在 JSX 中所有的屬性都要更換成駝峰式命名,比如 onclick 要改成 onClick,唯一比較特殊的就是 class,因為在 JS 中 class 是保留字,我們要把 class 改成 className 。


        日歷

        鏈接

        個人資料

        藍藍設(shè)計的小編 http://m.shtzxx.cn

        存檔

        主站蜘蛛池模板: 国产区精品系列在线观看| 久久久99精品成人片中文字幕| 五月丁香啪啪| 遂溪县| 影音先锋男人站| 南平市| 国产九九久久99精品影院| 国产成人精品久久综合| 人妻人人做人碰人人添| 亚洲精品国产第一综合99久久| 两个黑人挺进校花体内np| 亚洲综合国产一区| 黑人巨大videosjapan| 久久国产精品偷| 中文字幕丰满乱孑伦无码专区| 河源市| 精品亚洲成a人片在线观看| 强被迫伦姧惨叫在线视频| 无码av最新无码av专区| 把女邻居弄到潮喷的性经历| 97精品伊人久久久大香线蕉| 真实单亲乱l仑对白视频| 天堂一区人妻无码| 暖暖 在线 视频 免费 视频 | av在线 亚洲 天堂| 香蕉国产| 小sao货揉揉你的奶真大电影 | 人与物videos另类| 狠狠躁夜夜躁人人爽天天开心婷婷 | 久久人人爽爽人人爽人人片av| 黑人大荫蒂老太大| 天天爽天天爽夜夜爽毛片| 人妻美妇疯狂迎合| 亚洲男同帅gay片在线观看| 亚洲av极品视觉盛宴| 亚洲综合一区自偷自拍| 最近日本字幕mv高清在线电影 | 免费人成视频x8x8入口| 久久人妻av中文字幕| 米奇777超碰欧美日韩亚洲| 天堂8在线天堂资源bt|