Vue-22、总结Vue数据监测

1、功能

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Vue总结数据监测</title>
    <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
</head>
<body>
<div id="root">
    <hr/>
    <h1 >学生信息</h1>
    <button @click="student.age++">年龄+1岁</button>
    <button @click="addsex">点击添加学生性别</button>

    <button @click="student.sex='女'">点击修改学生性别</button>

    <button @click="addFirstFriend">在列表首位添加一个朋友</button>
    <button @click="updateFirstName">修改第一个朋友的名字为张三</button>
    <button @click="addHobby">添加一个爱好</button>
    <button @click="updateHobby">修改第一个爱好为:开车</button>
    <h2>学生名字:{{student.name}}</h2>
    <h2 v-if="student.sex">性别:{{student.sex}}</h2>
    <h2>学生年龄:{{student.age}}</h2>

    <hr/>
    <h2>学生爱好</h2>
    <ul>
        <li v-for="p in student.hobby">{{p}}</li>
    </ul>
    <h2>学生朋友们</h2>
    <h2>
        <ul>
            <li v-for="(p,index) in student.friends" :key="index"> {{p.name}}--{{p.age}}</li>
        </ul>
    </h2>
</div>
<script type="text/javascript">
    Vue.config.productionTip=false;
    const vm = new Vue({
        el:"#root",
        data:{
            student:{
                name: 'tom',
                age:18,
                hobby:[
                    '抽烟',
                    '喝酒',
                    '烫头'
                ],
                friends:[
                    {name:'jeery',age:35},
                    {name:'tony',age:36}
                ]
            }
        },
        methods:{
            addsex(){
                // Vue.set(this.student,'sex','男')
                this.$set(this.student,'sex','男');
            },
            addFirstFriend(){
                this.student.friends.unshift({name:'李四',age:36});
            },
            updateFirstName(){
               this.student.friends[0].name="张三";
            },
            addHobby(){
                this.student.hobby.unshift('抽烟');
            },
            updateHobby(){
                this.student.hobby.splice(0,1,'开车');
               // Vue.set(this.student.hobby,0,'开车');
               // this.$set(this.student.hobby,0,'开车')
            },
        }
    })
</script>
</body>
</html>

2、总结

相关推荐
张拭心4 小时前
Cursor 又偷偷更新,这个功能太实用:Visual Editor for Cursor Browser
前端·人工智能
I'm Jie4 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324605 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
CodeCraft Studio6 小时前
文档开发组件Aspose 25.12全新发布:多模块更新,继续强化文档、图像与演示处理能力
前端·.net·ppt·aspose·文档转换·word文档开发·文档开发api
PPPPickup6 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫6 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
前端大卫7 小时前
【重磅福利】学生认证可免费领取 Gemini 3 Pro 一年
前端·人工智能
孜燃7 小时前
Flutter APP跳转Flutter APP 携带参数
前端·flutter
脾气有点小暴7 小时前
前端页面跳转的核心区别与实战指南
开发语言·前端·javascript
lxh01137 小时前
最长递增子序列
前端·数据结构·算法