1. 什么是Vue
Vue.js 是目前最火的一个前端框架,React是最流行的一个前端框架(React除了开发网站,还可以开发手机App, Vue语法也是可以用于进行手机App开发的,需要借助于Weex)
Vue.js 是前端的主流框架之一,和Angular.js、React.js 一起,并成为前端三大主流框架!
Vue.js 是一套构建用户界面的框架,只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。(Vue有配套的第三方类库,可以整合起来做大型项目的开发)
前端的主要工作?主要负责MVC中的V这一层;主要工作就是和界面打交道,来制作前端页面效果;
2. 为什么要学习流行框架
企业为了提高开发效率:在企业中,时间就是效率,效率就是金钱;
- 企业中,使用框架,能够提高开发的效率;
提高开发效率的发展历程:原生JS -> Jquery之类的类库 -> 前端模板引擎 -> Angular.js / Vue.js(能够帮助我们减少不必要的DOM操作;提高渲染效率;双向数据绑定的概念【通过框架提供的指令,我们前端程序员只需要关心数据的业务逻辑,不再关心DOM是如何渲染的了】)
在Vue中,一个核心的概念,就是让用户不再操作DOM元素,解放了用户的双手,让程序员可以更多的时间去关注业务逻辑;
增强自己就业时候的竞争力
- 人无我有,人有我优
- 你平时不忙的时候,都在干嘛?
3. 框架和库的区别
框架:是一套完整的解决方案;对项目的侵入性较大,项目如果需要更换框架,则需要重新架构整个项目。
- node 中的 express;
库(插件):提供某一个小功能,对项目的侵入性较小,如果某个库无法完成某些需求,可以很容易切换到其它库实现需求。
- 从Jquery 切换到 Zepto;
- 从 EJS 切换到 art-template
4. MVC和MVVM的关系图解
- MVC 是后端的分层开发概念;
- MVVM是前端视图层的概念,主要关注于 视图层分离,也就是说:MVVM把前端的视图层,分为了 三部分 Model, View , VM ViewModel
5. Vue基本代码 和 MVVM 之间的对应关系
1 |
|
el 指定要控制的区域
data 是个对象,指定了控制的区域内要用到的数据
methods 虽然带个s后缀,但是是个对象,这里可以自定义了方法
在 VM 实例中,如果要访问 data 上的数据,或者要访问 methods 中的方法, 必须带 this
1 | <script> |
6. Vue指令
6.1 插值表达式{ {} }
1 | <div>{ {msg2} }</div> |
6.2 v-cloak
使用 v-cloak 能够解决插值表达式闪烁的问题
1 | <style> |
6.3 v-text
默认 v-text 是没有闪烁问题的
v-text会覆盖元素中原本的内容,但是插值表达式只会替换自己的这个占位符,不会把整个元素的内容清空
1 | <div v-text="msg"></div> |
6.4 v-html
执行js表达式
1 | <div v-html="msg2">1212112</div> |
6.5 v-bind
v-bind是 Vue中,提供的用于绑定属性的指令,v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定
1 | <input type="button" value="按钮" v-bind:title="mytitle"> |
注意: v-bind: 指令可以被简写为 :要绑定的属性,v-bind 中,可以写合法的JS表达式
1 | <input type="button" value="按钮" :title="mytitle + '123'"> |
6.6 v-on
Vue 中提供了 v-on: 事件绑定机制
1 | <input type="button" value="按钮" :title="mytitle + '123'" v-on:click="alert('hello')"> |
v-on: 指令可以被简写为 @
1 | <input type="button" value="按钮" :title="mytitle + '123'" @click="alert('hello')"> |
6.7 事件修饰符
1 | <script> |
6.7.1 .stop
阻止冒泡
1 | <div class="inner" @click="div1Handler"> |
6.7.2 .prevent
阻止默认事件
1 | <a href="http://www.baidu.com" @click.prevent="linkClick">有问题,先去百度</a> |
6.7.3 .capture
添加事件侦听器时使用事件捕获模式
1 | <div class="inner" @click.capture="div1Handler"> |
6.7.4 .self
只当事件在该元素本身(比如不是子元素)触发时触发回调
1 | <div class="inner" @click.self="div1Handler"> |
6.7.5 .once
事件只触发一次
1 | <a href="http://www.baidu.com" @click.prevent.once="linkClick">有问题,先去百度</a> |
6.8 v-mode
使用 v-model 指令,可以实现表单元素和 Model 中数据的双向数据绑定
注意: v-model 只能运用在表单元素中
1 |
|
6.9 vue中样式v-bind:class
1、数组
1 | <h1 :class="['red', 'thin']">这是一个邪恶的H1</h1> |
2、数组中使用三元表达式
1 | <h1 :class="['red', 'thin', isactive?'active':'']">这是一个邪恶的H1</h1> |
3、数组中嵌套对象
1 | <h1 :class="['red', 'thin', {'active': isactive}]">这是一个邪恶的H1</h1> |
4、直接使用对象
1 | <h1 :class="{red:true, italic:true, active:true, thin:true}">这是一个邪恶的H1</h1> |
6.10 vue中样式v-bind:style
1、直接在元素上通过 :style
的形式,书写样式对象
1 | <h1 :style="{color: 'red', 'font-size': '40px'}">这是一个善良的H1</h1> |
2、将样式对象,定义到 data
中,并直接引用到 :style
中
- 在data上定义样式:
1 | data: { |
- 在元素中,通过属性绑定的形式,将样式对象应用到元素中:
1 | <h1 :style="h1StyleObj">这是一个善良的H1</h1> |
3、在 :style
中通过数组,引用多个 data
上的样式对象
- 在data上定义样式:
1 | data: { |
- 在元素中,通过属性绑定的形式,将样式对象应用到元素中:
1 | <h1 :style="[h1StyleObj, h1StyleObj2]">这是一个善良的H1</h1> |
6.11 v-for
6.11.1 v-for循环普通数组
1 | <div id="app"> |
6.11.2 v-for循环对象数组
1 | <div id="app"> |
6.11.3 v-for循环对象
1 | <div id="app"> |
6.11.4 v-for迭代数字
1 | <div id="app"> |
6.11.5 v-for循环中key属性的使用
1 | <!-- 在组件中,使用v-for循环的时候,或者在一些特殊情况中,如果 v-for 有问题,必须在使用 v-for 的同时,指定唯一的字符串/数字类型 :key 值 --> |
2.2.0+ 的版本里,当在组件中使用 v-for 时,key 现在是必须的。
6.12 v-if/v-show
1 | <div id="app"> |
7. 品牌管理案例-根据条件筛选品牌
在Vue中,使用事件绑定机制,为元素指定处理函数的时候,如果加了小括号,就可以给函数传参了
1 | <div id="app"> |
8. Vue调试工具vue-devtools
9. 过滤器
概念:Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化。过滤器可以用在两个地方:mustache 插值和 v-bind 表达式。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示;
过滤器的定义语法
1 | Vue.filter('过滤器名称', function () {}) |
9.1 全局的过滤器
所谓的全局过滤器,就是所有的VM实例都共享的
1 | Vue.filter('dateFormat', function (dateStr, pattern = "") { |
9.2 私有的过滤器
只能在当前 VM 对象所控制的 View 区域进行使用
1 | // 如何自定义一个私有的过滤器(局部) |
9.3 调用过滤器
过滤器调用时候的格式 { { name | 过滤器的名称 } }
1 | <td>{ {item.ctime | dataFormat('yyyy-mm-dd')} }</td> |
多个过滤器共同调用
1 | <div id="app"> |
9.4 内置过滤器
9.4.1 capitalize
首字母大写
9.4.2 uppercase
全部大写
9.4.3 lowercase
全部小写
9.4.4 currency
输出金钱以及小数点
参数:
第一个参数 {String} [货币符号] - 默认值: ‘$’
第二个参数 {Number} [小数位] - 默认值: 2
10. 键盘修饰符
10.1 默认键盘修饰符
为文本框回车键绑定事件
1 | <label> |
10.2 使用自定义的按键修饰符
通过Vue.config.keyCodes.名称 = 按键值
来自定义案件修饰符的别名
1 | // 自定义全局按键修饰符 |
11. 自定义指令
11.1 定义全局的指令
使用 Vue.directive() 定义全局的指令 v-focus
其中:
参数1 : 指令的名称,注意,在定义的时候,指令的名称前面,不需要加 v- 前缀, 但是: 在调用的时候,必须在指令名称前 加上 v- 前缀来进行调用
参数2: 是一个对象,这个对象身上,有一些指令相关的函数,这些函数可以在特定的阶段,执行相关的操作
1 | Vue.directive('focus', { |
1 | <label> |
11.2 自定义私有指令
1 | var vm2 = new Vue({ |
1 | <div id="app2"> |
-------------本文结束感谢您的阅读-------------
本文标题: Vue(一)
本文链接: https://wgy1993.gitee.io/archives/ad25968.html
版权声明: 本作品采用 CC BY-NC-SA 4.0 进行许可。转载请注明出处!
