2.3

  • style 多重值;

        <div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

    这会渲染数组中最后一个被浏览器支持的值。

  • 新增.passive 修饰符 (demo1) ; .passive 修饰符表示事件永远不会调用 preventDefault() ,主要为解决滚动和触摸事件的卡顿而出现,关于 passive 更多信息请移步 MDN 。

  • 重新引入 .sync 修饰符 (demo2);提供对于 prop 的双向绑定。

        <child :bar.sync="foo"></child>

    其实是个语法糖

        <child :bar="foo" @update:bar="e => foo = e">

    此时需要在子组件中显示触发事件:

        this.$emit('update:bar', newValue)
  • Async Component Improvements (demo3);

    在 2.3 之前,可以使用异步组件:

      // some.vue
    export default {
    // ...
    components: {
    'asyncCom': () => import('./asyncCøm')
    }
    }

    2.3 新增高级异步组件

    官网上比较清楚:

    为了便于演示,使用延迟加载异步组件:


    import loadingCom from '../components/loadingCom.vue'
    import errCom from '../components/errCom.vue'
    const asyncCom = () => ({
    component: new Promise((resolve, reject) => {
    setTimeout(() => {
    resolve(import('../components/asyncCom.vue'))
    }, 2000)
    }),
    loading: loadingCom,
    error: errCom,
    delay: 200,
    timeout: 3000
    }) export default {
    // ...
    components: { asyncCom }
    }

    效果如下图:

    或者,你也可以点击后加载 (demo4):

    当然,也可以用于 vue-router ( 2.40+ ) demo5

  • Functional Component Improvements;

    在2.3 + 版本,函数式组件可以省略 props 选项,所有组件上的属性会被自动解析 成props,更多内容,请参考 https://cn.vuejs.org/v2/guide/render-function.html#函数化组件 。

2.4

  • v-on 支持绑定一个事件/监听器键值对的对象,此时不支持任何修饰器;
  <button v-on="{ mousedown: some, mouseup: other }"></button>
  • 新增 comments 选项,当设为 true 时,将会保留且渲染模板中的 HTML 注释;
    该选项暂时无法在构建工具中使用 issues
  • 新增 interitAttrs 选项;

    在版本 2.4 之前,默认情况下父作用域的不被作为props特性绑定的属性,将会作为普通的 HTML 属性,应用在跟元素上。

    举个例子:

      // parent.vue
    <template>
    <child-commpent :foo="f" :boo="b"></child-comment>
    </template> <script>
    const childComment = () => import('./childCom.vue')
    export default {
    data () {
    return {
    f: 'Hello world!'
    b: 'Hello Vue!'
    }
    }
    }
    </script>
      // childComment.vue
    <template>
    <div>{{ foo }}<div>
    </template> <script>
    export default {
    props: ['foo']
    }
    </script>

    最后会被渲染为:

      <div boo="Hello Vue!">Hello world!</div>

    设置 interitAttrs 为 false,之后,不会应用到跟元素上。

      // childCom.vue
    <template>
    <div>{{ foo }}</div>
    </template> <script>
    export default {
    props: ['foo'],
    inheritAttrs: false
    }
    </script>

    渲染:


    <div>Hello world!</div>
  • 新增 $attrs, $listeners 选项;

    多级组件嵌套需要传递数据时,通常使用的方法是通过 vuex 。如果仅仅是传递数据,而不做中间处理,使用 vuex 处理,未免有点杀鸡用牛刀,Vue 2.4 版本提供了另一种方法,使用 v-bind="$attrs", 将父组件中不被认为 props特性绑定的属性传入子组件中,通常配合 interitAttrs 选项一起使用,具体请看 demo 。

      // demo.vue
    <template>
    <div>
    <child-com :foo="foo" :boo="boo" :coo="coo" :doo="doo"></child-com>
    </div>
    </tempalte>
    <script>
    const childCom = () => import('./childCom1.vue')
    export default {
    data () {
    return {
    foo: 'Hello World!',
    boo: 'Hello Javascript!',
    coo: 'Hello Vue',
    doo: 'Last'
    }
    },
    components: { childCom }
    }
    </script>
      // childCom1.vue
    <template>
    <div>
    <p>foo: {{ foo }}</p>
    <p>attrs: {{ $attrs }}</p>
    <child-com2 v-bind="$attrs"></child-com2>
    </div>
    </template>
    <script>
    const childCom2 = () => import('./childCom2.vue')
    export default {
    props: ['foo'],
    inheritAttrs: false,
    created () {
    console.log(this.$attrs) // { boo: 'Hello Javascript!', coo: 'Hello Vue', doo: 'Last' }
    }
    }
    </script>
      // childCom2.vue
    <template>
    <div>
    <p>boo: {{ boo }}</p>
    <p>attrs: {{ $attrs }}</p>
    <child-com3 v-bind="$attrs"></child-com3>
    </div>
    </template> <script>
    const childCom3 = () => import('./childCom3.vue')
    export default {
    props: ['boo']
    inheritAttrs: false,
    created () {
    console.log(this.$attrs) // { coo: 'Hello Vue', doo: 'Last' }
    }
    }
    </script>
      // childCom3.vue
    // ...

    最后被渲染为

    具体请看 demo6 。

    $listeners 的用法和 $attrs 类似,demo6 。

Vue 2.3、2.4 知识点小结的更多相关文章

  1. React及Nextjs相关知识点小结

    React及Nextjs知识点小结 函数式组件和类组件区别是什么 1.函数式组件是用于创建无状态的组件,组件不会被实例化,无法访问this中的对象,无法访问生命周期方法,是无副作用的,相比于类组件函数 ...

  2. C++重要知识点小结---3

    C++重要知识点小结---1:http://www.cnblogs.com/heyonggang/p/3246631.html C++重要知识点小结---2:http://www.cnblogs.co ...

  3. C++重要知识点小结---2

    C++重要知识点小结--1 :http://www.cnblogs.com/heyonggang/p/3246631.html 1.C++允许程序员声明一个不能有实例对象的类,这样的类惟一的用途是被继 ...

  4. 【SpringBoot MQ 系列】RabbitMq 核心知识点小结

    [MQ 系列]RabbitMq 核心知识点小结 以下内容,部分取材于官方教程,部分来源网络博主的分享,如有兴趣了解更多详细的知识点,可以在本文最后的文章列表中获取原地址 RabbitMQ 是一个基于 ...

  5. SpringBoot 系列教程之事务隔离级别知识点小结

    SpringBoot 系列教程之事务隔离级别知识点小结 上一篇博文介绍了声明式事务@Transactional的简单使用姿势,最文章的最后给出了这个注解的多个属性,本文将着重放在事务隔离级别的知识点上 ...

  6. disruptor笔记之四:事件消费知识点小结

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  7. vue知识点小结

    vue.js中==和===的区别 1.== 用于比较.判断两者相等,比较时可自动换数据类型 2.=== 用于(严格)比较.判断两者(严格)相等,不会进行自动转换,要求进行比较的操作数必须类型一致,不一 ...

  8. Vuejs技术栈知识点小结

    前言 上家公司的项目主要是使用jQuery和Angular1,然后自己学了React,没想到来到这家公司突然开始做vue,不过vue还是挺容易上手的.下面是vue技术栈的一些总结,都是来自官网,主要是 ...

  9. promise知识点小结

    断断续续学习es6也有一段时间了,趁着开学空闲对知识点做一些小结. 为什么使用promise 谈到Promise,我们知道,这是社区较理想的异步编程解决方案.想要掌握promise,我们首先要知道其提 ...

随机推荐

  1. silverlight5 OOB 直接p/invoke实现串口通信

    public class SerialWrapper : IDisposable     {         #region Enum         public enum StopBits     ...

  2. JMeter上传案例2

    今天自己的QQ群里有个朋友一直在问JMeter图片上传的问题 原始通过JMeter抓包如下: 参考: http://blog.csdn.net/huashao0602/article/details/ ...

  3. 设置VMware10开机自启动并同时启动虚拟机镜像系统

    首先,进入VMware Workstation的安装目录 C:\Program Files (x86)\VMware\VMware Workstation

  4. 实际生产用法CMS和G1

    java -Xms100m -Xmx100m -Xmn50m -XX:MetaspaceSize=20m -XX:MaxMetaspaceSize=20m -XX:+UseConcMarkSweepG ...

  5. Ubuntu16.04中nginx除80之外其他端口不能访问

    不废话, 大多数都以为是ufw防火墙的问题. 但我的是因iptables防火墙, 坑死我了. 查了好多也没查到怎么在Ubuntu关闭iptables, 索性直接卸载 apt-get remove ip ...

  6. 《第六周java学习笔记》

    教材知识点总结 Java 把 String 类定义为 final 类. new 运算符首先分配内存空间并在内存空间中放入字符序列,然后计算出引用.(new String(char a[],int st ...

  7. 最小生成树-QS Network(Prim)

    题目大意: 给出的案例结果得出步骤,如下图所示,从结点1开始查找,找出的一条路径如绿色部分所标注.(关键处在于连接每条路径所需要的适配器的价格得加上去) 代码实现: #include<iostr ...

  8. JAVA基础中的注意点(一)

    1.标识符 标识符:标识某些事物用于区分的符号.  (即区分某些事物的符号) 四条硬性规定: a.不能是 关键字.true.false.null. b.可以包含 字母.数字(0-9).下划线(_)或美 ...

  9. python中sqlite问题和坑

    import sqlite3 #导入模块 conn = sqlite3.connect('example.db') C=conn.cursor() #创建表 C.execute('''CREATE T ...

  10. 使用Admin监控

    在springboot中,也提供了很全面的监控系统.这篇文章介绍一下springboot-admin监控springboot项目. 原来大致是这样的,springboot--admin--server ...