react組件選項卡demo
阿新 • • 發佈:2018-08-10
大寫 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