1. 程式人生 > >react組件選項卡demo

react組件選項卡demo

大寫 ons tle pan babel port struct st3 傳值

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="../node_modules/react/umd/react.development.js"></script>
    <script src="../node_modules/react-dom/umd/react-dom.development.js"></script>
    <script src="../node_modules/babel-standalone/babel.js"></script>
</head>
<body>
    <div id="app">

    </div>
    <script type="text/babel">
        let arr 
= [1,2,3,4]; // 根組件默認拿到全局變量為data的值 在子組件傳值直接傳值進行調用 class List3 extends React.Component{//必須是大寫的首字母 constructor(props){ //構造函數傳參 super(props); //調用所有原型上的屬性來實現props傳值 this.state = { n:0 } } inc(ind){
this.setState({ n:ind }) }; render(){ console.log(this);//符號必須是分號不能是逗號 let {data} = this.props; let {n} = this.state; return( data.map((item,index)
=>{ return ( <div key={index} style={{color:n===index?‘red‘:null}} onClick={this.inc.bind(this,index)}>{item}</div> //函數不能寫括號 不然會立即執行 )//由於es6的this指向問題this值拿不到(onclick綁定的是匿名函數),所有需要綁定當前的this指向當前的作用域 } ) ) } } ReactDOM.render( <div> <List3 data={arr}/> </div>, document.getElementById(‘app‘) ) </script> </body> </html>

react組件選項卡demo