vue的相关知识
一、DOM vs 函数库 vs框架
DOM: API繁琐
函数库:JQuery对DOM的每个步骤的API进行一对一的简化,但并没有改变DOM做事的步骤和方法。
框架:一个包含部分已经实现的功能的半成品项目,只是暂时缺少数据和个性化页面。
优点:彻底简化了开发的步骤,且彻底避免了大量重复的劳动。
缺点:需要转变观念。
二、什么是Vue
Vue是基于MVVM设计模式开发的渐进式的前端js框架
渐进式:可以有选择的,逐渐使用框架中的功能
vs "全家桶":必须完整使用所有功能,不能掺杂其他技术
前端JS:Vue是纯前端的框架,无需node.js,就可以独立运行。但是,需要node.js在运行之前将vue
编译为浏览器认识的普通的HTML、CSS、和JS文件
何时:适合于以数据操作为主的项目。
三、如何使用Vue:
官网:https://cn.vuejs.org/
2种:
1.下载并引入vue.js文件
最新版本:2.5.x
开发版本:未压缩,带错误提示
生产版本:压缩,去掉错误提示
2.安装脚手架工具
四、Vue的原理:
旧式前端划分:
HTML:定义网页静态内容
CSS:定义网页静态样式
JS: 为网页添加动态行为
MVVM设计模式:
新的前端划分:
1.将一个.html文件,拆分为多个组件文件:.vue/.component
2.每个组件又细分为3部分:
1.界面(View):HTML和CSS
2.数据模型(Model):在内存中自己创建的或从服务器端请求来的保存页面
需要的所有数据的对象或数组:Ajax中的res
3.控制器(ViewModel/controller):自动将数据模型中的数据绑定/同步到页面需要的位置-----不再需要程序员
反复手工查找并修改元素。
控制器的原理:2大子系统:
1.响应系统:监视模型数据的变化,并通知框架修改页面的机制。
其实是将数据模型中每个属性变为一个访问属性
每次修改模型中的数据时,都会自动触发set
set会发出通知:“xx变量发生改变”
2.虚拟DOM树:扫描原始DOM而产生的一棵仅包含可能变化的元素的新的简版DOM树
优点:
1.仅包含可能变化的元素的个别属性----简单---遍历快
2.修改时,可仅找到发生变化的元素仅修改发生变化的元素-----效率高
vue对象创建时,首次扫描并创建虚拟DOM树
响应系统发出通知时:虚拟DOM树收到通知,并查找要修改的个别元素,实际修改DOM树。
五、绑定语法
什么是:在页面中使用特殊符号{{}}指定所需的变量名
学名:interpolation 插值语法
何时:只要页面的某个位置需要动态生成值时
如何:
{{模型变量名}}
{{表达式}}
表达式包括:算术计算,关系计算/逻辑运算,方法调用,访问数组元素,访问对象的属性,三目运算符
强调:不能写程序结构
if else if else
for while do while
六、指令(directive)
什么是:为HTML提供新功能的特殊属性
为什么:{{}}只能绑定元素的内容(innerHTML),不能绑定属性/事件或执行结构
何时:不能使用{{}}绑定的位置,又想动态生成值,都要用各种指令来增强
如何:
1.v-bind:专门用于动态绑定属性值
何时:只要一个属性的值需要动态生成时
如何:完整:<ANY v-bind:属性=“表达式”>
可省略v-bind
2.v-for:专门根据一个数组中的元素,动态反复生成多段相同的页面内容
何时:只要根据一个数组中的元素,动态绑定页面内容时
如何:<ANY v-for="模型变量 of 数组类型模型变量">
根据of后数组中的元素个数,反复生成多个<ANY>元素
of 前的模型变量时临时决定的,获得数组中的一个当前元素
of 前的模型变量在,<ANY>内部可用于绑定
3.控制元素的显示隐藏:
v-if:专门根据一个条件表达式来决定当前元素是否显示
只有条件表达式为true时,当前元素才显示。
何时:只要根据一个条件控制元素的显示隐藏时
如何:
<ANY v-if="条件表达式 1"
<ANY v-else-if="条件表达式 2"
<ANY v-else-if="......"
<ANY v-else //不同写条件
强调:v-if和v-else-if和v-else之间不能插入其他元素
v-show:专门根据一个条件表达式来决定当前元素是否显示
只有条件表达式为true时,当前元素才显示
采用display:block/none的方式显示隐藏
何时:如果仅控制一个元素的显示隐藏时,首选v-show
vs v-if:采用添加删除元素的方式,控制显示隐藏
何时:多个元素选其一显示时,首选v-if v-else-if v-else
七、绑定事件
界面View中:
<ANY v-on:事件名=“处理函数()”>
简写:v-on:可替换为@
new Vue({})中:
new Vue({
el:"选择器",
data:{模型变量},
methods:{//专门保存控制器所需所有自定义方法的属性
处理函数(){//处理函数:function(){
//this->当前Vue对象->vm
this.模型变量 //访问模型变量
}}
}
})
问题1:阻止默认行为
解决:2步:
1.界面:当事件发生时,自动调用js语句,并传入$event作为参数
<ANY @click="处理函数($event)">
$event就是DOM中的e,是vue封装的事件对象
2.new Vue()中:
methods:{
//定义形参,准备接事件对象
处理函数(e){
e.preventDefault();
}
}
简写:事件修饰符,对DOM中事件API的简写:
2个:
阻止默认行为:@click.prevent="处理函数()"
取消冒泡:@click.stop="处理函数()'=>e.stopPropagaton()
vue的相关知识的更多相关文章
- Vue.js相关知识4-路由
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Vue.js相关知识3-路由
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Vue.js相关知识2-组件
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Vue.js相关知识1
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Vue.js 相关知识(脚手架)
1. vue-cli 简介 Vue-cli 是 vue的设计者,为提升开发效率而提供的一个脚手架工具,可通过vue-cli快速构造项目结构 2. vue-cli 安装步骤 安装npm 或 cnpm n ...
- Vue.js 相关知识(路由)
1. 简介 路由,工作原理与路由器相似(路由器将网线总线的IP分发到每一台设备上),Vue中的路由根据用户在网页中的点击,将其引导到对应的页面. 2. 使用步骤 安装vue-router或者直接引入v ...
- Vue.js 相关知识(动画)
1. 简介 Vue 在插入.更新或移除 DOM 时,提供多种不同方式的过渡效果,并提供 transition 组件来实现动画效果(用 transition 组件将需执行过渡效果的元素包裹) 语法:&l ...
- Vue.js 相关知识(组件)
1. 组件介绍 组件(component),vue.js最强大的功能之一 作用:封装可重用的代码,通常一个组件就是一个功能体,便于在多个地方都能调用该功能体 根组件:我们实例化的Vue对象就是一个组件 ...
- Vue.js 相关知识(基础)
1. Vue.js 介绍 Vue,读音 /vjuː/,类似于 view),是一套用于构建用户界面的渐进式框架(重点在于视图层). 作者:尤雨溪 注:学习 vue.js 时,一定要抛弃 jQuery 的 ...
随机推荐
- [WPF自定义控件库] 模仿UWP的ProgressRing
1. 为什么需要ProgressRing 虽然我认为这个控件库的控件需要模仿Aero2的外观,但总有例外,其中一个就是ProgressRing.ProgressRing是来自UWP的控件,部分代码参考 ...
- STM32SPI连续读写多个字节会产生时间间隔
最近在做一个音频芯片的项目用到SPI接口配置寄存器,发现只要连续两次向从机发送(接收)帧,当STM32处于主机模式时,这两帧数据中间会产生一个时钟的间隙. 起初我想能不能利用状态标志来去除间隙,后来怎 ...
- CTF-SMB渗透
环境 Kali ip 192.168.56.102 Smb 靶机ip 192.168.56.103 靶场下载: 链接:https://pan.baidu.com/s/1OwNjBf7ZEGmFlRq ...
- PMBOK(第六版) PMP笔记——《十》第十章(项目沟通管理)
PMBOK(第六版) PMP笔记——<十>第十章(项目沟通管理) 第十章 项目沟通管理: PM 大多数时间都用在与干系人的沟通上. 第十章有三个过程: 规划沟通管理:根据干系人的需求,制定 ...
- 《锋利的jQuery》学习总结
通过对<锋利的jQuery>(第二版)一书的学习,发现此书讲解通俗易懂,是学习jQuery的一本很好的指导书,特作如下总结.此书主要讲解了jQuery的常用操作,包括认识jQuery,jQ ...
- sqlserver 查看最耗时的前10个存储过程
SELECT TOP OBJECT_NAME(a.object_id,database_id) SP_Name, DB_NAME(a.database_id) Database_Name, a.cac ...
- 简单,常用,基础的css滤镜效果!
第一次写博客,有些紧张.如写的不好,尽请谅解! 2019-10-28 09:33:48 第一:透明度滤镜 该滤镜的效果其实跟调整透明度差不多.它总共有7个参数!语法如下!(摈弃那些花里胡哨,我们只 ...
- ESP8266开发之旅 基础篇④ ESP8266与EEPROM
授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...
- 用最简单的方式学Python单链表
Python 实现单链表 在本博客中,我们介绍单链表这种数据结构,链表结构为基于数组的序列提供了另一种选择(例如Python列表). 基于数组的序列和链表都能够对其中的元素保持一定得顺序,但采用的方式 ...
- 什么是Kafka?
1 kafka 是什么 Apache kafka is a distributed streaming platform,即官方定义 kafka 是一个分布式流式计算平台.而在大部分企业开发人员中,都 ...