自定义指令 ,自定义过滤器,组件的创建和使用,组件的高级用法-02

一、自定义指令的创建和使用

Vue自带的指令很多,v-for/v-if/v-else/v-else-if/v-model/v-bind/v-on/v-show/v-html/v-text...
但是这些指令都是比较偏向于工具化,有些时候在实现具体的业务逻辑的时候,发现不够用,如何来自定义指令。

①注册自定义指令

new Vue({
  directives: { //注册指令,类似于注册组件
    change: { //定义名为change的指令
      bind: function () {},
      update: function () {},
      unbind: function () {}
    }
  }
})

在自定义指令时,在指令对应的配置对象中有3个处理函数指令对应的操作

bind:指令在绑定到元素要执行的操作,只调用一次
update:如果在调用指令时候,传了参数,当参数变化时候,就会执行update所指定的方法
unbind:解绑要执行的操作

②使用自定义指令

v-change

注意事项:
建议在给指令的命名采用小驼峰式的命名方式,比如changeBackgroundColor,在使用的时候,采用烤串式写法 v-change-background-color

练习:实现自定义指令v-time,在微博朋友圈中常见的将用户发布某些内容的时间改为“刚刚”,“XX分钟前”等。

时间转换逻辑:
1分钟以前:显示“刚刚”
1分钟-1小时之间:显示“XX分钟前”
1小时-1天之间:显示“XX小时前”
1天-1个月(31天)之间,显示“XX天前”
大于1个月,显示“XX年XX月XX日”

二、自定义过滤器的创建和使用

vue支持在{{}}插值的尾部添加一个管道符“|”对数据进行过滤,经常用于格式化文本比如字母大小写,货币千位使用逗号分隔等等。
过滤器的作用:实现数据的筛选、过滤、格式化。
vue1.版本是有内置的过滤器,但是在vue2.所有的版本都已经没有自带的过滤器了。

1、过滤器创建

过滤器的本质是一个有参数有返回值的方法。

export default {
  data() {
    return {
        price:500,
    };
  },
  filters: {
    myCurrency: function (myInput) {
      return myInput+100;   //返回处理后的数据
    }
  }
};
2、过滤器使用
{{price | myCurrency}}
3、过滤器高级用法

在使用过滤器的时候,还可以指定参数,来告诉过滤器按照参数进行数据的过滤。

①如何给过滤器传参?

{{price | myCurrency('¥',true)}}

②如何在过滤器中接收到?
export default {
  data() {
    return {};
  },
  filters: {
    //myInput是通过管道传来的数据
    //arg1在调用过滤器时在圆括号中第一个参数
    //arg2在调用过滤器时在圆括号中第二个参数
    myCurrency: function (myInput, arg1, arg2) {
      return 处理后的数据;
    }
  }
};

常用过滤器链接 https://blog.csdn.net/dylan_zeng92/article/details/77850143

三、组件

w3c为什么有组件概念?
现在的前端领域,对于代码的质量和数量有着非常高的要求,特别容易出问题。
通过组件的方式来完成代码的管理和编写。
组件:是一个可以被反复使用的 带有指定功能的 视图
组件化编程 一切都是组件component,把可以被反复使用的任何的视图 都可以封装成组件

组件化的好处(封装):
①提高了代码的复用率
②提高开发速度
③降低测试难度
④降低整个应用的耦合度

1、组件的创建

组件需要注册以后才可以使用,注册分为全局注册和局部注册,全局注册,任何Vue实例都可以使用。

Vue.component('my-component', {//全局注册
  template: '

it is a component

' })
export default {//局部注册
  data() {
    return {
    };
  },
  components: {
    'my-component':myComponent
  },
};
2、组件的使用

组件的使用就像是使用普通的html标签一样

 

建议:组件的命名和使用建议来使用烤串式命名规则。
(如果组件的名字写成驼峰式 myComponent,使用依然还得是烤串式)

注意:
①如果一个组件要渲染多个元素,将多个元素放到一个顶层标签;否则会报错。

3、复合组件

组件可以像vue实例那样使用其他选项,比如data,computed,methods,只是在使用data时和实例稍有区别,这里的data必须是函数,然后将数据return出去。

组件可以像html一样来使用,复合组件并不是一个新的概念,就是一个组件,只不过该组件中又调用了其它的组件。

一个完整的Vue的项目,可以比作是一颗组件树,组件树的根 就是 根组件(my-article)....

组件树可以帮助我们降低业务的复杂度,避免出现一些错误,提高开发速度。

4、组件的生命周期

分为4个阶段:create/mount/update/destroy,每一个阶段都对应着有自己的处理函数。

create: beforeCreate created 初始化
mount: beforeMount mounted 和挂载相关的处理
update: beforeUpdate updated 根据要更新的数据 做逻辑判断
destroy:beforeDestroy destroyed 清理工作

在Vue的实例或者在组件,都有哪些属性?
el
data
methods
directives
filters
watch

你可能感兴趣的:(自定义指令 ,自定义过滤器,组件的创建和使用,组件的高级用法-02)