Vue技术12.6总结Vue数据监测

<!DOCTYPE html>>
<html>
    <head>
        <mata charset="UTF-8"/>
        <title>总结Vue数据监测</title>
        <script type="text/javascript" src="../js/vue.js"></script>
    </head>
    <body>
        <!--
          Vue监视数据的原理:
          1.vue会监视data中所有层次的数据。
          2.如何监测对象中的数据?
            通过setter实现监视,且要在new Vue时就传入要监测的数据。
            (1).对象中后追加的属性,Vue默认不做响应式处理
            (2).如需给后添加的属性做响应式,请使用如下API:
                Vue.set(target.propertyName/index,value)或
                vm.$set(target.propertyName/index,value)
          3.如何监测数组中的数据?
            通过包裹数组更新元素的方法实现,本质就是做了两件事:
            (1).调用原生对应的方法对数组进行更新。
            (2).重新解析模板,进而更新页面。
          4.在Vue修改数组中的某个元素一定要用如下方法:
            (1).使用这些API:push()、pop()、shift()、unshift()、splice()、sort()、reverse()
            (2).Vue.set()或vm.$set()

            特别注意:Vue.set()和vm.$set()不能给vm或vm的跟数据对象添加属性!
        -->
        <!-- 准备好一个容器 -->
        <div id="root">
         <h1>学生信息</h1>
         <button @click="student.age++">年龄+1岁</button><br/><br/>
         <button @click="addSex">添加性别属性,默认值:男</button><br/><br/>
         <button @click="student.sex='未知' ">修改性别</button><br/><br/>
         <button @click="addFriend">在列表首位添加一个朋友</button><br><br/>
         <button @click="updateFriendName">修改第一个朋友的名字为:张三</button><br/><br/>
         <button @click="addHobby">添加一个爱好</button><br/><br/>
         <button @click="updateHobby">修改一个爱好为:开车</button><br/><br/>

         <h3>姓名:{{student.name}}</h3>
         <h3>年龄:{{student.age}}</h3>
         <h3 v-if="student.sex">性别:{{student.sex}}</h3>
         <h3>爱好:</h3>

         <ul>
            <li v-for="(h,index) in student.hobby" :key="index">
                {{h}}
            </li>
         </ul>

         <h3>朋友们:</h3>
            <ul>
                <li v-for="(f,index) in student.friends" :key="index">
                    {{f.name}}--{{f.age}}
                </li>
            </ul>
        </div>
    </body>

    <script type="text/javascript">
        Vue.config.productionTip = false

        const vm = new Vue({
            el:'#root',
            data:{
                student:{
                    name:'tom',
                    age:18,
                    hobby:['抽烟','喝酒','烫头'],
                    friends:[
                        {name:'jerry',age:35},
                        {name:'tory',age:36}
                    ]
                }
                
            },
            methods:{
                addSex(){
                    //Vue.set(this.student,'sex','男')
                    this.$set(this.student,'sex','男')
                },
                addFriend(){
                    this.student.friends.unshift({name:'jack',age:70})
                },
                updateFriendName(){
                    this.student.friends[0].name = '张三'
                },
                addHobby(){
                    this.student.hobby.push('学习')
                },
                updateHobby(){
                   // this.student.hobby.splice(0,1,'开车')
                   Vue.set(this.student.hobby,0,'开车')
                }
            }

        })
    </script>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yitahutu79

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值