热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

传说中VUE的语法糖到底是做什么的_vue.js

从接触Vue我们就知道v-model是实现数据双向绑定的那他能实现绑定的原理到底是啥?最常见的语法糖v-model,今天通过案例给大家详细介绍下

一、什么是语法糖?

语法糖也译为糖衣语法,是由英国计算机科学家彼得·约翰·兰达(Peter J. Landin)发明的一个术语。指的是计算机语言中添加的一种语法,在不影响功能的情况下,添加某种简单的语法也能实现效果,这种语法对计算机没有任何影响,但是对于程序员更方便,通常增加的语法糖能够增加程序员的可读性,减少出错的机会。

使用语法糖可以简化代码,更便于程序员开发。

二、VUE中语法糖有哪些?

1、最常见的语法糖 v-model

使用 v-model 可以实现数据双向绑定,但是如何实现的呢?

v-model 绑定数据之后,既绑定了数据,又添加了事件监听,这个事件就是 input 事件。

使用案例:

//语法糖写法

  
  //还原为以下实例

输入的时候会触发 input 事件,input 事件会把当前值赋值给 value ,这就是 v-model 为什么可以实现双向绑定的原因。

2、v-bind 的语法糖

v-bind 用来添加动态属性的,常见的 src、href、class、style、title 等属性都可以通过 v-bind 添加动态属性值。

v-bind 的语法糖就是去掉 v-bind 替换成冒号 (:)

// 语法糖写法
没有语法糖
// 没有语法糖
没有语法糖

3、v-on 的语法糖

v-on 绑定事件监听器的,v-on 的语法糖,就是简写成@ 。

情况1:如果方法不传参时,可以不加小括号。





//需要注意的是,如果方法本身有一个参数,会默认将原生的事件event参数传递进来
methods:{
 btn( event ){
  console.log( 'event' , event )
 }
}

情况2:如果需要传递参数时,又同时需要 event 参数。



//需要注意的是,$event 事件拿到浏览器事件对象
methods:{
 btn( type, event ){
  console.log( 'type' , type ) //点击事件
  console.log( 'event' , event )
 }
}

4、修饰符

修饰符是以半角句号 . 指明的特殊后缀。v-on 后面的修饰符,也是语法糖。

示例:链接添加点击事件,点击之后不希望跳转。

//语法糖
百度

//普通写法
百度
methods:{
 go(e){
  e.preventDefault();
  console.log('阻止链接跳转')
 }
}

prevent 修饰符是阻止默认事件。还有 submit 同样也适用。


下列是常见的修饰符,与上边 .prevent 使用相同。

  • .stop 用来阻止事件冒泡。
  • .once 事件只触发一次。
  • .self 事件只在自身触发,不能从内部触发。
  • .enter | .tab | .delete | .esc ..... 键盘修饰符
  • .ctr | .alt | .shift | .meta 系统修饰符

    5、动态css

    使用 v-bind 可以通过 style 或 class, 可以添加动态样式。

    //点击 你好,实现文字红黑之间切换
    

    你好 data:{ changeColor:false }

    6、注册组件语法糖

    所谓的注册组件语法糖是指省去组件构造器的定义,直接将组件构造器对象传入注册组件函数里,这样会减少 CPU 的调度以及内存的分配。

    全局组件使用:

    //全局组件语法糖写法
    Vue.component(
      'my-component' , 
      template:`
      	
    组件内容
    `) /* 全局组件注册 */ //组件使用 //注册组件 const myCompOnent= Vue.extend({ template:`

    VUkeh

    ` }) Vue.component('myComponent', myComponent)

    局部组件使用:

//全局组件语法糖写法
components:{
  'my-component':{
  	template:`
组件内容
` } } /* 局部组件注册 */ //注册组件 const myCompOnent= Vue.extend({ template:`

VUkeh

`, components:{ child:{ template:`
子组件内容
` } } }) Vue.component('myComponent', myComponent)

推荐阅读
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • switch语句的一些用法及注意事项
    本文介绍了使用switch语句时的一些用法和注意事项,包括如何实现"fall through"、default语句的作用、在case语句中定义变量时可能出现的问题以及解决方法。同时也提到了C#严格控制switch分支不允许贯穿的规定。通过本文的介绍,读者可以更好地理解和使用switch语句。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 一次上线事故,30岁+的程序员踩坑经验之谈
    本文主要介绍了一位30岁+的程序员在一次上线事故中踩坑的经验之谈。文章提到了在双十一活动期间,作为一个在线医疗项目,他们进行了优惠折扣活动的升级改造。然而,在上线前的最后一天,由于大量数据请求,导致部分接口出现问题。作者通过部署两台opentsdb来解决问题,但读数据的opentsdb仍然经常假死。作者只能查询最近24小时的数据。这次事故给他带来了很多教训和经验。 ... [详细]
  • 本文介绍了互联网思维中的三个段子,涵盖了餐饮行业、淘品牌和创业企业的案例。通过这些案例,探讨了互联网思维的九大分类和十九条法则。其中包括雕爷牛腩餐厅的成功经验,三只松鼠淘品牌的包装策略以及一家创业企业的销售额增长情况。这些案例展示了互联网思维在不同领域的应用和成功之道。 ... [详细]
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • 本文介绍了Python版Protobuf的安装和使用方法,包括版本选择、编译配置、示例代码等内容。通过学习本教程,您将了解如何在Python中使用Protobuf进行数据序列化和反序列化操作,以及相关的注意事项和技巧。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • 【影评】大内密探灵灵狗
    本文是对王晶执导的电影《大内密探灵灵狗》进行的影评。文章称赞了王晶的才华和导演经验,认为演员阵容强大,笑料不少,发明新奇又好笑。然而,编剧的表现被认为是本片的最大失败,宣传言过其实,笑点不多。总体来说,本片是一部典型的王式喜剧,可看性较高,但没有突破。 ... [详细]
  • 说到C语言的语句块,真是一堆血泪史。第一大坑就是优先级。刚工作那会儿,C的书没看几本,自信满满的认为C语言都会了,拿出搞ACM培养的豪情壮志,代码倒是写得爽,却到处留 ... [详细]
author-avatar
捡耙活哟752
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有