Vue学习笔记02

简介: Vue学习笔记02

1. 事件基本使用


  1. 使用v-on:xxx或@xxx绑定事件,其中xxx是事件名;
  2. 事件的回调需要配置在methods对象中,最终会在vm上;
  3. methods中配置的函数,不要用箭头函数!否则this就不是vm了;
  4. methods中配置的函数,都是被Vue所管理的函数,this的指向是vm或组件实例对象;
  5. @click=“demo”和@click="demo($event)"效果一致,但后者可以传参;


事件修饰符


  1. prevent:阻止默认事件;
  2. stop:阻止事件冒泡;
  3. once:事件只触发一次;
  4. capture:使用事件的捕获模式;(捕获模式与冒泡模式顺序相反)
  5. self:只有event.target是当前操作的元素时才触发事件;
  6. passive:事件的默认行为立即执行,无需等待时间回调执行完毕。
<a href="http://www.baidu.com" @click.prevent="demo"></a>

注意:也可以连着写,但是有顺序。下面的就是先阻止默认事件,再阻止冒泡。

@click.prevent.stop="demo()"


键盘事件


<input type="text" value="" @keyup.enter="demo()" />
  1. Vue中常用的按键别名:
    回车 => enter
    删除 => delete(捕获“删除”和“退格”键)
    退出 => esc
    空格 => space
    换行 => tab (特殊,必须配合keydown去使用)
    上 => up
    下 => down
    左 => left
    右 => right


  1. Vue未提供别名的按键,可以使用按键原始的key值去绑定,但要注意转为kebab-case(短横线命名。如键盘的CapsLock,名字为caps-lock)


  1. 系统修饰键(用法特殊):ctrl、alt、shift、meta


  • 配合keyup使用:按下修饰键的同时,再按下其他键,随后释放其它键,事件才触发。
  • 配合keydown使用:正常触发事件。


  1. 也可以使用keyCode去指定具体的按键(不推荐)


  1. Vue.config.keycode.自定义键名 = 键码,可以去定制按键名。
Vue.config.keycode.huiche = 13


注意:也可以连着写,如下为按下ctrl+y键触发demo()事件。


@keyup.ctrl.y="demo()"


2. 计算属性


  1. 定义:要用的属性不存在,要通过已有的属性计算得来。


  1. 原理:底层借助了Object.defineproperty方法提供的getter和setter。


  1. get函数什么时候执行?


  1. 初次读取时会执行一次。
  2. 当依赖的数据发生改变时会被在此调用。


  1. 优势:与methods实现相比,内部有缓存机制(复用),效率更高,调试方便。


  1. 备注:


  1. 计算属性最终会出现在vm上,直接读取使用即可。
  2. 如果计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生。


如下为实现“姓”、“名”两个值拼接的三种方法


简写方式 (当不需要修改计算属性的时候可以采取以下方式简写)

computed: {
     fullName(){
         return this.firstName + '-' + this.lastName;
     }
 }


1.插值方法


<body>
     <div id="root">
         姓: <input type="text" v-model="firstName"><br /><br />
         名: <input type="text" v-model="lastName"><br /><br />
         全名:<span>{{firstName}} - {{lastName}}</span>
     </div>
 </body>
 <script>
     Vue.config.productionTip = false;
     new Vue({
         el: '#root',
         data() {
             return {
                 firstName: '张',
                 lastName: '三'
             }
         },
         methods: {
         }
     })
 </script>


2.methods方法实现


<body>
     <div id="root">
         姓: <input type="text" v-model="firstName"><br /><br />
         名: <input type="text" v-model="lastName"><br /><br />
         全名:<span>{{fullName()}}</span>
     </div>
 </body>
 <script>
     Vue.config.productionTip = false;
     new Vue({
         el: '#root',
         data() {
             return {
                 firstName: '张',
                 lastName: '三'
             }
         },
         methods: {
             fullName() {
                 return this.firstName + '-' + this.lastName
             }
         }
     })
 </script>


3.计算属性


<body>
    <div id="root">
        姓: <input type="text" v-model="firstName"><br /><br />
        名: <input type="text" v-model="lastName"><br /><br />
        全名:<span>{{fullName}}</span>
    </div>
</body>
<script>
    Vue.config.productionTip = false;
    var vm = new Vue({
        el: '#root',
        data() {
            return {
                firstName: '张',
                lastName: '三'
            }
        },
        computed: {
            fullName: {
                get() {
                    return this.firstName + '-' + this.lastName;
                },
                set(value) {
                    this.firstName = value.split('-')[0];
                    this.lastName = value.split('-')[1];
                }
            }
        }
    })
</script>


相关文章
|
9天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
67 1
|
20天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
50 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
46 1
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
35 1
|
2月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
37 1
|
2月前
|
JavaScript 前端开发 开发者
vue 数据驱动视图
总之,Vue 数据驱动视图是一种先进的理念和技术,它为前端开发带来了巨大的便利和优势。通过理解和应用这一特性,开发者能够构建出更加动态、高效、用户体验良好的前端应用。在不断发展的前端领域中,数据驱动视图将继续发挥重要作用,推动着应用界面的不断创新和进化。
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
下一篇
开通oss服务