一、前言

进入Vue.js的新世界,打怪升级,熟悉Vue.js的武器系统。菜鸟诞生的第二课,在新手村中熟悉Vue指令~~~

二、打怪升级

1、 v-cloak

在使用Vue的过程中,当我们引入了 vue.js 这个文件之后,浏览器的内存中就存在了一个 vue 对象,此时,我们就可以通过构造函数的方式创建出一个 vue 的对象实例,后面就可以对这个实例进行操作。

如果在这个过程中,对于 vue.js 的引用因为某些原因没有加载完成,此时,未编译的 Mustache 标签就无法正常显示。例如,在下面的例子中,我们模拟将网页加载速度变慢,此时就可以看见,页面最先开始会显示出插值表达式,只有 vue.js 加载完成后,才会渲染成正确的数据。

1

2

{{msg}}

3

4  5  6  7  8     new Vue({ 9         el: '#app',10         data: {11             msg: 'hello world'12         }13     });14

这时候,我们就可以使用v-cloak指令用于隐藏未编译完成的插值表达式,一般我们在使用时会与添加一个隐藏该元素的样式同时使用。

[v-cloak] {

display: none;

}

{{msg}}

大家可以看到,当页面没有显示内容时,此时 p 标签添加了一个 v-cloak 属性,同时,从右侧的样式中可以看到,隐藏显示,当加载完成后, p 标签上去除了该属性,同时插值表达式也编译完成,正确显示出来。

2、 v-text 与 v-html

v-text 与 v-html 指令都可以更新页面元素的内容,不同的是,v-text 会将数据以字符串文本的形式更新,而 v-html 则是将数据以 html 标签的形式更新。

在更新数据上,我们也可以使用差值表达式进行更新数据,不同于 v-text、v-html 指令,差值表达式只会更新原本占位插值所在的数据内容,而 v-text、v-html 指令则会替换掉整个的内容。

1

2  3

+++++++++ {{msg}} -----------

4

=================

5

==============

6      7

============

8  9

10 11 12     new Vue({13         el: '#app',14         data: {15             msg: 'hello world',16             msgHtml: '

I want to learn vue.js

'17         }18     });19

3、 v-bind

v-bind 可以用来在标签上绑定标签的属性(例如:img 的 src、title 属性等等)和样式(可以用 style 的形式进行内联样式的绑定,也可以通过指定 class 的形式指定样式)。同时,对于绑定的内容,是做为一个 js 变量,因此,我们可以对该内容进行编写合法的 js 表达式。

在下面的示例中,我们将这个按钮的 title 和 style 都是通过 v-bind 指令进行的绑定,这里对于样式的绑定,我们需要构建一个对象,其它的对于样式的绑定方法,我们将在后面的学习中提到。

1

2      6      7  8      9     10 

11 12 13 new Vue({14     el: '#app',15     data: {16         msgTitle: '这是我自定义的title属性',17         colorStyle: 'red',18         widthStyle: '120'19     }20 });21

效果示意图如下所示

4、 v-on

在传统的前端开发中,当我们想对一个按钮绑定事件时,我们需要获取到这个按钮的 dom 元素,再对这个获取到的 dom 进行事件的绑定。在我们学习 vue 的过程中,我们可以秉持一个思想,对于 dom 的操作,全部让 vue 替我们完成,我们只关注业务代码实现,因此,我们可以使用 vue 内置的 v-on 指令来替我们完成事件的绑定。

传统的元素 js 写法如下所示

// 传统的事件绑定方法    document.getElementById('btn'). = function () {

alert('传统的事件绑定方法');

}

在使用 v-on 指令对事件进行绑定时,我们需要在标签上指明 v-on:event(click、mousedown、mouseup 等等) 绑定的事件。

这样就可以了吗?我们可以测试下,哦吼,报错了,vue 提醒我们属性或者方法在 vue 实例中未定义,原来在 vue 的设计中许多事件处理逻辑会更为复杂,所以直接把 JavaScript 代码写在 v-on 指令中是不可行的。因此 v-on 还可以接收一个需要调用的方法名称。所以,我们需要在 vue 实例的 methods 下写出方法。

当然,使用 v-on 指令接收的方法名称也可以传递参数,我们只需要在 methods 中定义方法时说明这个形参即可在方法中获取到。

1  2  3  4  5  6 var vm = new Vue({ 7     el: '#app', 8     data: { 9         msgTitle: '这是我自定义的title属性',10         colorStyle: 'red',11         widthStyle: '120'12     },13     methods: {//在 methods 中定义当前 vue 实例的所有可访问方法14         handlerClick() {15             alert('我是使用 v-on 指令绑定的事件');16         },17          handlerClickWithParam(id) {18             alert('我是使用 v-on 指令绑定的事件,方法参数为'+id);19         }20     }21 });

5、 v-model

在之前的学习中,对于数据的绑定,不管是使用插值表达式还是 v-text 指令,对于数据间的交互都是单向的,即只能将 vue 实例里的值传递给页面,页面对数据值的任何操作却无法传递给 model。

例如,在下面的示例页面中,我们手动将页面的 h3 标签里的内容进行修改,通过控制台获取到 vue 实例中的数据,发现数据并没有发生变化。这里可以使用 window.vm 获取到 vue 实例,则是因为我们之前引入 vue.js 后,会自动在浏览器内存中创建 vue 对象,我们通过构造函数创建的 vue 的实例也就存在与浏览器的内存里了。

{{ msg }}

var vm = new Vue({

el: '#app',

data: {

msg: '你好啊,hahaha'

}

});

MVVM中最重要的一个特性,可以说就是数据的双向绑定,而 vue 作为一个 MVVM 框架,理所应当的实现了数据的双向绑定,所以我们可以使用内置的 v-model 指令完成数据的在 View 与 Model 间的双向绑定。

我们知道,只有表单元素可以与用户进行交互,所以我们只能使用 v-model 指令在表单控件或者组件上创建双向绑定。对于组件的双向绑定,我们也会在后面的学习中提到。

{{ msg }}

var vm = new Vue({

el: '#app',

data: {

msg: '你好啊,程十六'

}

});

6、 v-if 与 v-show

v-if 与 v-show 指令都是根据表达式的真假值判断元素的显示与否。

在下面的代码中,我们通过绑定一个按钮的点击事件,去修改 flag 值,从而做到对于两个 h3 标签的显示与否的控制。

1

2      3  4

我是通过 v-if 指令控制的~~~

5

我是通过 v-show 指令控制的~~~

6

7  8  9     var vm = new Vue({10         el: '#app',11         data: {12             flag: true13         },14         methods: {15             handlerClick() {16                 this.flag = !this.flag;17             }18         }19     });20

我们可以看到,flag 的初始值为 true,此时,两个 h3 标签都可以显示出来,当我们点击切换按钮后,两个 h3 都隐藏了,不同的是,我们可以看到,对于使用 v-if 指令控制的 h3 标签,当表达式为 false 时,这个元素 dom 会直接销毁并重建,而对于使用 v-show 指令控制的 h3 标签,当表达式为 false 时,仅仅是将当前元素的 display CSS 属性值设置为 none。所以,当我们需要频繁控制元素的显示与否时,推荐使用 v-show 指令,避免因为使用 v-if 指令而造成的高性能消耗。

7、 v-for

不管我们是写 C# 还是写 JAVA 或者是前端的 JavaScript 脚本,提到循环数据,首先都会想到 使用 for 循环,同样的,在 vue 中,作者也为我们提供了 v-for 这一指令 用来循环数据。

在使用 v-for 指令时,我们可以对数组、对象、数字、字符串进行循环,获取到源数据的每一个值。使用 v-for 指令,必须使用特定语法 alias in expression ,为当前遍历的元素提供别名,这里类似于 C# 中的 foreach 的循环格式。

1

2      3

数组索引值: {{ index }} , 数据值: {{ item }}

4

5  6  7     var vm = new Vue({ 8         el: '#app', 9         data: {10             arrayList: [12, 20, 34, 1, 6]11         }12     });13

在 v-for 指令中,我们拥有对父作用域属性的完全访问权限。v-for 还支持一个可选的第二个参数为当前项的索引。在上面这个循环数组的代码中,item 代表了数组中的每一项数据,index 则表示为当前项的索引,所以我们可以很方便的打印出数组中每一项数据和索引。同时,我们在 ul 标签上绑定了一个 key 属性,它可以为循环出来的每一项提供一个 key 值,我们可以理解成数据库表中的每一条数据都有一个唯一的主键值,同样的,我们需要保证这个 key 值要唯一对应着当前的数据项。

这里,采用循环数组对象的方式,来解释这个 key 属性要唯一的问题。

1

2       3      4

数组索引值: {{ index }} , id: {{ item.id }} , name: {{ item.name }} , age: {{ item.age }}

5

6  7  8     var vm = new Vue({ 9         el: '#app',10         data: {11             objList: [12                     {id: 1,name: 'zhangsan',age: 23},13                     {id: 2,name: 'lisi',age: 32},14                     {id: 3,name: 'wangwu',age: 22},15                 ]16         }17     });18

我们现在循环了一个对象数组,并在每一个数据项多的前面加了一个单选框,现在我们选中 {id: 2,name: 'lisi',age: 32} 这个数据对象,同时,使用控制台往数组中添加新的元素。我们知道往一个数组中新增元素可以使用 push 方法或者是 unshift 方法,我们来尝试一下。

我们看到当我们使用 push 方法在数组的最后添加一个数据时,之前单选框选择的数据没有发生更改,而当我们使用 unshift 方法在数组最前面添加一个数据时,单选框选择的数据就发生了更改。这里就是因为 key 属性绑定的是数组索引的缘故,我们选中的索引值是1,当在选中的数组元素前面添加数据时,原来选中的数组数据的索引值就会加一,所以最后就会选择到别的元素。

这里我们就可以将 key 绑定为 item.id 这个属性,这样我们添加数据时就不会对选中的数据造成影响了,因为,我们已经告诉了程序,我们是根据 item.id 这个 key 值进行选中的,与数组的索引值无关。注意,这里如果我们添加的对象数据 id 还是3的话虽然可以添加成功,但是 vue 会给我们提示警告信息了,因为已经存在了一个 id 等于3的数据。

数组索引值: {{ index }} , id: {{ item.id }} , name: {{ item.name }} , age: {{ item.age }}

对于对象、数字、字符串的循环与对于数组的循环差不多,实现方法如下所示,大家可以自己编写下试试。不过在遍历对象时,是按 Object.keys() 的结果遍历,但是不能保证它的结果在不同的 JavaScript 引擎下是一致的。

键名: {{ key }} , 值: {{ value }} , 索引值: {{ index }}

{{ item }}

{{ item }}

var vm = new Vue({

el: '#app',

data: {

obj: {

id: 1,

name: 'chengshiliu',

age: 17

}

}

});

三、总结

这一章我们主要学习了一些 vue 中的内置指令,熟悉了它们的使用方法,本篇文章的全部的源码都在文章开始处提供仓储地址里,每一个文件的说明,可以查看 github 仓储的 readme 说明,希望多多关注啊,嘻嘻。

20层的试炼html5,Vue.js-02:新手村的试炼 - 新世界的武器(指令)相关推荐

  1. 微信公众号菜单html5,Vue.js 实现微信公众号菜单编辑器功能(一)

    学习一段时间Vue.js,于是想尝试着做一个像微信平台里那样的菜单编辑器,在这里分享下 具体样式代码查看项目github 创建一个vue实例 var app = new Vue({ el: '#app ...

  2. Vue.js 学习笔记 第5章 内置指令

    本篇目录: 5.1 基本指令 5.2 条件渲染指令 5.3 列表渲染指令 v-for 5.4 方法与事件 5.5 实战:利用计算属性.指令等知识开发购物车 回顾一下第2.2节,我们己经介绍过指令(Di ...

  3. Vue.js 3.0 学习笔记(三)指令

    一.内置指令 1.v-show v-show指令会根据表达式的真假值,切换元素的display CSS属性,来显示或者隐藏元素.当条件变化时,该指令会自动触发过渡效果 <!DOCTYPE htm ...

  4. Vue.js基础特性、生命周期及常用指令

    目录 一.Vue构造选项 el根标签 data数据对象 methods定义方法 二.生命周期 三.常用指令 一.Vue构造选项 选项 说明 el 唯一根标签,决定Vue实例会管理哪一个DOM节点 da ...

  5. (9)vue.js 指令(1)

    一.vue.js指令介绍 指令的本质就是 HTML 自定义属性,Vue.js 的指令就是以 v- 开头的自定义属性.我们HTML元素非为固有属性和自定义属性,固有属性就是自己元素本身就有的,比如id, ...

  6. 前端清单之Vue.js篇

    2019独角兽企业重金招聘Python工程师标准>>> 教程实践 基于 Vue 与 DeepStream 构建实时 CRUD 应用:Vue 是专注于 JavaScript UI 的渐 ...

  7. 全面掌握前端框架Vue.js

    整理自菜鸟教程 Vue.js简介 Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架. Vue 只关注视图层, 采用自底向上增量开发的设计. Vue 的目标是通过尽 ...

  8. 基于 Vue.js+Springboot 的学院社团管理系统的设计与实现

    在教育深化改革的背景下,我国除了优化教育体制,提升教育水平之外,还鼓励学生参与课外活动,促进学生全面发展.如何更好地让大学生加入适合自己的社团,在繁忙的学习之余,可以更好的参与到社团的活动,从中汲取新 ...

  9. vue 高阶面试题_15个 Vue.js 高级面试题,必收藏

    1. 渲染项目列表时,"key" 属性的作用和重要性是什么? 渲染项目列表时,key 属性允许 Vue 跟踪每个 Vnode.key 值必须是唯一的. 如果没有使用 key 属性, ...

最新文章

  1. 计算机绘图 招聘,计算机绘图-网课答案.pdf
  2. html最小化窗口,[转载]js实现窗口(支持拉伸,拖拽,最大化,最小化,滚动
  3. rtx3090 pytorch_RTX 3090显卡8K游戏测试演示 《暗黑3》稳定60帧运行
  4. nextcloud 中文乱码解决方案
  5. delphi中採用bpl共享模塊的幾點釋疑
  6. linux如何查看所有的用户(user)、用户组(group)、密码(password/passwd)
  7. CF1208F Bits And Pieces(未解决)
  8. 关于类、抽象类和接口的继承关系
  9. GC之详解CMS收集过程和日志分析
  10. Java来做马里奥[0]—让精灵再次舞动
  11. matlab标签背景透明,ROI透明背景(matlab)
  12. NonEmpty和Hierarchize嵌套的bug
  13. leetcode121、122、123
  14. mysql修改表只读属性_VF设置的疑问
  15. HTML,CSS,font-family: 中文字体的英文名称 (宋体 微软雅黑 的英文写法)
  16. error Link 2005
  17. 【原】win 7 屏幕旋转问题的解决
  18. Sqlite数据库锁死问题
  19. LeetCode:934. Shortest Bridge - Python
  20. ContextCapture空三后像控点颜色含义

热门文章

  1. 柿饼UI在ART-Pi上的移植
  2. android测试类--Method setUp in android.test.AndroidTestCase not mocked
  3. 一篇13年前的采访|庚顿首席科学家孙宝元:从数据融合起步,瞄准创造价值,打造助力智能化生产的利器
  4. 初体验微信小程序记事本
  5. Python——库docx(四)12.25
  6. 自定义listview和ProgressBar的简单使用
  7. android系统自带system/app下载,Android 把应用APK安装包放到system/app下的方法
  8. html5 contenteditable 可编辑属性
  9. 注册公司流程和费用(2016版)
  10. 刷题笔记 | 朋友圈、岛屿的最大面积、岛屿数量