国产精品爱久久久久久久小说,女人扒开腿让男人桶到爽 ,亚洲欧美国产双大乳头,国产成人精品综合久久久久,国产精品制服丝袜无码,免费无码精品黄av电影,黑色丝袜无码中中文字幕,乱熟女高潮一区二区在线

            react框架

            2020-3-18    seo達人

            環境準備

            創建項目



            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出去的內容就是這個組件將要渲染的內容,然后Babel 會把 JSX 轉譯成一個名為 React.createElement() 函數調用。



            React.createElement(

              'div',

              {},

              'Hello, World'

            )



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

            第一個參數是必填,傳入的是似HTML標簽名稱: ul, li, div;

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

            第三個參數是選填, 子節點: 要顯示的文本內容;

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



            // 注意:這是簡化過的結構

            const element = {

              type: 'div',

              props: {

                className: '',

                children: 'Hello, world!'

              }

            };



            元素渲染

            與瀏覽器的 DOM 元素不同,React 元素是創建開銷極小的普通對象。React DOM 會負責更新 DOM 來與 React 元素保持一致。

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



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

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



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



            組件 & props

            組件,從概念上類似于 JavaScript 函數。它接受任意的入參(即 “props”),并返回用于描述頁面展示內容的 React 元素。

            函數組件:



            function Welcome(props){

            renter (

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

            )

            }

            <Welcome name="World"/>



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

            class組件:



            class Welcome extends React.Component {

            render(){

            renter (

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

            )

            }

            }

            <Welcome name="World"/>



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

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



            State & 生命周期

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



            class Clock extends React.Component {

            constructor(props){

            super(props)

            this.state = {

            date : new Date()

            }

            }

            componentDidMount() {

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

            }



            componentWillUnmount() {

            //當DOM組件Clock被刪除時,會調用,也就是卸載

            }

            render(){

            return (

            <div>

            <h1>Hello, World</h1>

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

            </div>

            )

            }

            }



            修改state中數據:



            class Clock extends React.Component {

            constructor(props){

            super(props)

            this.state = {

            date: new Date()

            }

            }

            componentDidMount() {

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

            this.timer = setInterval(()=>{

            this.tick()

            },1000)

            }



            tick(){

            this.setState({

            date: new Date()

            })

            }



            componentWillUnmount() {

            //當DOM組件Clock被刪除時,會調用,也就是卸載

            clearInterval(this.timer)

            }

            render(){

            return (

            <div>

            <h1>Hello, World</h1>

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

            </div>

            )

            }

            }



            不要直接修改 State,構造函數是唯一可以給 this.state 賦值的地方



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

            1

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



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

              counter: state.counter + props.increment

            }));



            事件處理

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

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

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



            <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函數中綁定this



            class LoggingButton extends React.Component {

              handleClick() {

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

              }



              render() {

                // 此語法確保 handleClick 內的 this 已被綁定。

                return (

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

                    Click me

                  </button>

                );

              }

            }



            在循環中,通常我們會為事件處理函數傳遞額外的參數



            <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 。


            日歷

            鏈接

            個人資料

            藍藍設計的小編 http://www.dzxscac.cn

            存檔

            主站蜘蛛池模板: 欧美在线精彩视频免费播放| 极品探花在线| 精品人妻无码一区二区三区换脸 | 亚洲精品亚洲人成在线观看麻豆| 18成人免费观看网站| 日韩电影在线观看一区二区| 美女疯狂连续喷潮视频| 无套内谢少妇毛片免费看 | 国内露脸中年夫妇交换| 成人av一本不卡二卡| 久久综合激情| jlzzjlzz国产精品久久| 日本精品人妻无码免费大全| 永久免费观看的毛片视频| 尹人综合网| 大地资源在线观看官网第三页| 米奇777超碰欧美日韩亚洲| h片在线播放| 色中色在线视频| 日本乱偷互换人妻中文字幕| 久久天天躁狠狠躁夜夜| 91pron在线| 国产麻豆电影在线观看| 久久精品aⅴ无码中文字字幕蜜桃 草色噜噜噜av在线观看香蕉 | 久久久免费看片| 中文字幕一区二区人妻电影| 精品国产杨幂在线观看| 第一次破处视频| 欧美精欧美乱码一二三四区| 天天做天天爱夜夜爽女人爽| 福利视频一区二区| 国产一区二区黄色| 久久这里只有精品首页| 一本久道综合在线无码人妻| 亚洲欧美网站| 日韩免费av片| 思思久久99热只有频精品66| 18禁黄污无遮挡无码网站| 一本色道久久综合亚洲精品酒店| 成人午夜在线观看日韩| 国产丝袜美女一区二区三区|