自定义指令 ,自定义过滤器,组件的创建和使用,组件的高级用法-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、过滤器使用
<any>{{price | myCurrency}}</any>
3、过滤器高级用法

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

①如何给过滤器传参?
<h1>{{price | myCurrency('¥',true)}}</h1>
②如何在过滤器中接收到?
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: '<h1>it is a component</h1>'
})
export default {//局部注册
  data() {
    return {
    };
  },
  components: {
    'my-component':myComponent
  },
};
2、组件的使用

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

<my-component> </my-component>

建议:组件的命名和使用建议来使用烤串式命名规则。
(如果组件的名字写成驼峰式 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

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

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,048评论 0 29
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,207评论 0 6
  • # 传智播客vue 学习## 1. 什么是 Vue.js* Vue 开发手机 APP 需要借助于 Weex* Vu...
    再见天才阅读 3,534评论 0 6
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,010评论 4 129
  • 8月10日。我的姨妈从西安千里迢迢地赶了回来,姥姥为了庆祝,让我们一起去过两个景点,而五老峰就是其中一个。 ...
    风信子_1b1a阅读 426评论 0 0