什么是Vue.js?
☛Vue.js是目前最火的一个前端框架。React是最流行的前端框架(都可以进行手机App的开发);
☛Vue.js是一套构建用户界面的框架,只关注视图层,易于上手;
☛Vue.js主要负责MVC中的V这一层,主要与界面打交道,来制作页面效果。
框架与库的区别
☛框架:是一套完整的解决方案,对项目的侵入性较大,项目如果需要更换框架,则需要重新架构整个项目。
☛库(插件):提供某一个小功能,对项目的侵入性较小。
Node(后端)中的MVC 与 前端中的MVVM之间的区别?
☛MVC——M-Model层: 处理数据的CRUD增加(Create)、读取查询(Retrieve)、更新(Update)和删除(Delete);
...................V:视图层,前端页面;
...................C:业务逻辑层,controller控制层:登录、注销等;
☛MVVM——是前端视图层的概念,分为Model,View,VM-ViewModel。
Vue.js基本代码和MVVM之间的对应关系
<body>
<!-- 将来new的Vue实例,会控制这个元素中的所有内容 -->
<!-- ******Vue实例所控制的元素区域,就是我们的V -->
<div id="app">
<p>{{msg}}</p>
</div>
<script>
// 2.创建一个Vue的实例
// 当我们导入包之后,在浏览器的内存中,就多了一个Vue构造函数
// ******注意:我们new出来的这个VM 对象,就是我们MVVM中VM 的调度者
var vm = new Vue({
el:'#app', //表示当前我们new的这个vue实例,要控制页面上的哪个区域
// *******这里的data就是MVVM中的 M ,专门保存每个页面的数据的
data:{ //data属性中,存放的是el中要用到的数据
msg:'欢迎学习Vue' //通过Vue提供的指令,很方便就能把数据渲染到页面上,程序员不再手动操作DOM元素了
}
})
</script>
</body>
v-cloak、v-text、v-html指令
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
[v-cloak]{
display: none;
}
</style>
</head>
<body>
<div id="app">
<!-- 使用 v-cloak 能够解决 插值表达式闪烁的问题,可以显示++++ -->
<p v-cloak>++++++{{msg}}+++++</p>
<!-- 1.默认 v-text 是没有闪烁问题的 -->
<!-- 2.v-text、v-html会覆盖元素中原本的内容,不会显示“******”和“12345678” -->
<h4 v-text="msg">************</h4>
<!-- 3.v-html可以把内容当做html来显示出来,其他方式会连带标签 -->
<div>{{msg2}}</div>
<div v-text="msg2"></div>
<div v-html="msg2">12345678</div>
</div>
<script src="vue.js"></script>
<script>
var vm = new Vue({
el:'#app',
data:{
msg:'yuyu',
msg2:'<h1>小鱼儿与花无缺<h1>'
}
})
</script>
</body>
</html>
v-bind指令
<body>
<div id="app">
<!-- v-bind:是Vue中提供的用于绑定属性的命令 -->
<input type="button" value="按钮" v-bind:title="mytitle+'123'">
<!-- 注意:v-bind: 指令可以被简写为 :要绑定的属性 -->
<!-- v-bind中 也可以写合法的JS表达式 -->
<input type="button" value="按钮" :title="mytitle+'123'">
</div>
<script src="lib/vue.js"></script>
<script>
var vm = new Vue({
el:'#app',
data:{
mytitle:'自己定义的title'
}
})
</script>
</body>
v-on指令
<body>
<div id="app">
<!-- Vue 中提供了v-on:事件绑定机制 -->
<input type="button" value="按钮" v-on:click="show">
</div>
<script src="lib/vue.js"></script>
<script>
var vm = new Vue({
el:'#app',
data:{
mytitle:'自己定义的title'
},
// 这个methods属性中定义了当前Vue实例中所有可用的方法
methods:{
show:function(){
alert('hello');
}
}
})
</script>
</body>
跑马灯效果
分析:
1、给【浪起来】按钮,绑定一个点击事件 v-on || 简写@
2、 在按钮的事件处理函数中,写相关的业务逻辑代码:拿到msg字符串,然后 调用 字符串的substring来进行字符串的截取操作,把第一个字符串取出来,放到最后一个位置即可;
3、为了实现点击一下按钮,自动截取的功能,需要把步骤2中的代码,放到一个定时器中。
<body>
<div id="app">
<input type="button" value="浪起来" @click="lang">
<input type="button" value="停止" @click="stop">
<h4>{{msg}}</h4>
</div>
<script>
// 注意:在VM实例中,如果想要获取data中的数据,或者想要调用methods中的方法,必须通过this.数据属性名 或 this.方法名
// 来进行访问,这里的this,就表示我们new出来的VM实例对象
var vm = new Vue({
el:'#app',
data:{
msg:'猥琐发育,别浪~~~',
intervalId:null //在data上定义 定时器ID
},
methods:{
lang(){
// 箭头函数能够使内部的this和外部的this永远保持一致,解决this指向的问题
if(this.intervalId != null) return;
this.intervalId = setInterval( () => {
// 获取到头的第一个字符
var start = this.msg.substring(0,1)
// 获取到后面的所有字符
var end = this.msg.substring(1)
// 重新拼接得到新的字符串,并赋值给this.msg
this.msg = end + start
},200)
// 注意:VM实例会监听自己身上data中所有数据的改变,只要数据一发生变化,就会自动把最新的数据,从data上同
// 步到页面中去;【不需要考虑如何重新渲染DOM页面】
},
// 终止定时器
stop(){
clearInterval(this.intervalId);
this.intervalId = null;
}
}
})
</script>
</body>
事件修饰符
<body>
<div id="app">
<!-- 使用.stop阻止向上冒泡 -->
<div class="inner" @click="yuyu">
<input type="button" value="我爱你" @click.stop="leilei">
</div>
<!-- 使用.prevent阻止默认事件 -->
<a href="http://www.baidu.com" @click.prevent="love">有问题找百度</a>
<!-- 使用.captrue实现捕获触发事件的机制 -->
<div class="inner" @click.capture="yuyu">
<input type="button" value="我爱你" @click="leilei">
</div>
<!-- 使用.self实现只有点击当前元素才会触发事件处理函数 -->
<div class="inner" @click.self="yuyu">
<input type="button" value="我爱你" @click="leilei">
</div>
<!-- 使用.once只触发一次事件处理函数 -->
<a href="http://www.baidu.com" @click.prevent.once="love">有问题找百度</a>
<!-- .stop 和 .self的区别 -->
<div class="yulei" @click="yulei">
<div class="inner" @click="yuyu">
<input type="button" value="我爱你" @click.stop="leilei">
</div>
</div>
<!-- .self只会阻止自己身上冒泡行为的触发,并不会真正阻止冒泡行为 -->
<div class="yulei" @click="yulei">
<div class="inner" @click.self="yuyu">
<input type="button" value="我爱你" @click="leilei">
</div>
</div>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{},
methods:{
yuyu(){
alert('鱼鱼');
},
leilei(){
alert('磊磊')
},
love(){
alert('I Love You')
},
yulei(){
alert('鱼鱼love磊磊')
}
}
})
</script>
</body>
v-model双向数据绑定
<body>
<div id="app">
<h4>{{msg}}</h4>
<!-- 使用v-model可以实现表单元素和Model中数据的双向绑定 -->
<!-- 注意:v-model只能运用在表单元素中 -->
<!-- input(radio,text,address,email..)select checkbox textarea -->
<input type="text" v-model="msg" style="width: 100%">
<!-- v-bind只能实现数据的单向绑定,从M自动绑定到V -->
<!-- <input type="text" v-bind:value="msg" style="width: 100%"> -->
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
msg:'v-model数据双向绑定'
}
})
</script>
</body>
v-model简易计算器demo
<body>
<div id="app">
<input type="text" v-model="n1">
<select v-model="opt">
<option value="+">+</option>
<option value="-">-</option>
<option value="*">*</option>
<option value="/">/</option>
</select>
<input type="text" v-model="n2">
<input type="button" value="=" @click="count">
<input type="text" v-model="result">
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
n1:0,
n2:0,
opt:'+',
result:0
},
methods:{
count(){
// 逻辑:
switch(this.opt){
case '+':
this.result = parseInt(this.n1)+parseInt(this.n2)
break;
case '-':
this.result = parseInt(this.n1)-parseInt(this.n2)
break;
case '*':
this.result = parseInt(this.n1)*parseInt(this.n2)
break;
case '/':
this.result = parseInt(this.n1)/parseInt(this.n2)
break;
}
// 注意:这是投机取巧的方法,正式开发中,尽量少用
var sum = 'parseInt(this.n1)'+this.opt+'parseInt(this.n2)'
this.result = eval(sum);
}
}
})
</script>
</body>
Vue中的class样式
<style>
.red{
color: red;
}
.thin{
font-weight: 200;
}
.italic{
font-style: italic;
}
.active{
letter-spacing: 0.5em;
}
</style>
<body>
<div id="app">
<!-- 第一种方式,直接传递一个数组,注意:这里的class需要使用v-bind做数据绑定 -->
<h2 :class="['red','thin','italic']">小鱼儿与花无缺</h2>
<!-- 在数组中使用三元表达式 -->
<h2 :class="['red','thin','italic',flag?'active':'']">小鱼儿与花无缺</h2>
<!-- 在数组中使用 对象来代替三元表达式,提高代码可读性 -->
<h2 :class="['red','thin','italic',{'active':flag}]">小鱼儿与花无缺</h2>
<!-- 在为class使用 v-bind 绑定对象的时候,对象的属性是类名,由于 对象的属性可带引号,也可不带引号,所以 这里我没写引号;属性值是一个标识符 -->
<h2 :class="classObj">小鱼儿与花无缺</h2>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
flag:true,
classObj:{red:true,thin:true,italic:false,active:true}
},
})
</script>
</body>
Vue中的内联样式
<body>
<div id="app">
<!-- 对象就是无序键值对的集合 -->
<!-- <h1 :style="{color:'red','font-weight':'200'}">这是一个h1</h1> -->
<h1 :style="styleObj1">这是一个h1</h1>
<h1 :style="[styleObj1,styleObj2]">这是一个h1</h1>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
styleObj1:{color:'red','font-weight':'200'},
styleObj2:{'font-style':'italic'}
}
})
</script>
</body>
Vue指令值v-for 和 key属性
<body>
<div id="app">
<!-- v-for循环普通数组 -->
<p v-for="(item,index) in list">索引值{{index}}---对应值{{item}}</p>
<!-- v-for循环对象数组 -->
<p v-for="(item,index1) in list1">ID:{{item.id}}---名字:{{item.name}}</p>
<!-- v-for循环对象 -->
<p v-for="(item,key,index2) in list2">信息:{{item}}---键值:{{item.name}}---索引:{{index2}}</p>
<!-- 如果使用v-for迭代数字的话,前面的count值从1开始 -->
<p v-for="count in 10">这是第{{count}}次循环</p>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
list:[1,2,3,4,5,6],
list1:[
{id:1,name:'yuyu1'},
{id:2,name:'yuyu2'},
{id:3,name:'yuyu3'},
{id:4,name:'yuyu4'},
],
list2:{
id:1,
name:'yuer',
sex:'女'
}
}
})
</script>
</body>
Vue指令值v-for 和 key属性 的 使用
<body>
<div id="app">
<label>
ID:<input type="text" v-model="id">
</label>
<label>
Name:<input type="text" v-model="name">
</label>
<input type="button" value="添加" @click="add">
<!-- 循环的时候,key属性只能使用number获取string -->
<!-- key在使用的时候,必须使用v-bind属性绑定的形式,指定key的值 -->
<!-- 在组件中使用v-for循环的时候,或者在一些特殊的情况中,如果v-for有问题,必须在使用v-for的同时,指定唯一的 字符串/数字 类型 :key值 -->
<p v-for="item in user" :key="item.id">
<input type="checkbox">
{{item.name}}
</p>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
id:'',
name:'',
user:[
{id:1,name:'yuyu1'},
{id:2,name:'yuyu2'},
{id:3,name:'yuyu3'},
{id:4,name:'yuyu4'},
]
},
methods:{
add(){
this.user.unshift({id:this.id,name:this.name})
}
}
})
</script>
</body>
v-if 和 v-show 的使用
<body>
<div id="app">
<input type="button" value="toggle" @click="flag=!flag">
<!-- v-if:每次都会重新删除或创建元素 -->
<h3 v-if="flag">这是用v-if控制的元素</h3>
<!-- v-show:只是切换了元素的display:none 样式 -->
<h3 v-show="flag">这是用v-show控制的元素</h3>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
flag:true
},
})
</script>
</body>