Vue学习:监视属性-实现天气切换

点击按钮。可以实现天气的直接切换。并且在控制台显示切换前后的天气

实现天气切换部分
直接写:使用三目运算符 但是过于麻烦使用计算属性

     <!-- 准备容器 -->
    <div id="root">
        <!-- 但是过于麻烦使用计算属性 -->
        <h2>今天天气很{{isHot  ? '炎热':'凉爽'}}</h2>
        <button>切换天气</button>
    </div>
    <script type="text/javascript">
        new Vue({
            el: '#root',
            data: {
                isHot: true,//使用布尔值进行两个判断
    
            },
         
        });
    </script>
计算属性
<body>
     <!-- 准备容器 -->
    <div id="root">
        <!-- 但是过于麻烦使用计算属性 -->
        <h2>今天天气很{{info}}</h2>
        <button>切换天气</button>
    </div>
    <script type="text/javascript">
        new Vue({
            el: '#root',
            data: {
                isHot: true,//使用布尔值进行两个判断
    
            },
            computed:{
                info(){//返回值就是info的值,必须写this拿到该属性
                    return this.isHot ? '炎热':'凉爽'
                }
            }
        });
    </script>
    
</body>
实现按钮绑定事件

为事件对象绑定方法

<body>
     <!-- 准备容器 -->
    <div id="root">
        <!-- 但是过于麻烦使用计算属性 -->
        <h2>今天天气很{{info}}</h2>
        <button @click="changeWeather">切换天气</button>
    </div>
    <script type="text/javascript">
        new Vue({
            el: '#root',
            data: {
                isHot: true,//使用布尔值进行两个判断
            },
            computed:{
                info(){//返回值就是info的值,必须写this拿到该属性
                    return this.isHot ? '炎热':'凉爽'
                }
            },
            methods: {//方法
                changeWeather(){
                    this.isHot=!this.isHot
                }
              
            },
        }); 
        
    </script>
    
</body>

--当我们使用我模板中没有使用到计算属性和属性中的数据时候,但是在事件中对属性进行了操作,vue开发者工具中显示的内容会不进行变化,不会更新,但是实际上改了。用vm实例对象进行更新

简化点击实现(即绑定事件后面写简单的语句)

可以直接在事件后面写简单的语句(多个语句也可。但是不最好不要,并且不支持警告函数alert,先去原型对象上找,找不到就结束报错。需要弹窗可以在vm对象上直接写一个

<body>
     <!-- 准备容器 -->
    <div id="root">
        <!-- 但是过于麻烦使用计算属性 -->
        <h2>今天天气很{{info}}</h2>
        <button @click="isHot=!isHot">切换天气</button>
    </div>
    <script type="text/javascript">
       const v= new Vue({
            el: '#root',
            data: {
                isHot: true,//使用布尔值进行两个判断
            },
            computed:{
                info(){//返回值就是info的值,必须写this拿到该属性
                    return this.isHot ? '炎热':'凉爽'
                }
            },
            methods: {//方法
                // changeWeather(){
                //     this.isHot=!this.isHot
                // }
              
            },
        }); 
        
    </script>
    
</body>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值