复习4

组件通讯之slot

在要封闭的组件内部通过slot实现:

例如:

 <div class="hd" ref="hd">
    <slot name="goBack"></slot>
    {{ title }}
    <slot name="logout"></slot>
</div>


调用时,在组件标签中间嵌入:通过 slot="名称"来嵌入

<div class="hd" ref="hd">
    <slot name="goBack"></slot>
    {{ title }}
    <slot name="logout"></slot>
</div>

总结:封装一个组件的三要素:要传递的参数,事件,slot

组件通讯是单向的数据流:

如何双向传递解决方案:

   第一种方案:父组组件往子级组件传递一个JS对象  【不推荐】
   第二种方案:利用sync和update事件触发来来向父级反馈更新的值

       第一步:在父级传递的子组件添加sync

         例如: <headCom :title.sync="t"></headCom>


       第二步:在子组件内部,通过$emit更新父组件传递过来的值

         例如: this.$emit('update:title',v)

           其中:update是一个关键字,固定写法,后面跟冒号(:),再后是你要更新的哪个属性,例如:title



    当然:表单中的v-model也是双向数据流、

计算属性:主要通过computed关键字实现

通过逻辑计算,得到的一个新值,这个新值是可以实时响应的
计算属性的优势:可以缓存数据

注意:watch

你说一下vue中 methods,computed,watch的区别???

$set:可以动态的给对象添加属性,并且实现响应

vue过滤器:即数据进行格式化处理

一、 创建Vue过滤器:

1.全局过滤器

  Vue.filter('过滤器名称',function(参数1,参数2,...) {

      //逻辑实现

  })

  注意:参数1:就是要格式化的那个数据,
        参数2:才是真正过滤器中传递的第3个参数
        参数3:才是真正过滤器中传递的第2个参数
        以此类推。。。。


  全局过滤器:可以在任意组件中使用
  

2.局部过滤器:

  通过filters只能在当前组件内部来使用

二、使用过滤器

{{ 要格式化的数据 | 过滤器名(参数1,参数2,...,参数n) }}

自定义指令:主要对经常使用的dom操作进行封装,方便复用

vue指令:

  vue内置指令:v-for,v-if,v-show,v-cloak,v-html......
  vue自定义指令:全局自定义指令,局部自定义指令

    第一种:全局自定义指令:
    
       Vue.directive('自定义指令名',{

             
       })

       例如:

       Vue.directive('focus',{
        inserted(el) {
            console.log('el:',el)
            el.focus();
        }
      });

    第二种:局部自自定指令:主要通过directives实现

转场动画:主要通过transition组件来实现动画效果

使用步骤:

  第一步:要给进行切换的区域添加一个transition组件,并且添加一个name名称,这个名称即为css类的前缀

    例如:

      <transition name="move">
          <router-view></router-view>
       </transition>

  第二步:给添加name的transition定义css3动画效果,例如:位移(tranform:translate()),淡入淡出(opaicty)

        设置动画:进入动画,离开动画

        1.进入动画:
        
           .name名称-enter {

            }
           .name名称-enter-active {


           }

           例如:
           .dh-enter {
              transform: translateX(-100%)
            }

  

        2.离开:

        .name名称-leave {


        }

        .name名称-leave-active {


        }

        例如:

        .dh-leave-active {
            transform: translateX(100%)
        }

        .dh-enter-active, .dh-leave-active {

            transition: transform .3s;
        
        }



animate.css和vue中的transition配合使用


说明:

      1.进入动画  enter-active-class="animated tada"  
      2.离开动画:leave-active-class="animated fadeInDown"

 <transition 
      name="move"
      enter-active-class="animated tada"
      leave-active-class="animated fadeInDown"
 >
   <router-view></router-view>
 </transition>


###  keep-alive:可以缓存组件内容在内存中

   <keep-alive include="home,cate">
     <router-view></router-view>
   </keep-alive>

 说明:

   include:表示只包含对应的组件才缓存
   exclude:表示排除要缓存的组件


   与keep-alive相关的钩子函数:

    activated:keep-alive 组件激活时调用
    deactivated:keep-alive 组件停用时调用

    注意:必须在使用keep-alive时才会激活activated和deactivated这两个钩子

    


nextTick
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容

  • vue概述 在官方文档中,有一句话对Vue的定位说的很明确:Vue.js 的核心是一个允许采用简洁的模板语法来声明...
    li4065阅读 7,185评论 0 25
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,044评论 0 29
  • 一:什么是闭包?闭包的用处? (1)闭包就是能够读取其他函数内部变量的函数。在本质上,闭包就 是将函数内部和函数外...
    xuguibin阅读 9,523评论 1 52
  • 第一章 Vue概述 what? Vue是实现UI层的渐进式js框架,核心库关注视图层,简单的ui构建,复杂的路由控...
    fastwe阅读 700评论 0 0
  • 双休两天,天大寒,砚冰坚,室外滴水成冰;屋里生有火炉,暖如春天!写字、读书,自得其乐;品茗,下棋,美若神仙!无俗世...
    红梅赞_af47阅读 276评论 2 4