Vue 笔记11.29 表单输入绑定(修饰符)、绑定事件(事件修饰符&按键修饰符)、深度响应式(小练习)、购物车

一、v-model指令和修饰符:

1.v-model指令双向绑定的注意事项:

(1)、v-model指令默认触发的是input事件,当文本框的值发生变化后,立刻同步给数据

(2)、 v-model绑定一组单选框,每个单选框指定相同的属性

绑定相同属性后会互相影响,不会出现都是true或者false的情况了

(3)、v-model绑定单个复选框,绑定一个boolean值   v-model绑定多个复选框,绑定同一个数组

(4)、单选菜单 绑定一个属性   多选菜单 绑定一个数组

2.修饰符:

.lazy-----可以将input事件转换为change事件

.trim-----用于去掉内容首尾的空格

<input type="text" v-model.lazy.trim='name'>{{name}}

通过修饰符.lazy 表单中本来因为双向绑定而同步变化的value和data中的name属性会在离开input表单窗口后再同步

.number-----用于将字符串转为数字 

<input type="text" v-model.number='age'>

data中的age传过来的数字是字符串的形式 加上.number后就又是数字了 可以进行运算

二、绑定事件、事件修饰符:

1.v-on: 缩写是@ 绑定事件的注意事项:

解释以下就是当绑定了事件后对方法不穿参数,那么就会默认传一个事件对象 e 进去

可以通过console.log(e)来查看

如果传了参数那么方法在运行时就会接收到这个参数

比如在上述代码中 运行sayHello方法时会有个  hello  出现

$event 参数 就是事件对象

2.绑定样式行内式写法:

仅仅当代码比较简单时才会使用。

3.事件修饰符:

(1)、.stop修饰符,用于阻止事件冒泡   子盒子的事件不会传给父盒子

             等同于在方法中写  e.stopPropagation();//阻止事件冒泡

(2)、.prevent修饰符,用于阻止默认行为

             等同于在方法中写  e.preventDefault();//阻止默认事件

(3)、.once修饰符,用于只绑定一次事件方法(只能调用一次 后面在点击就无效了)

(4)、.self修饰符,只能在自身元素上触发,不能在子元素身上触发

              这个有点类似于冒泡,区别在于这个是 父盒子的事件不会在点击子盒子时触发

三、深度响应式和按键修饰符:

1.按键修饰符:

Vue针对键盘事件,提供了按键修饰符。

一共有9个按键修饰符,分别是:

.enter 是回车键

.tab 是tab键 

.delete 是删除键和退格键        

.esc 是退出键       

 .space 是空格键        

.up 是上箭头        

.down 是下箭头        

.left 是左箭头        

.right 是右箭头

这里我们用了键盘弹起的方法。按键修饰符可以换成按键码。

2.深度响应式:

这些都是定义在methods中的方法

根据图中的代码进行一步步分析

(1)、addSex()方法中,使用 this.obj.sex ='男' 来给data中的obj对象增加属性。

这样添加的属性不会采用Object.defineProperties去封装,所以,就失去了响应式。

所以对data中的obj有影响但是对页面没有影响,页面不会更新。

通过$set方法   this.$set(this.obj,'sex','男')  可以给对象添加响应式属性。

(2)、delAge()方法与上述同理

delete this.obj.age  删除obj中的age属性 并没有响应式 所以页面不会刷新

而通过$delete方法    this.$delete(this.obj,'age'),删除对象的属性,并触发响应式

(3)、addArr()方法是要给data中的arr数组添加元素

this.arr[5]=66 这个方法不触发页面更新

特别注意:

在vue中,操作数组,并触发页面更新只能使用数组的以下方法: push(),pop () ,unshift () ,shift () ,splice () ,reverse () ,sort ()

所以:

this.arr.push(66)   和   this.$set(this.arr,5,66)   

这两个方法其实都可以在改变数据的同时刷新页面

(4)、delArr()方法删除arr数组中的第三位(下标为2)用splice截取一位

this.arr.splice(2,1)   和   this.$delete(this.arr,2)   就同上,都能够在改变数据的同时刷新页面

四、深度响应式小练习:

截图有点麻烦直接上代码了 大致意思就是通过this.$set()方法和this.$delete()方法给data中的对象添加及删除属性和属性值

<body>

    <div id="app">

        <div>

            {{obj}}

        </div>

        <div>

           属性:<input type="text" v-model='key'> 

        </div>

        <div>

          属性值:<input type="text" v-model='value'>  

        </div>

        <div>

            <button @click='add'>添加属性</button>

        </div>

        <div>

          属性:<input type="text" v-model='key2'>  

        </div>


        <button @click='del'>删除属性</button>

    </div>

    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.14/vue.js"></script>

    <script>

        new Vue({

            el:'#app',

            data:{

                obj:{

                },

                key:'',

                value:'',

                key2:''

            },

            methods:{

                add(){

                    //设置的效果为添加或者修改 如果对象没有这个属性 就添加 如果有 就修改

                    //设置obj对象的key属性值为value

                    this.$set(this.obj,this.key,this.value)

                },

                del(){

                    this.$delete(this.obj,this.key2)

                }

            }

        })

    </script>

</body>

五、购物车:这个敲完了 需要时间理解

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容