昨天我们大致了解了有关Vue的基础知识和语法;今天我们继续在大V这条路上前进。

首先,我们回忆一下昨天提到的相关知识点:

1.了解Vue的核心理念------”数据驱动视图“

2.了解Vue的特色功能-------”双向绑定“

3.了解Vue的基础语法-------”{{bigSurprise}},el:'',data{},vm.project,method{},等

首先,昨天我们提到了很好用的双向绑定,但是如果在某些情况下我们不需要双向绑定应该怎么办呢,看如下代码:

<div id=" javascript ">

<div v-once> {{ vue }} </div>

<input v-medol="vue">

</div>

new Vue({

  el:'#javascript'

  data{

    vue : ' hello world '

}

})

那么这个地方,我们堆div标签添加一个directive,即为 v-once,阻止了双向绑定,所以当input中的元素发生改变,div中也并不会改变。

然后进入正题------------filters(过滤器)

先上代码:

new Vue ({

  el:'#javascript'

  data{

    vue :  123.123

},

  filters{

    toInt function(value){

      return parseInt(value)

}

}

})

<div>{{vue}}</div>

//那么这个时候div中输出的元素就应该是整数 123.

可以看到,data中定义了一个小数变量,通过关键字filters定义了一个传参方法(值得注意的是filters中function的默认第一个参数为当前value值)---toInt

既然说到了filters,那么我们还需了解到的是,filters支持链式写法,代码如下:

<div>{{ vue | filtersMc | filtersCm }}</div> ( 利用管道符分割多个过滤器,过滤器会自动按照顺序执行 )

当然filters也可以传递参数, 代码如下:

<div>{{ vue | filtersMc , Mc1 , Mc2 }}</div>

(不同的参数之间用逗号隔开,在这里,其实我们已经拥有了3个参数-------value, Mc1 , Mc2)

PS: 然而filters在2.0版本以后,将不再被允许在directive中使用,所以这个时候我们引入 计算属性---computed;

废话不多说,直接上代码:

new Vue({

  el:' mcc ',

  data {

    mcc_number : 123.123

},

  filters{

    toInt function(value){

      return parseInt(value)

},

  computed{

    mcc_numbers : function(){

      return parseInt( this.mcc_number )

}

  method{

    toInt : function{

      return parseInt (this.mcc_number)

}

}

}

}

})

<div id="mcc">

<div> {{mcc_number}} </div>

<div>{{mcc_numbers}}</div>

</div>

以上代码,我们可以发现,

1.我们利用计算属性computed替代了filters的作用

2.我们利用computed计算出来的mcc_numbers其实是一个动态属性,它随着mcc_number的变化而改变,而不像filters只获取当前data中的数据,这一点值得推崇。

3.这里的computed中的mcc_numbers不是一个方法,而是作为一个属性来使用(如果不能理解,试着理解计算属性这个词)

4.上面代码中的this,也就是vm(昨天提到了  view-medol)

所以,我们看一下打印的结果:

console.log( vm.mcc_number )    // -> 123.123

console.log( vm.mcc_numbers )  //  ->123

if ( vm.mcc_number == 123456.123456 )

console.log( vm.mcc_number )  //  ->123456.123456

console.log( vm.mcc_numbers )  //  ->  123456;

细心的人可能还发现了,我们利用 method{ toInt:function() }其实也达到了相同的效果,那么这两种写法的区别在哪里呢??

我们来试着理解一下,上面提到计算属性是动态输出,那么它是根据 mcc_number 的变化而变化的,换言之,它随着 data 的数据而变化

我们可以把data当成 computed 的数据源,那么当data没有发生变化的时候,data中的数据就会被缓存;而filters和method不一样就在于

filters和method中都是一个方法,它们每次都会运行一次这个方法(上面提到,computed中的mcc_number是一种属性);所以善于计算属性

在某些情况下就会提高开发效率。

举一个例子:

compute{

  date : function() {

    return Data.now()

}

}

这个例子没有依赖任何的data数据,所以在data数据变化之前,它会一直缓存住第一个数据,而不用每次都要再运行一次拿到数据。

这些东西感觉陌生? ALL right~ 我们来点熟悉的~~~

前面我们提到了  v-bind=”“ 可以用来绑定HTML的自有属性,那么现在我们来延展一下 v-bind=”“:

<div class=" vue " v-bind="{ active : bootstrap , current : directive }"></div>

new Vue({

  el:'',

  data{

    bootstrap : true,

    directive : false

}

})

注:

1.以上代码我们利用 v-bind 绑定了两个键值对,key为类名,而value为属性

2.我们在data中做一个判断,当属性为true的时候 显示对应的key,反之则不显示

3.v-bind=”{}“是可以和自带的class 连用的,于是输出结果为  -> <div class=" vue active "></div>

我们继续延展,上代码:

<div class="vue" v-bind="{ objectClass }"></div>

new Vue({

  el:'',

  data:{

    objectClass:{

      nav:true

      header:true

      active : true,

      current:false

      btn:false

      footer:false

}

}

})

不难看出,我们其实只是把v-bind所绑定的键值对换成了对象而已,然后在data中对对象中的class直接进行判断

这种写法比较适合class较多的情况。

有经验的小伙伴,肯定可以想到下一步该学习什么了,对,既然对象有了,键值对有了,那数组呢?

代码如下:

<div class = "vue" v-bind="{ [ mmClass, ccClass , ffClass] }"

new Vue({

  el:'',

  data{

    mmClass : active,

    ccClass : current,

    ffClass : nav

}

})

这种用数组的写法使用于切换多个class的情况,和之前的判断显不显示同一个类名有所不同

如果你依然需要判断是否显示,那么可以这样:

<div class = " vue "  v-bind = "{ [ activeOk ? active : ' ', mmClass]  }"

如果觉得这样的三元计算方法太过复杂,那么我们可以换一种方式:

<div class = " vue " v-bind = " { [ { active : bootstrap }, mmClass ] } "

如上,我们在数组中又加入了一个键值对,利用value来判断是否显示active

同样,思维活跃的小伙伴们又会发现,我们除了把它变成一个键值对,如果有更多的class,我们还可以把它变成一个对象来写,如下:

<div class = "vue"  v-bind = " { [ { objectClass }, mmClass ] } "

new Vue ({

  el:'',

  data : {

    objectClass : {

      active : true,

      current : false

}

    mmclass : nav

}

})

这样的写法可以理解为,前面固定一个或多个类名,而后面可以显示任意类名

我们学习完利用v-bind="{}"绑定class,那么同理,我们依然可以用这几种方法来绑定 Class, 这个留个大家一起来做,明天晚上我们一起来揭晓答案~~

顺便提一下,在vue中,某些需要加前缀的属性,比如 border-radius,transform等,vue会自动添加前缀~~~很方便哦~~~~~~

冰冻三尺,非一日之寒;学习东西也一样,我们一步一步稳扎稳打的走~~那么明天见~~~~~~good night~~~

Vue学习之路---No.2(分享心得,欢迎批评指正)的更多相关文章

  1. vue学习之路 - 4.基本操作(下)

    vue学习之路 - 4.基本操作(下) 简述:本章节主要介绍 vue 的一些其他常用指令. Vue 指令 这里将 vue 的指令分为系统内部指令(vue 自带指令)和用户自定义指令两种. 系统内部指令 ...

  2. Vue学习之路之登录注册实例代码

    Vue学习之路之登录注册实例代码:https://www.jb51.net/article/118003.htm vue项目中路由验证和相应拦截的使用:https://blog.csdn.net/wa ...

  3. Vue学习之路---No.4(分享心得,欢迎批评指正)

    这里说声抱歉,周末因为有其他事,没有更新博客,那么我们今天继续上周5的说. 老规矩,先回顾一下上一次的重点: 1.利用V-if和v-else来提到show()和hide(),同时要记住,v-else一 ...

  4. JAVA学习之路与大家分享

    这是我四年以前总结的JAVA学习之路,希望对初学者或想从事JAVA开发的人有帮助. 本人是软件工程专业出身,先后学过C.C++.JAVA.VB.delphi等等开发语言以及网络相关管理技术.哎,好久不 ...

  5. Vue学习之路第一篇(学习准备)

    1.开发工具的选择 这个和个人的开发习惯有关,并不做强求,厉害的话用记事本也可以.但是我还是建议用人气比较高的编辑工具,毕竟功能比较全面,开发起来效率比较高. 我之前写前端一直用的是sublimete ...

  6. Vue学习之路---No.6(分享心得,欢迎批评指正)

    我们还是先回顾一下上一次的重点: 1.事件绑定,我们可以对分别用方法和js表达式对事件进行处理 2.当方法名带括号的时候,在方法中一定要传参:而不带括号的时候,vm会自动配置默认event 3.各类事 ...

  7. Vue学习之路---No.7(分享心得,欢迎批评指正)

    老规矩,先回顾一下上回的重点: 1.对于input框,若为单选框,如果没有对其设置value,那么其checked的值将在true Or false之间切换:如果设置了value,那么将会切换valu ...

  8. Vue学习之路---No.3(分享心得,欢迎批评指正)

    同样的,我们先来回顾一下昨天学习的内容: 1.利用v-once来组织双向绑定 2.filter{}过滤器的使用(详情请看上一章) 3.computed(计算属性),利用computed属性实现filt ...

  9. Vue学习之路---No.1(分享心得,欢迎批评指正)

    首先为了打消大家对Vue.js存在的顾虑,先通过大家所熟知的JQ作为对比. 都知道JQ的语法相对简单.清楚.使用方便.功能齐全: 那么Vue.js呢,同样的,Vue.js与JQ在很多地方都是相同之处, ...

随机推荐

  1. 3.1. 修改托管对象模型(Core Data 应用程序实践指南)

    托管对象模型是会变好的,有时候变化的比较小,什么添加验证规则.修改默认值.修改获取请求模板等.但是设置到结构变化,如添加.删除字段时,需要先把持久化数据区迁移到新的模型版本才行.假如没有提供迁移数据所 ...

  2. 浅谈Log4j

    1 什么是Log4j Log4j 是Apache为Java提供的日志管理工具.为了你快速理解Log4j的作用,我们用下面的代码说明Log4j的作用.我们为了调试程序,总是需要在程序使用System.o ...

  3. 查看Eclipse版本号,及各个版本区别

    查看Eclipse版本号,及各个版本区别 参考:http://blog.csdn.net/gaojinshan/article/details/38903043 查看Eclipse版本号的方法:1.找 ...

  4. 如何给js动态创建的dom添加事件

    delegate() 方法 实例 当点击鼠标时,隐藏或显示 p 元素: $("div").delegate("button","click" ...

  5. editormd使用教程

    对于现在的程序员来说,都需要一个快速写文章的语言,那么无非就是markdown了,市面上markdown编辑器并不多,而且也不怎么好用,现在推荐国内的比较牛逼的. 入门 建议先到官方看下如何使用,避免 ...

  6. Hadoop权威指南:从Hadoop URL读取数据

    [TOC] Hadoop权威指南:从Hadoop URL读取数据 使用java.net.URL对象从Hadoop文件系统读取文件 实现类似linux中cat命令的程序 文件名 HDFSCat.java ...

  7. JavaSE 教程的选择

    你好 我是大福 你现在看的是大福笔记 又降温了 下点小雨 出门有点冷 走路到公司20多分钟,又走的有点热 昨天说到了,今年的计划是从零开始重新学习并梳理下这两年学习和接触到的技术 那么今天开始第一个知 ...

  8. Applovin Interview (面经)

    职位:SDE Intern positon 地点: San Jose 轮电面:self introduction what's your interest Concept of "Concu ...

  9. 程序员的一生时间90%是用在编程上,而剩余的10%是活在世界上。刚进CSDN的博客看到这么句话

    程序员的一生时间90%是用在编程上,而剩余的10%是活在世界上. 而自己呢?是个程序员呢还是个业余玩家!

  10. Spring 中使用Quartz实现任务调度

    前言:Spring中使用Quartz 有两种方式,一种是继承特定的基类:org.springframework.scheduling.quartz.QuartzJobBean,另一种则不需要,(推荐使 ...