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>

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容