【Vue2.0学习】— Vue监视数据的原理(四十二)

简介: 【Vue2.0学习】— Vue监视数据的原理(四十二)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        <h2>学生信息</h2>
        <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="updateFriend">修改第一个朋友的名字为张飒</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>
    <script>
        const vm = new Vue({
            el: '#root',
            data: {
                student: {
                    name: '张三',
                    age: 18,
                    hobby: ['抽烟', '喝酒', '烫头'],
                    friends: [{
                        name: '小王',
                        age: 20
                    }, {
                        name: '李四',
                        age: 22
                    }]
                }
            },
            methods: {
                addSex() {
                    this.$set(this.student, 'sex', '男')
                        // Vue.set(this.student, 'sex', '男')
                },
                addFriend() {
                    this.student.friends.unshift({
                        name: 'jack',
                        age: 26
                    })
                },
                updateFriend() {
                    this.student.friends[0].name = '张飒'
                },
                addhobby() {
                    this.student.hobby.push('打球')
                },
                updatehobby() {
                    this.student.hobby.splice(0, 1, '开车')
                }
            }
        })
    </script>
</body>
</html>


相关文章
|
2天前
|
JavaScript
vue打印v-model 的值
vue打印v-model 的值
|
2天前
|
移动开发 前端开发 JavaScript
VUE3内置组件Transition的学习使用
VUE3内置组件Transition的学习使用
|
2天前
|
移动开发 JavaScript 前端开发
学习vue3使用在线官方开发环境play.vuejs.org进行测试
学习vue3使用在线官方开发环境play.vuejs.org进行测试
|
2天前
|
JavaScript
Vue实战-组件通信
Vue实战-组件通信
5 0
|
2天前
|
JavaScript
Vue实战-将通用组件注册为全局组件
Vue实战-将通用组件注册为全局组件
5 0
|
3天前
|
JavaScript
VUE里的find与filter使用与区别
VUE里的find与filter使用与区别
12 0
|
3天前
|
JavaScript
vue页面加载时同时请求两个接口
vue页面加载时同时请求两个接口
|
3天前
|
JavaScript
vue里样式不起作用的方法,可以通过deep穿透的方式
vue里样式不起作用的方法,可以通过deep穿透的方式
12 0
|
3天前
|
移动开发 JavaScript 应用服务中间件
vue打包部署问题
Vue项目`vue.config.js`中,`publicPath`设定为&quot;/h5/party/pc/&quot;,在线环境基于打包后的`dist`目录,而非Linux的`/root`。Nginx代理配置位于`/usr/local/nginx/nginx-1.13.7/conf`,包含两个相关配置图。
vue打包部署问题
|
3天前
|
JavaScript 前端开发
iconfont 图标在vue里的使用
iconfont 图标在vue里的使用
13 0