Vue.js也称为Vue,读音/vju:/,相似view,错误读音
v-u-e
css
MVVM
(Model-View-ViewModel)框架,和angular、react相似,其实就是所谓的数据双向绑定
vue2.0和1.0相比,最大的变化就是引入了Virtual DOM(虚拟DOM)
,页面更新效率更高,速度更快。html
参考:官网前端
共同点:都不兼容低版本IE
vue
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Hello World</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ //配置是否容许vue-devtools检查代码,方便调试,生产环境中须要设置为false,默认为true Vue.config.devtools=false; Vue.config.productionTip=false; //阻止vue启动时生成生产消息 var vm=new Vue({ el:'#itany', //指定关联的元素 data:{ //存储数据 msg:'Hello World' } }); } </script> </head> <body> <div id="itany"> {{msg}} <!-- 两对大括号{{}}称为模板,用来进行数据的绑定显示在页面中 --> </div> <h3> {{msg}} </h3> </body> </html>
vue-devtools下载地址react
直接将vue-devtools解压缩,而后将文件夹中的chrome拖放到扩展程序中 //配置是否容许vue-devtools检查代码,方便调试,生产环境中须要设置为false Vue.config.devtools=false; Vue.config.productionTip=false; //阻止vue启动时生成生产消息
用来扩展html标签的功能
。ios
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>经常使用指令:v-model</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ new Vue({ // el:'.itany', el:'div', //vue2.0中不容许将vue实例挂载到<html>或<body>元素,在vue1.0中是能够的 data:{ name:'', //即便没有值,也不能省略,报错 age:21, flag:true, nums:[12,4,23,5], user:{id:9527,name:'唐伯虎'} } }); } </script> </head> <body> <!-- <div id="itany"> --> <!-- <div class="itany"> --> <div> 用户名:<input type="text" v-model="name"> <br> {{name}} <br> {{age}} <br> {{flag}} <br> {{nums}} <br> {{user}} </div> </body> </html>
v-for
对数组或对象进行循环操做,使用的是v-for,不是v-repeat
注:在vue1.0中提供了隐式变量,如$index、$keygit
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>经常使用指令:v-for</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ new Vue({ el:'#itany', data:{ arr:[12,4,5,34,2,11], user:{id:9527,name:'唐伯虎',age:25}, arr2:[12,4,5,34,2,11,12], users:[ {id:9527,name:'唐伯虎',age:25}, {id:1001,name:'秋香',age:22}, {id:1002,name:'石榴姐',age:24} ] } }); } </script> </head> <body> <div id="itany"> <!-- {{arr}} --> <ul> <!-- 普通循环 --> <!-- <li v-for="value in arr">{{value}}</li> --> <!-- <li v-for="value in user">{{value}}</li> --> <!-- 键值循环 --> <!-- <li v-for="(v,k) in arr">{{k}}={{v}}</li> --> <!-- <li v-for="(v,k) in user">{{k}}={{v}}</li> --> <!-- 能够直接循环包含重复数据的集合,能够经过指定:key属性绑定惟一key,当更新元素时可重用元素,提升效率,相似于vue1.0中track-by --> <!-- <li v-for="(v,k) in arr2" :key="k">{{v}}</li> --> <li v-for="(user,index) in users"> {{index+1}},{{user.id}},{{user.name}},{{user.age}} </li> </ul> </div> </body> </html>
+ v-on 用来绑定事件,用法:v-on:事件="函数"
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>经常使用指令:v-on</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ let vm=new Vue({ el:'#itany', data:{ //存储数据 arr:[12,34,45,23,5] }, methods:{ //存储方法 show:function(){ console.log('show方法'); }, add(){ // console.log(this); //this表示当前vue实例 // console.log(this===vm); //true this.arr.push(666); //使用this访问当前实例中的成员 // this.show(); } } }); } </script> </head> <body> <div id="itany"> <!-- <button onclick="show()">点我</button> --> <button v-on:click="show">点我</button> <button v-on:click="add()">向数组中添加一个元素</button> <br> {{arr}} <hr> <button v-on:mouseover="show">鼠标通过</button> <button v-on:dblclick="show">鼠标双击</button> </div> </body> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>经常使用指令:v-show</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ let vm=new Vue({ el:'#itany', data:{ flag:true }, methods:{ change(){ this.flag=!this.flag; } } }); } </script> </head> <body> <div id="itany"> <!-- <button v-on:click="change">隐藏</button> --> <button v-on:click="flag=!flag">隐藏</button> <hr> <div style="width: 100px;height: 100px; background-color: red" v-if="flag">欢迎来到南京网博</div> </div> </body> </html>
v-on:click="" 简写方式 @click=""
$
eventconsole.log(e.target.innerHTML); //DOM对象 console.log(this); //当前Vue实例 包含事件相关信息,如事件源、事件类型、偏移量 target、type、offsetx
阻止事件冒泡: a)原生js方式:e.stopPropagation();依赖于事件对象 b)vue方式,不依赖于事件对象 @click.stop
阻止默认行为: a)原生js方式:e.preventDefault();依赖于事件对象 b)vue方式:@click.prevent
原生:console.log(e.keyCode); if(e.keyCode==13){ console.log('您按了回车'); } 回车:@keydown.13 或@keydown.enter 上:@keydown.38 或@keydown.up 默认没有@keydown.a/b/c...事件,能够自定义键盘事件,也称为自定义键码或自定义键位别名
.stop - 调用 event.stopPropagation()。 .prevent - 调用 event.preventDefault()。 .{keyCode | keyAlias} - 只当事件是从特定键触发时才触发回调。 .native - 监听组件根元素的原生事件。 .once - 只触发一次回调。
v-bind 用于属性绑定, v-bind:属性="" 属性的简写: v-bind:src="" 简写为 :src=""
绑定class和style属性时语法比较复杂:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>class和style属性</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> window.onload=function(){ let vm=new Vue({ el:'#itany', data:{ bb:'aa', dd:'cc', flag:true, num:-2, hello:{aa:true,cc:true}, xx:{color:'blue',fontSize:'30px'}, yy:{backgroundColor:'#ff7300'} } }); } </script> <style> .aa{ color:red; font-size:20px; } .cc{ background-color:#ccc; } </style> </head> <body> <div id="itany"> <!-- class属性 --> <!-- <p class="aa">南京网博</p> --> <!-- 能够访问,普通css方式 --> <!-- <p :class="aa">南京网博</p> --> <!-- 不能够,Vue的属性绑定时不能直接css样式 --> <!-- 方式1:变量形式 --> <!-- <p :class="bb">南京网博</p> --> <!-- 方式2:数组形式,同时引用多个 --> <!-- <p :class="[bb,dd]">南京网博</p> --> <!-- 方式3:json形式,经常使用!!! --> <!-- <p :class="{aa:true,cc:flag}">南京网博</p> --> <!-- <p :class="{aa:num>0}">南京网博</p> --> <!-- 方式4:变量引用json形式 --> <!-- <p :class="hello">南京网博</p> --> <!-- style属性 --> <p :style="[xx,yy]">itany</p> </div> </body> </html>
Vue.js使用基于HTML的模板语法,能够将DOM绑定到Vue实例中的数据 模板就是{{}},用来进行数据绑定,显示在页面中 也称为Mustache语法
a.双向绑定 v-model b.单向绑定 方式1:使用两对大括号{{}},可能会出现闪烁的问题,可使用v-cloak解决 /* 必须配置css样式,不然不生效 */ [v-cloak]{ //属性选择器 display:none; } <h3>aaa<span v-cloak>{{msg}}</span></h3> 方式2:使用v-text(等价 {{}},但不会出现闪烁问题 )、v-html
v-once 数据只绑定一次 v-pre 不编译,直接原样显示
用来过滤模型数据,在显示以前进行数据处理和筛选 语法:{{ data | filter1(参数) | filter2(参数)}}
vue1.0中内置许多过滤器,如: currency、uppercase、lowercase limitBy orderBy filterBy vue2.0中已经删除了全部内置过滤器,所有被废除 如何解决: a.使用第三方工具库,如lodash、date-fns日期格式化、accounting.js货币格式化等 b.使用自定义过滤器
分类:全局过滤器、局部过滤器
使用全局方法Vue.filter(过滤器ID,过滤器函数)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>自定义过滤器</title> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script> /** * 自定义全局过滤器 */ Vue.filter('addZero',function(data){ // console.log(data); return data<10?'0'+data:data; }); /*Vue.filter('number',(data,n) => { // console.log(data,n); return data.toFixed(n); });*/ Vue.filter('date',data => { let d=new Date(data); return d.getFullYear()+'-'+(d.getMonth()+1)+'-'+d.getDate()+' '+d.getHours()+':'+d.getMinutes()+':'+d.getSeconds(); }); window.onload=function(){ let vm=new Vue({ el:'#itany', data:{ currentTime:Date.now() }, filters:{ //局部过滤器 number:(data,n) => { return data.toFixed(n); } } }); } </script> </head> <body> <div id="itany"> <!-- <h3>{{3 | addZero}}</h3> --> <!-- 课后做业:本身实现toFiexed()四舍五入的功能 ,toFixed 不稳定--> <h3>{{12.345678 | number(2)}}</h3> <!-- <h3>{{12.045 | number(2)}}</h3> --> <h3>{{currentTime | date}}</h3> </div> </body> </html>
参考Vue教学视频:Vue.js 2.0之全家桶系列视频课程(vue、vue-router、axios、vuex)
笔记代码github
原文地址:https://segmentfault.com/a/1190000012934686vue-router