7.state状态

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>state</title>
    <style>
        .title {
            background-color: orange;
            width: 200px;
        }
    </style>
</head>

<body>
    <!-- 准备好一个“容器” -->
    <div id="test"></div>

    <!-- 引入react核心库 -->
    <script type="text/javascript" src="package/react.development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="package/react-dom.development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="package/babel.min.js"></script>

    <script type="text/babel">
        class Wheather extends React.Component {
            constructor(props){
                super(props)
                this.state = {isHot : false}
            }
            render() {
                // console.log(this);
                return  (
                    <h1 onClick = {this.changeWeather}>今天天气真{this.state.isHot ? '炎热' : '凉爽'}</h1>
                );
            }
            changeWeather() {
                this.state.isHot = !this.state.isHot;
            }
        }
        ReactDOM.render(<Wheather/>, document.getElementById('test'));
    </script>
</body>

</html>

由于这段代码

onClick = {this.changeWeather}

只是将changeWeather这个函数赋值给点击事件的回调函数,并没有调用,所以changeWeather方法并不指向Weather实例,而回调函数的this默认是指向window的,而这边开启了babel严格模式,而且类中方法被自动开启了严格模式,所以会报undefined

解决方式是

            constructor(props){
                super(props)
                this.state = {isHot : false}
                this.changeWeather = this.changeWeather.bind(this);
            }

案例

    <script type="text/babel">
        class Wheather extends React.Component {
            constructor(props){
                super(props)
                this.state = {isHot : false}
                this.changeWeather = this.changeWeather.bind(this);
            }
            render() {
                return  (
                    <h1 onClick = {this.changeWeather}>今天天气真{this.state.isHot ? '炎热' : '凉爽'}</h1>
                );
            }
            changeWeather() {
                const isHot = this.state.isHot;
                // react不支持手动更改state,必须通过内置api setState来进行更改
                this.setState({isHot:!isHot});
            }
        }
        ReactDOM.render(<Wheather/>, document.getElementById('test'));

下边是简写形式

        class Weather extends React.Component {
            // 初始化状态
            state = {isHot : false};//赋值语句,相当于在Weather实例对象身上添加了一个新的属性state
            render() {
                return  (
                    <h1 onClick = {this.changeWeather}>今天天气真{this.state.isHot ? '炎热' : '凉爽'}</h1>
                );
            }
            changeWeather = () => {//赋值语句,相当于在Weather实例对象身上添加了一个新的属性changeWeather   
                const isHot = this.state.isHot;
                // react不支持手动更改state,必须通过内置api setState来进行更改
                this.setState({isHot:!isHot});
            }
        }
        // 渲染组件到页面上
        ReactDOM.render(<Weather/>, document.getElementById('test'));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值