VUE 学习第一天

1. VUE

1.1. 课程介绍

前 5 天:都在学习 Vue 基本的语法和概念;打包工具 Webpack , Gulp
后 5 天:以项目驱动教学;

1.1.1. 什么是Vue.js

  • Vue.js 是目前最火的一个前端框架,React 是最流行的一个前端框架(React除了开发网站,还可以开发手机 App, Vue 语法也是可以用于进行手机 App开发的,需要借助于 Weex)

  • Vue.js 是前端的主流框架之一,和 Angular.js、React.js 一起,并成为前端三大主流框架!

  • Vue.js 是一套构建用户界面的框架,只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。(Vue 有配套的第三方类库,可以整合起来做大型项目的开发)

  • 前端的主要工作?主要负责 MVC 中的V这一层;主要工作就是和界面打交道,来制作前端页面效果;

1.2. 为什么要学习流行框架

  • 企业为了提高开发效率:在企业中,时间就是效率,效率就是金钱;

  • 企业中,使用框架,能够提高开发的效率;

  • 提高开发效率的发展历程:原生 JS -> Jquery 之类的类库 -> 前端模板引擎 -> Angular.js / Vue.js(能够帮助我们减少不必要的 DOM 操作;提高渲染效率;双向数据绑定的概念【通过框架提供的指令,我们前端程序员只需要关心数据的业务逻辑,不再关心 DOM 是如何渲染的了】)

  • 在 Vue 中,一个核心的概念,就是让用户不再操作 DOM 元素,解放了用户的双手,让程序员可以更多的时间去关注业务逻辑;

  • 增强自己就业时候的竞争力

  • 人无我有,人有我优

  • 你平时不忙的时候,都在干嘛?

1.3. 框架和库的区别

  • 框架:是一套完整的解决方案;对项目的侵入性较大,项目如果需要更换框架,则需要重新架构整个项目。

  • node 中的 express;

  • 库(插件):提供某一个小功能,对项目的侵入性较小,如果某个库无法完成某些需求,可以很容易切换到其它库实现需求。

  • 1. 从Jquery 切换到 Zepto

  • 2. 从 EJS 切换到 art-template

1.4. Node(后端)中的 MVC 与 前端中的 MVVM 之间的区别

  • MVC 是后端的分层开发概念;

  • MVVM 是前端视图层的概念,主要关注于 视图层分离,也就是说:MVVM 把前端的视图层,分为了 三部分 Model, View , VM ViewModel

  • 为什么有了 MVC 还要有 MVVM

1.5. Vue.js 基本代码 和 MVVM 之间的对应关系

1.6. Vue 之基本的代码结构和插值表达式、v-cloak

1.7. Vue 指令之 v-text 和 v-html

1.8. Vue 指令之 v-bind 的三种用法

  1. 直接使用指令v-bind

  2. 使用简化指令:

  3. 在绑定的时候,拼接绑定内容::title="btnTitle + ', 这是追加的内容'"

1.9. Vue 指令之 v-on 和跑马灯效果

1.9.1. 跑马灯效果

  1. HTML 结构:

1<div id="app">
2
3    <p>{{info}}</p>
4
5    <input type="button" value="开启" v-on:click="go">
6
7    <input type="button" value="停止" v-on:click="stop">
8
9  </div>
  1. Vue 实例:

 1    // 创建 Vue 实例,得到 ViewModel
 2
 3    var vm = new Vue({
 4
 5      el: '#app',
 6
 7      data: {
 8
 9        info: '猥琐发育,别浪~!',
10
11        intervalId: null
12
13      },
14
15      methods: {
16
17        go() {
18
19          // 如果当前有定时器在运行,则直接return
20
21          if (this.intervalId != null) {
22
23            return;
24
25          }
26
27          // 开始定时器
28
29          this.intervalId = setInterval(() => {
30
31            this.info = this.info.substring(1) + this.info.substring(0, 1);
32
33          }, 500);
34
35        },
36
37        stop() {
38
39          clearInterval(this.intervalId);
40
41        }
42
43      }
44
45    });

1.10. Vue 指令之 v-on 的缩写和事件修饰符

1.10.1. 事件修饰符:

  • .stop       阻止冒泡

  • .prevent    阻止默认事件

  • .capture    添加事件侦听器时使用事件捕获模式

  • .self       只当事件在该元素本身(比如不是子元素)触发时触发回调

  • .once       事件只触发一次

1.11. Vue 指令之 v-model 和双向数据绑定

1.12. 简易计算器案例

  1. HTML 代码结构

 1  <div id="app">
 2
 3    <input type="text" v-model="n1">
 4
 5    <select v-model="opt">
 6
 7      <option value="0">+</option>
 8
 9      <option value="1">-</option>
10
11      <option value="2">*</option>
12
13      <option value="3">÷</option>
14
15    </select>
16
17    <input type="text" v-model="n2">
18
19    <input type="button" value="=" v-on:click="getResult">
20
21    <input type="text" v-model="result">
22
23  </div>
  1. Vue 实例代码:

 1    // 创建 Vue 实例,得到 ViewModel
 2
 3    var vm = new Vue({
 4
 5      el: '#app',
 6
 7      data: {
 8
 9        n1: 0,
10
11        n2: 0,
12
13        result: 0,
14
15        opt: '0'
16
17      },
18
19      methods: {
20
21        getResult() {
22
23          switch (this.opt) {
24
25            case '0':
26
27              this.result = parseInt(this.n1) + parseInt(this.n2);
28
29              break;
30
31            case '1':
32
33              this.result = parseInt(this.n1) - parseInt(this.n2);
34
35              break;
36
37            case '2':
38
39              this.result = parseInt(this.n1) * parseInt(this.n2);
40
41              break;
42
43            case '3':
44
45              this.result = parseInt(this.n1) / parseInt(this.n2);
46
47              break;
48
49          }
50
51        }
52
53      }
54
55    });

1.13. 在 Vue 中使用样式

1.13.1. 使用 class 样式

  1. 数组

1<h1 :class="['red', 'thin']">这是一个邪恶的H1</h1>
  1. 数组中使用三元表达式

1<h1 :class="['red', 'thin', isactive?'active':'']">这是一个邪恶的H1</h1>
  1. 数组中嵌套对象

1<h1 :class="['red', 'thin', {'active': isactive}]">这是一个邪恶的H1</h1>
  1. 直接使用对象

1<h1 :class="{red:true, italic:true, active:true, thin:true}">这是一个邪恶的H1</h1>

1.13.2. 使用内联样式

  1. 直接在元素上通过 :style 的形式,书写样式对象

1<h1 :style="{color: 'red', 'font-size': '40px'}">这是一个善良的H1</h1>
  1. 将样式对象,定义到 data 中,并直接引用到 :style

  • 在 data 上定义样式:

1data: {
2        h1StyleObj: { color: 'red', 'font-size': '40px', 'font-weight': '200' }
3}
  • 在元素中,通过属性绑定的形式,将样式对象应用到元素中:

1<h1 :style="h1StyleObj">这是一个善良的H1</h1>
  1. :style 中通过数组,引用多个 data 上的样式对象

  • 在 data 上定义样式:

1data: {
2        h1StyleObj: { color: 'red', 'font-size': '40px', 'font-weight': '200' },
3        h1StyleObj2: { fontStyle: 'italic' }
4}
  • 在元素中,通过属性绑定的形式,将样式对象应用到元素中:

1<h1 :style="[h1StyleObj, h1StyleObj2]">这是一个善良的H1</h1>

1.14. Vue 指令之 v-for 和 key 属性

  1. 迭代数组

1<ul>
2  <li v-for="(item, i) in list">索引:{{i}} --- 姓名:{{item.name}} --- 年龄:{{item.age}}</li>
3</ul>
  1. 迭代对象中的属性

1    <!-- 循环遍历对象身上的属性 -->
2
3    <div v-for="(val, key, i) in userInfo">{{val}} --- {{key}} --- {{i}}</div>
  1. 迭代数字

1<p v-for="i in 10">这是第 {{i}} 个P标签</p>

2.2.0+ 的版本里,当在组件中使用 v-for 时,key 现在是必须的。

当 Vue.js 用 v-for 正在更新已渲染过的元素列表时,它默认用 “就地复用” 策略。如果数据项的顺序被改变,Vue将不是移动 DOM 元素来匹配数据项的顺序, 而是简单复用此处每个元素,并且确保它在特定索引下显示已被渲染过的每个元素。

为了给 Vue 一个提示,以便它能跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为每项提供一个唯一 key 属性。

1.15. Vue 指令之 v-if 和 v-show

一般来说,v-if 有更高的切换消耗而 v-show 有更高的初始渲染消耗。因此,如果需要频繁切换 v-show 较好,如果在运行时条件不大可能改变  v-if 较好。

1.16. 品牌管理案例

1.16.1. 添加新品牌

1.16.2. 删除品牌

1.16.3. 根据条件筛选品牌

  1. 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>
  1. 在 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.17. Vue 调试工具 vue-devtools 的安装步骤和使用

Vue.js devtools - 翻墙安装方式 - 推荐

1.18. 过滤器

概念:Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。过滤器可以用在两个地方:mustache 插值和 v-bind 表达式。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示;

1.18.1. 私有过滤器

  1. HTML 元素:

1<td>{{item.ctime | dataFormat('yyyy-mm-dd')}}</td>
  1. 私有 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中的字符串新方法 String.prototype.padStart(maxLength, fillString='') 或 String.prototype.padEnd(maxLength, fillString='')来填充字符串;

1.18.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.19. 键盘修饰符以及自定义键盘修饰符

1.19.1. 1.x中自定义键盘修饰符【了解即可】

1Vue.directive('on').keyCodes.f2 = 113;

1.19.2. 2.x中自定义键盘修饰符

  1. 通过Vue.config.keyCodes.名称 = 按键值来自定义案件修饰符的别名:

1Vue.config.keyCodes.f2 = 113;
  1. 使用自定义的按键修饰符:

1<input type="text" v-model="name" @keyup.f2="add">

1.20. 自定义指令

  1. 自定义全局和局部的 自定义指令:

 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. 自定义指令的使用方式:

1<input type="text" v-model="searchName" v-focus v-color="'red'" v-font-weight="900">

1.21. Vue 1.x 中 自定义元素指令【已废弃,了解即可】

1Vue.elementDirective('red-color', {
2  bind: function () {
3    this.el.style.color = 'red';
4  }
5});

使用方式:

1<red-color>1232</red-color>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值