当前位置: 首页 > news >正文

Vue 2.3、2.4 知识点小结

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 。

相关文章:

  • 颜色模式
  • 自作聪明的开发
  • 记录一次MySQL进程崩溃,无法重启故障排查
  • 我的IntelliJ IDEA 设置
  • shell自定义函数
  • SVN:show log问题
  • monaco editor + vue的配置
  • Centos7配置ubuntu本地仓库
  • jQuery 选择器
  • IP unnumbered interface,某个接口不编号,某个接口不分配IP地址
  • struts2中怎样处理404?
  • 一张图让你学会LVM
  • WiFi替代者LiFi首次实测结果出炉:1Gbps
  • 解读:四点让云计算引发全球变革
  • 数据蒋堂 | 开放的计算能力为数据库瘦身
  • 2018天猫双11|这就是阿里云!不止有新技术,更有温暖的社会力量
  • ES6之路之模块详解
  • Idea+maven+scala构建包并在spark on yarn 运行
  • JAVA SE 6 GC调优笔记
  • js操作时间(持续更新)
  • JS正则表达式精简教程(JavaScript RegExp 对象)
  • k8s如何管理Pod
  • mac修复ab及siege安装
  • Spark RDD学习: aggregate函数
  • Spring框架之我见(三)——IOC、AOP
  • 推荐一款sublime text 3 支持JSX和es201x 代码格式化的插件
  • 小程序01:wepy框架整合iview webapp UI
  • 智能合约Solidity教程-事件和日志(一)
  • ​iOS实时查看App运行日志
  • ​LeetCode解法汇总2304. 网格中的最小路径代价
  • #QT(智能家居界面-界面切换)
  • (1)Nginx简介和安装教程
  • (1)常见O(n^2)排序算法解析
  • (C语言)共用体union的用法举例
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (转载)OpenStack Hacker养成指南
  • .net 简单实现MD5
  • .NET/C# 在 64 位进程中读取 32 位进程重定向后的注册表
  • .net流程开发平台的一些难点(1)
  • .net中的Queue和Stack
  • .Net转Java自学之路—SpringMVC框架篇六(异常处理)
  • @Repository 注解
  • [ C++ ] STL_vector -- 迭代器失效问题
  • [ 代码审计篇 ] 代码审计案例详解(一) SQL注入代码审计案例
  • [20180312]进程管理其中的SQL Server进程占用内存远远大于SQL server内部统计出来的内存...
  • [Android Pro] android 混淆文件project.properties和proguard-project.txt
  • [BZOJ4566][HAOI2016]找相同字符(SAM)
  • [CSS]CSS 字体属性
  • [EWS]查找 文件夹
  • [GPT]Andrej Karpathy微软Build大会GPT演讲(上)--GPT如何训练
  • [HarmonyOS]第一课:从简单的页面开始
  • [LeetCode] NO. 169 Majority Element