vue 学习笔记第二弹
1.x 版本中的 filterBy 指令,在2.x中已经被废除:
filterBy - 指令
1<tr v-for="item in list | filterBy searchName in 'name'">
2
3 <td>{{item.id}}</td>
4
5 <td>{{item.name}}</td>
6
7 <td>{{item.ctime}}</td>
8
9 <td>
10
11 <a href="#" @click.prevent="del(item.id)">删除</a>
12
13 </td>
14
15</tr>
在 2.x 版本中手动实现筛选的方式:
筛选框绑定到 VM 实例中的
searchName
属性:
1<hr> 输入筛选名称:
2
3<input type="text" v-model="searchName">
在使用
v-for
指令循环每一行数据的时候,不再直接item in list
,而是in
一个 过滤的 methods 方法,同时,把过滤条件searchName
传递进去:
1<tbody>
2
3 <tr v-for="item in search(searchName)">
4
5 <td>{{item.id}}</td>
6
7 <td>{{item.name}}</td>
8
9 <td>{{item.ctime}}</td>
10
11 <td>
12
13 <a href="#" @click.prevent="del(item.id)">删除</a>
14
15 </td>
16
17 </tr>
18
19 </tbody>
search
过滤方法中,使用 数组的filter
方法进行过滤:
1search(name) {
2
3 return this.list.filter(x => {
4
5 return x.name.indexOf(name) != -1;
6
7 });
8
9}
1.1. 过滤器
概念:Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。过滤器可以用在两个地方:mustache 插值和 v-bind 表达式。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示;
1.1.1. 私有过滤器
HTML元素:
1<td>{{item.ctime | dataFormat('yyyy-mm-dd')}}</td>
私有
filters
定义方式:
1filters: { // 私有局部过滤器,只能在 当前 VM 对象所控制的 View 区域进行使用
2
3 dataFormat(input, pattern = "") { // 在参数列表中 通过 pattern="" 来指定形参默认值,防止报错
4
5 var dt = new Date(input);
6
7 // 获取年月日
8
9 var y = dt.getFullYear();
10
11 var m = (dt.getMonth() + 1).toString().padStart(2, '0');
12
13 var d = dt.getDate().toString().padStart(2, '0');
14
15
16
17 // 如果 传递进来的字符串类型,转为小写之后,等于 yyyy-mm-dd,那么就返回 年-月-日
18
19 // 否则,就返回 年-月-日 时:分:秒
20
21 if (pattern.toLowerCase() === 'yyyy-mm-dd') {
22
23 return `${y}-${m}-${d}`;
24
25 } else {
26
27 // 获取时分秒
28
29 var hh = dt.getHours().toString().padStart(2, '0');
30
31 var mm = dt.getMinutes().toString().padStart(2, '0');
32
33 var ss = dt.getSeconds().toString().padStart(2, '0');
34
35
36
37 return `${y}-${m}-${d} ${hh}:${mm}:${ss}`;
38
39 }
40
41 }
42
43 }
使用 ES6 中的字符串新方法
1String.prototype.padStart(maxLength, fillString='')
或用如下方式来填充:
1String.prototype.padEnd(maxLength, fillString='')
1.1.2. 全局过滤器
1// 定义一个全局过滤器
2
3Vue.filter('dataFormat', function (input, pattern = '') {
4
5 var dt = new Date(input);
6
7 // 获取年月日
8
9 var y = dt.getFullYear();
10
11 var m = (dt.getMonth() + 1).toString().padStart(2, '0');
12
13 var d = dt.getDate().toString().padStart(2, '0');
14
15
16
17 // 如果 传递进来的字符串类型,转为小写之后,等于 yyyy-mm-dd,那么就返回 年-月-日
18
19 // 否则,就返回 年-月-日 时:分:秒
20
21 if (pattern.toLowerCase() === 'yyyy-mm-dd') {
22
23 return `${y}-${m}-${d}`;
24
25 } else {
26
27 // 获取时分秒
28
29 var hh = dt.getHours().toString().padStart(2, '0');
30
31 var mm = dt.getMinutes().toString().padStart(2, '0');
32
33 var ss = dt.getSeconds().toString().padStart(2, '0');
34
35
36
37 return `${y}-${m}-${d} ${hh}:${mm}:${ss}`;
38
39 }
40
41});
注意:当有局部和全局两个名称相同的过滤器时候,会以就近原则进行调用,即:局部过滤器优先于全局过滤器被调用!
1.2. 键盘修饰符以及自定义键盘修饰符
1.2.1. 1.x中自定义键盘修饰符【了解即可】
1Vue.directive('on').keyCodes.f2 = 113;
1.2.2. 2.x中自定义键盘修饰符
通过
Vue.config.keyCodes.名称 = 按键值
来自定义案件修饰符的别名:
1Vue.config.keyCodes.f2 = 113;
使用自定义的按键修饰符:
1<input type="text" v-model="name" @keyup.f2="add">
1.3. 自定义指令
自定义全局和局部的 自定义指令:
1 // 自定义全局指令 v-focus,为绑定的元素自动获取焦点:
2
3 Vue.directive('focus', {
4
5 inserted: function (el) { // inserted 表示被绑定元素插入父节点时调用
6
7 el.focus();
8
9 }
10
11 });
12
13
14
15 // 自定义局部指令 v-color 和 v-font-weight,为绑定的元素设置指定的字体颜色 和 字体粗细:
16
17 directives: {
18
19 color: { // 为元素设置指定的字体颜色
20
21 bind(el, binding) {
22
23 el.style.color = binding.value;
24
25 }
26
27 },
28
29 'font-weight': function (el, binding2) { // 自定义指令的简写形式,等同于定义了 bind 和 update 两个钩子函数
30
31 el.style.fontWeight = binding2.value;
32
33 }
34
35 }
自定义指令的使用方式:
1<input type="text" v-model="searchName" v-focus v-color="'red'" v-font-weight="900">
1.4. Vue 1.x 中 自定义元素指令【已废弃,了解即可】
1Vue.elementDirective('red-color', {
2 bind: function () {
3 this.el.style.color = 'red';
4 }
5});
使用方式:
1<red-color>1232</red-color>
1.5. vue实例的生命周期
什么是生命周期:从Vue实例创建、运行、到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期!
生命周期钩子:就是生命周期事件的别名而已;
生命周期钩子 = 生命周期函数 = 生命周期事件
主要的生命周期函数分类:
创建期间的生命周期函数:
beforeCreate:实例刚在内存中被创建出来,此时,还没有初始化好 data 和 methods 属性
created:实例已经在内存中创建OK,此时 data 和 methods 已经创建OK,此时还没有开始 编译模板
beforeMount:此时已经完成了模板的编译,但是还没有挂载到页面中
mounted:此时,已经将编译好的模板,挂载到了页面指定的容器中显示
运行期间的生命周期函数:
beforeUpdate:状态更新之前执行此函数, 此时 data 中的状态值是最新的,但是界面上显示的 数据还是旧的,因为此时还没有开始重新渲染DOM节点
updated:实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!
销毁期间的生命周期函数:
beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。
destroyed:Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。
1.6. Vue中的动画
为什么要有动画:动画能够提高用户的体验,帮助用户更好的理解页面中的功能;
1.6.1. 使用过渡类名
HTML结构:
1<div id="app">
2 <input type="button" value="动起来" @click="myAnimate">
3 <!-- 使用 transition 将需要过渡的元素包裹起来 -->
4 <transition name="fade">
5 <div v-show="isshow">动画哦</div>
6 </transition>
7 </div>
VM 实例:
1// 创建 Vue 实例,得到 ViewModel
2var vm = new Vue({
3 el: '#app',
4 data: {
5 isshow: false
6 },
7 methods: {
8 myAnimate() {
9 this.isshow = !this.isshow;
10 }
11 }
12});
定义两组类样式:
1/* 定义进入和离开时候的过渡状态 */
2 .fade-enter-active,
3 .fade-leave-active {
4 transition: all 0.2s ease;
5 position: absolute;
6 }
7
8 /* 定义进入过渡的开始状态 和 离开过渡的结束状态 */
9 .fade-enter,
10 .fade-leave-to {
11 opacity: 0;
12 transform: translateX(100px);
13 }
1.6.2. 使用第三方 CSS 动画库
导入动画类库:
1<link rel="stylesheet" type="text/css" href="./lib/animate.css">
定义 transition 及属性:
1<transition
2 enter-active-class="fadeInRight"
3 leave-active-class="fadeOutRight"
4 :duration="{ enter: 500, leave: 800 }">
5 <div class="animated" v-show="isshow">动画哦</div>
6</transition>
1.6.3. 使用动画钩子函数
定义 transition 组件以及三个钩子函数:
1<div id="app">
2 <input type="button" value="切换动画" @click="isshow = !isshow">
3 <transition
4 @before-enter="beforeEnter"
5 @enter="enter"
6 @after-enter="afterEnter">
7 <div v-if="isshow" class="show">OK</div>
8 </transition>
9 </div>
定义三个 methods 钩子方法:
1methods: {
2 beforeEnter(el) { // 动画进入之前的回调
3 el.style.transform = 'translateX(500px)';
4 },
5 enter(el, done) { // 动画进入完成时候的回调
6 el.offsetWidth;
7 el.style.transform = 'translateX(0px)';
8 done();
9 },
10 afterEnter(el) { // 动画进入完成之后的回调
11 this.isshow = !this.isshow;
12 }
13 }
定义动画过渡时长和样式:
1.show{
2 transition: all 0.4s ease;
3 }
1.6.4. v-for 的列表过渡
定义过渡样式:
1<style>
2 .list-enter,
3 .list-leave-to {
4 opacity: 0;
5 transform: translateY(10px);
6 }
7
8 .list-enter-active,
9 .list-leave-active {
10 transition: all 0.3s ease;
11 }
12</style>
定义DOM结构,其中,需要使用 transition-group 组件把 v-for 循环的列表包裹起来:
1 <div id="app">
2 <input type="text" v-model="txt" @keyup.enter="add">
3
4 <transition-group tag="ul" name="list">
5 <li v-for="(item, i) in list" :key="i">{{item}}</li>
6 </transition-group>
7 </div>
定义 VM 中的结构:
1 // 创建 Vue 实例,得到 ViewModel
2 var vm = new Vue({
3 el: '#app',
4 data: {
5 txt: '',
6 list: [1, 2, 3, 4]
7 },
8 methods: {
9 add() {
10 this.list.push(this.txt);
11 this.txt = '';
12 }
13 }
14 });
1.6.5. 列表的排序过渡
<transition-group>
组件还有一个特殊之处。不仅可以进入和离开动画,还可以改变定位。要使用这个新功能只需了解新增的 v-move
特性,它会在元素的改变定位的过程中应用。
v-move
和v-leave-active
结合使用,能够让列表的过渡更加平缓柔和:
1.v-move{
2 transition: all 0.8s ease;
3}
4.v-leave-active{
5 position: absolute;
6}
不甘于「本该如此」,「多选参数 」值得关注