Vue学习的第十一天

#编写可复用组件

在编写组件时,最好考虑以后是否要进行复用,可复用组件应当定义一个清晰的公开接口,同时也不要对其使用的外层数据作出任何假设.

Vue组件的API来自三个部分--prop,事件和插槽:

1. Prop允许外部环境传递数据给组件;

2. 事件允许从组件内触发外部环境的副作用;

3. 插槽允许外部环境将额外的内容组合在组件中.

#子组件引用

尽管有prop和事件,但是有时仍然需要在JavaScript中直接访问子组件.为此可以使用ref为子组件指定一个引用ID.

<div id="parent">

      <user-profile ref="profile"></user-profile>

</div>

var parent = new Vue({

     el:"#parent"

})

var child = parent.$refs.profile

#异步组件

在大型应用中,可能需要将应用拆分为多个小模块,按需从服务器下载,Vue允许将组件定义为一个工厂函数,异步地解析组件的定义.Vue只在组件需要渲染时触发工厂函数,并且把结果缓存起来,用于后面的再次渲染.

Vue.component('async-example', function(resolve, reject){

      setTimeout(function(){

            resolve({

                  template:"<div>I am async </div>"

            })

     }, 1000)

})

进入/离开&列表过渡

概述


Vue 在插入、更新或者移除 DOM 时,提供多种不同方式的应用过渡效果。

包括以下工具:

在 CSS 过渡和动画中自动应用 class

可以配合使用第三方 CSS 动画库,如 Animate.css

在过渡钩子函数中使用 JavaScript 直接操作 DOM

可以配合使用第三方 JavaScript 动画库,如 Velocity.js

单元素/组件的过渡


Vue提供了transition的封装组件,在下列情形中可以给任何元素和组件添加entering/leaving过渡

1.条件渲染(使用v-if)

2.条件展示(使用v-show)

3.动态组件

4.组件根节点

<div id="demo">

      <button v-on:click="show = ! show">Toggle</button>

      <transition name="fade">

           <p v-if="show">hello</p>

     </transition>

</div>

new Vue({

     el:"#demo",

     data:{

          show:true

     }

})

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,082评论 0 29
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,252评论 0 6
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,109评论 4 129
  • vue学习笔记 安装 Vue 提供一个官方命令行工具,可用于快速搭建大型单页应用。只需几分钟即可创建并启动一个带热...
    EL_PSY_CONGROO阅读 1,108评论 0 5
  • 文/观复知常 常说老子的无为思想消极,那么是真的消极,还是我们没有正常的理解。 无为不是让你不为,而是让你不要带欲...
    观复知常阅读 865评论 3 7