vue 基础入门教程(二)

说明:在基础一的基础上我们对vue有了一个大概的了解那么之后我们就可以开始新的学习了。

基础入门教程(二)的内容:

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

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

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

1、自定义指令
①创建

    new Vue({
        directives:{
            change:{
                bind:function(){},
                update:function(){},
                unbind:function(){}
            }
        }
    })

    在自定义指令时,在指令对应的配置对象中有3个处理函数指令对应的操作
    bind
        指令在绑定到元素要执行的操作
    update
        如果在调用指令时候,传了参数,当参数变化时候,就会执行update所指定的方法
    unbind
        解绑要执行的操作

②使用自定义指令
    

directives:{
   hello:{
      bind:function(){},
      update:function(){},
      unbind:function(){}
   }
}
v-hello


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

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

过滤器:生活中有很多例子,净水器 空气净化器 。
过滤器的作用:实现数据的筛选、过滤、格式化。

vue1.*版本是有内置的过滤器,但是在vue2.*所有的版本都已经没有自带的过滤器了。1、过滤器创建
过滤器的本质 是一个有参数 有返回值的方法
 

new Vue({
    filters:{
        myCurrency:function(myInput){
            return 处理后的数据
        }
    }
})

2、过滤器使用
语法:
<any>{{表达式 | 过滤器}}</any>
举个例子:
<h1>{{price | myCurrency}}</h1>

3、过滤器高级用法

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

①如何给过滤器传参?
<h1>{{price | myCurrency('¥',true)}}</h1>
②如何在过滤器中接收到?

new Vue({
    filters:{
    //myInput是通过管道传来的数据
    //arg1在调用过滤器时在圆括号中第一个参数
    //arg2在调用过滤器时在圆括号中第二个参数
    myCurrency:function(myInput,arg1,arg2){
    return 处理后的数据
}    }})

三、组件

w3c为什么有组件概念?

现在的前端领域,对于代码的质量和数量有着非常高的要求,特别容易出问题。
通过组件的方式来完成代码的管理和编写。

组件:是一个可以被反复使用的 带有指定功能的 视图

组件化编程 一切都是组件component,把可以被反复使用的任何的视图 都可以封装成组件。


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

1、组件的创建
    

Vue.component('my-component',{
   template:'<h1>it is a component</h1>'
})

2、组件的使用
    组件的使用就像是使用普通的html标签一样
    <my-component>    </my-component>

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

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

3、复合组件
组件可以像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

猜你喜欢

转载自blog.csdn.net/weixin_42457316/article/details/81334506