Vue总结(一)
vue总结
构建用户界面的渐进式框架
渐进式:用到什么功能即可使用转么的框架子模块。
两个核心点
向应的数据绑定
当时图发生改变->自动跟新视图,利用Object.defindProperty中的setter/getter代理数据,监控对数据的操作。(IE8不兼容)
组合的视图组件
ui页面映射位组件树
划分组件可维护,可重用,可测试
虚拟DOM
利用在内存中生成与真实DOM与之对应的数据结构,这个在内存中生成的结构。
当数据发生变化时,能够只能低级选出重新渲染组建的最小代价并应用到DOM操作上。
MVVM模式
M: Model 数据模型
V: view 视图模板
vm: view-Model 视图模板
V:
<div id="demo">
<input type="text" v-model="message">
<p>{{message}}</p>
</div>
vm:
let data = {
message: "hello world!"
}
M:
var vm = new Vue({
el: "#demo",
data: data
})
Vue实例
每一个应用都是通过Vue这个构造函数创建根实例(root instance)启动newVue
需要传入选项对象,对象包含挂载元素,数据,模板,方法等。
el:挂载元素选择器
data:代理数据
methods:定义方法
vue代理data数据
每个Vue实例都会代理data对象里的所有的属性,这些被代理的属性是响应的。新添加的属性不具备响应功能,改变后不会跟新视图。
实例自身属性和方法
暴露自身的属性和方法,以$开头为例:$el,$data
var vm = new Vue({
el: "#demo",
data: obj,
methods: {
clickHandle() {
alert(0);
}
}
});
//vm是一个对象,其中里面的为内置成员和属性,以$开头
声明式渲染
声明式:
只需声明在哪里做什么,而无需关心如何让实现,调用一些方法,类库实现。
命令式
需要以剧吐代码表达在哪里做什么,如何让实现。需求让自己实现的过程细节。
vue申明式渲染
初始化根实例,vue自动将数据绑定在DOM模板上
<div id="demo">
<input type="text" v-model="message">
<p>{{message}}</p>
</div>
let data = {
message: "hello world!"
}
var vm = new Vue({
el: "#demo",
data: data,
methods: {
//...
}
})
指令
是一种特殊的自定义行间属性,他的职责是当其表达式的值改变时相应地将某些行为应用到DOM上,Vue中,指令以v-开头。
v-bind 动态的绑定数据,可简写为":"
v-on 绑定事件监听,简写为"@"
v-text 更新数据,会覆盖已有结构
v-html 可以解析数据中的html
v-show 根据值的真假,切换元素的display属性
v-if 根据值得真假会被销毁,重建
v-else-if 多条件判断,为真渲染
v-else 条件都不符合渲染
v-for 基于源数据多次渲染元素或模板
v-model 在表单控件元素上创建双向数据的绑定
v-pre 跳过元素和子元素的编译过程
v-once 只渲染一次,随后数据更新不重新渲染
v-cloak 隐藏未编译的Mustache语法,css中设置[v-cloak]{display:none }
html模板
模板:基于DOM的模板,模板都是可解析的有效的HTML
插值:
文本:使用Mustache语法(双打括弧){{value}}
作用:替换实例上的属性值,当值改变时,插值内容处会自动更新
原生的html:双打括弧输出的是文本,不会解析html
<div id="demo">
<div v-html="html"></div>
</div>
let obj = {
html:"<div>hello vue</div>"
}
var vm = new Vue({
el:"#demo",
data: obj
});
属性:使用v-bind进行绑定,可以响应变化
<div id="demo">
<div v-html="html" :costom="abc"></div>
</div>
let obj = {
html:"<div>hello vue</div>",
abc: 1
}
var vm = new Vue({
el:"#demo",
data: obj
});
使用JavaScript表达式:写简单的表达式
<div>{{true?"yes":"no"}}</div>
字符串模板
template选项对象属性
模板将会替换挂载元素的内容都将被忽略
<div id="demo">
<div v-html="html" :costom="abc"></div>
</div>
let obj = {
html:"<div>hello vue</div>",
abc: 1
}
var str = "<div>assassin{{abc}}</div>"//根节点只有一个,不能同级出现,嵌套是可以的
var vm = new Vue({
el:"#demo",
data: obj,
template: str
});
//上述视图将会被新模板替换掉
根节点只有一个,支持es6的超级模板
将HTML结构卸载一对script 标签中,设置type=“x-templete”。
//html
<script id="temp" type="x-templete">
<div>
{{abc}}
<span>assassin</span>
</div>
</script>
//js
let obj = {
html:"<div>hello vue</div>",
abc: 1
}
var vm = new Vue({
el:"#demo",
data: obj,
template: "#temp"//对应的挂载点
});
//有局限性,跨文件等有问题
模板-rander函数
自己创建模板
绑定自己的样式:
.rad{color: red;}
<div id="demo">
<span v-bind:class="{red:addClass}"></span>
</div>
let obj = {
addClass: false
};
var vm = new Vue({
el: "#demo",
data: obj
});
//会根据obj数据修改span中的class
render 选项对象属性
createElement(标签名,[数据对象],子元素);
.fl{float:left;}
.bgR{background: red;}
<div id="demo"></div>
let obj = {
html: "<div>hello vue.js</div>",
abc: 2
};
var vm = new Vue({
el: "demo",
data: obj,
render(createElement) {
return createElement(
"ul",{
class: {
bgr: true,
fl: true
},
style: {
font-size: "50"
},
attrs: {
abc: "assassin"
},
domProps: {//自身的一些属性
innnerHTML: "<li>html</li>"//会覆盖后面的标签
}
},[
createElement("li",1);
createElement("li",2);
createElement("li",3);
createElement("li",4);
]
)
}
});
列表渲染
v-for根据一组数组的选项列表进行渲染
语法:
value,key in items
value,key of items
变异方法:
vue提供一组方法,对数组进行操作的时候,会触发试图跟新,并不是原生的js方法。
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
事件处理器
v-on指令,用来监听DOM事件出发代码
语法:
v-on:eventName="eventHandle" 或者 @
事件处理函数写在methods中统一管理
时间对象:
在处理时间函数中获取
内联事件按处理函数执行,传入时间对象 $event
事件修饰符:
事件处理函数只有纯粹的逻辑判断,不处理DOM世间安得细节,如:阻止冒泡,取消默认行为,判断按键
修饰符的位置:
v-on:eventName.修饰符
修饰符:
.stop .prevent .capture .self .once
案件修饰符:
.enter .tab .delete .esc .space .up .down .left .right .ctrl .alt .shit .meta .键值
条件渲染
v-show指令
根据表达式的值,用来显示/隐藏元素
语法:v-show="表达式"
元素会被渲染在页面中,指针局的表达式的值进行css切换
动态class
动态绑定class
class也为元素的属性,可以使用v-bind:class
语法:
:class="{className:表达式}"
//表达式为true表示添加此className
//..
:class="[className1,className2]"
自定义指令
除了vue内置的指令,可以自己设置指令
选项对象的directives属性
{
directives:{}
}
钩子函数:
update被绑定元素所在的模板更新时调用
钩子函数中的参数:
el:指令所绑定的元素,可以用来直接操作DOM
binging:一个对象
binding对象下的value:指令的绑定值
directives: {
"focus": {//自定义指令
update(el,binding) {
if(binding.value) {
el.foucs();
}
}
}
}
<input v-foucs="edtorTodos === item" />
计算属性
模板是为了描述视图属性的结构,模板中放入太多逻辑,导致模板过重且难以维护。
在计算一个计算属性时,Vue.js更新它的依赖列表并缓存结果,中有当其中一个依赖发生了变化,缓存的结果才无效。
语法:
在选项对象中
{
...
computed: {}
}
深度监控watch
浅监控:
watch: {
list: function() {
//监控list这个属性,当这个属性发生变化就会执行函数,list对象下的属性不能监控。
}
}
深监控:
watch: {
list: {
handler: function() {
store.save("xxxx",this.list);
},
deep: true
}
}
Vue总结(一)的更多相关文章
- Vue.js 和 MVVM 小细节
MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 ViewModel 的双向数据绑定,这使得ViewModel 的状态改变可以自 ...
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
- wepack+sass+vue 入门教程(二)
六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...
- wepack+sass+vue 入门教程(一)
一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...
- Vue + Webpack + Vue-loader 系列教程(2)相关配置篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ 使用预处理器 在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用.vue- ...
- Vue + Webpack + Vue-loader 系列教程(1)功能介绍篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue ...
- 关于Vue.js 2.0 的 Vuex 2.0,你需要更新的知识库
应用结构 实际上,Vuex 在怎么组织你的代码结构上面没有任何限制,相反,它强制规定了一系列高级的原则: 应用级的状态集中放在 store 中. 改变状态的唯一方式是提交mutations,这是个同步 ...
- Vue.js 2.0 和 React、Augular等其他框架的全方位对比
引言 这个页面无疑是最难编写的,但也是非常重要的.或许你遇到了一些问题并且先前用其他的框架解决了.来这里的目的是看看Vue是否有更好的解决方案.那么你就来对了. 客观来说,作为核心团队成员,显然我们会 ...
- 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?
引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...
- 初探Vue
Vue.js(读音/vju:/,类似于view),是近来比较火的前端框架,但一直没有怎么具体了解.实现过,就知道个啥的MVVM啦,数据驱动啦,等这些关于Vue的虚概念. 由于最近,小生在公司中,负责开 ...
随机推荐
- centos6.5安装配置nginx+php+mysql+httpsqs+ttserver+redis
一.准备 1.nginx, http://nginx.org/download/nginx-1.5.12.tar.gz 2.pcre, ftp://ftp.csx.cam.ac.uk/pub/soft ...
- Linux shell 内部变量
1 TMOUT 来自bash的解释: If set to a value greater than zero, TMOUT is treated as the default timeout for ...
- Springmvc JSON交互
先上前端javascript.ajax代码 <pre name="code" class="javascript"> function testAj ...
- IP地址的规划和设计方法(二)
五,IP地址规划方法 (1)IP地址规划的基本步骤 网络地址规划须要按下面6步进行: a)推断用户对网络与主机数的需求: ...
- java9新特性-6-多版本兼容jar包
1.官方Feature 238: Multi-Release JAR Files 2.使用说明 当一个新版本的Java出现的时候,你的库用户要花费数年时间才会切换到这个新的版本.这就意味着库得去向后兼 ...
- Swift学习笔记(2):错误处理
目录: Error do-catch 断言 Error 在 Swift 中,错误用符合 Error 协议的类型的值来表示.这个空协议表明该类型可以用于错误处理异常. Swift 的枚举类型尤为适合构建 ...
- 使用ajax验证用户名重复
继上次的用户注册登录案例之后,对其中的部分功能再做进一步改进.上一版中用户提交表单后才对用户名进行校验,虽然做了回显,但还是感觉功能弱了些.为了能有更好用户体验,不是在用户提交表单后才给提示,而是在用 ...
- 洛谷1019 单词接龙 字符串dfs
问题描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合 ...
- CentOS7.3 下开放防火墙的端口
CentOS 7.3默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1:关闭firewall: systemctl stop firewalld.service system ...
- [HNOI2006]超级英雄(二分+网络流)
[HNOI2006]超级英雄 题目描述 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主持人的几个问题,然后根据回答问题的多少获得不同数目的奖品或奖金.主持人问题准备了若干道题目, ...