六十四、vue基础
事件触发语法:v-on:事件名='函数名’可以简写成@事件名=‘函数名’函数传参:函数需要一个参数,但是没有传参数传少了需要两个参数,第一个是事件对象,第二个是字符串属性指令语法:v-bind:‘属性名’=’变量名‘,可以简写成:属性名=‘变量名’三 style和class四 条件渲染需求:输入成绩,回车后显示分数对应的等级。五 列表渲染模拟购物车展示小实例六 双向数据绑定适用于input标签,在
vue基础
一 插值语法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app01">
字符串渲染:{{name}}
<br>
整型渲染:{{age}}
<br>
数组渲染:{{arry}}
<br>
对象渲染:{{object}}
<br>
标签渲染:{{label1}}
<br>
运算:{{10+9+8}}
<br>
三木运算符:{{10>9?'是':'否'}}
</div>
</body>
<script>
var vm = new Vue({
el: '#app01',
data: {
name: 'jasper',
age: 18,
arry: ['lili', 'xxx', 29],
object: {name: 'jasper'},
label1: '<a href="https://www.baidu.com">百度</a>'
}
})
</script>
</html>
二 指令
2.1 文本指令
- v-text:把变量渲染到标签上,如果之前标签有数据就覆盖
- v-html:如果变量是标签字符串,就将标签字符串渲染到标签中
- v-show:控制标签是否展示,将display属性设为none
- v-if:控制标签是否展示,通过dom操作删除或增加
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app01">
<p v-text="name"></p>
<p v-html="label"></p>
<p v-show="isShow">v-show</p>
<p v-if="isIf">v-if</p>
</div>
</body>
<script>
var vm = new Vue({
el: '#app01',
data: {
name: 'jasper',
label: '<a href="https://www.baidu.com">百度</a>',
isShow:false,
isIf:false,
}
})
</script>
</html>
2.2 事件指令
事件触发语法:v-on:事件名='函数名’可以简写成@事件名=‘函数名’
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app01">
<button @click="clickEvent">点我隐藏或展示</button>
<div>
<img v-if="isShow"
src="https://img2.baidu.com/it/u=225235858,3671777433&fm=253&fmt=auto&app=138&f=JPEG?w=400&h=400" alt=""
width="300px" height="300px">
</div>
</div>
</body>
<script>
var vm = new Vue({
el: '#app01',
data: {
isShow: true
},
methods: {
// 单击按钮 触发事件执行 将当前vm对象的isShow属性取反
clickEvent() {
this.isShow = !this.isShow
}
}
})
</script>
</html>
函数传参:
-
函数需要一个参数,但是没有传
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="vue.js"></script> </head> <body> <div id="app01"> <button @click="clickEvent1">函数需要一个参数,但是没有传</button> </div> </body> <script> var vm = new Vue({ el: '#app01', data: { }, methods: { // 会自动将点击事件对象传入 clickEvent1(x){ console.log(x) } } }) </script> </html>
-
参数传少了
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="vue.js"></script> </head> <body> <div id="app01"> <button @click="clickEvent2('jasper')">函数需要三个参数,但是就传了一个</button> </div> </body> <script> var vm = new Vue({ el: '#app01', data: { }, methods: { // 按照位置接受 没传的都是undefined clickEvent2(x, y, z) { console.log(x) console.log(y) console.log(z) } } }) </script> </html>
-
需要两个参数,第一个是事件对象,第二个是字符串
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="vue.js"></script> </head> <body> <div id="app01"> <button @click="clickEvent3($event,'jasper')">函数需要两个参数,第一个是事件,第二个是字符串</button> </div> </body> <script> var vm = new Vue({ el: '#app01', data: { }, methods: { // $event就是当前事件对象 clickEvent3(event, name){ console.log(event) console.log(name) } } }) </script> </html>
2.3 属性指令
属性指令语法:v-bind:‘属性名’=’变量名‘,可以简写成:属性名=‘变量名’
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app01">
<img :src="url" alt="" width="200px" height="200px">
<hr>
<button @click="clickEvent">点我随机展示头像</button>
<br>
<img :src="init" alt="" width="200px" height="200px">
<hr>
<img :src="init2" alt="" width="200px" height="200px">
</div>
</body>
<script>
var vm = new Vue({
el: '#app01',
data: {
url: '',
init: null,
init2: null,
urlArryay: [
'https://img0.baidu.com/it/u=1602355639,1266403457&fm=253&fmt=auto&app=120&f=JPEG?w=400&h=400',
'https://img1.baidu.com/it/u=2464581623,2530444367&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
'https://img0.baidu.com/it/u=1215328029,2575861253&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
'https://img2.baidu.com/it/u=1608586102,2465728818&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
'https://img0.baidu.com/it/u=2600564833,3323894085&fm=253&fmt=auto&app=138&f=JPEG?w=501&h=500',
'https://img1.baidu.com/it/u=3932128358,2942918540&fm=253&fmt=auto&app=138&f=JPEG?w=519&h=500',
'https://img2.baidu.com/it/u=3899579668,1774588624&fm=253&fmt=auto&app=138&f=JPEG?w=498&h=500',
'https://img2.baidu.com/it/u=2003626181,3649993723&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500'
],
},
methods: {
clickEvent() {
var i = Math.floor(Math.random() * this.urlArryay.length)
this.init = this.urlArryay[i]
},
beforeCreate() {
console.log('在实例初始化之前调用')
},
mounted() {
// 页面加载完,开启一个定时器,每隔1s执行函数,函数里面在变化变量
setInterval(() => {
var i = Math.floor(Math.random() * this.urlArryay.length)
this.init2 = this.urlArryay[i]
}, 1000)
}
}
})
</script>
</html>
三 style和class
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<h1>style</h1>
<div :style="styleStr">style属性</div>
<div :style="styleArray">style属性</div>
<div :style="styleObj">style属性</div>
<hr>
<button @click="clickStyle">背景色全部改成粉色</button>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
styleStr: 'font-size: 30px;background: red',
// 可以使用数组的操作方法来控制style属性
styleArray: [{fontSize:'30px'}, {background:'yellow'}],
// 使用对象的操作方法来控制style的属性 使用较多
styleObj: {fontSize:'30px', background:'blue'},
},
methods:{
clickStyle(){
this.styleStr = this.styleStr.replace('red','pink')
this.styleArray[1].background = 'pink'
this.styleObj.background = 'pink'
}
}
})
</script>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
<style>
.red {
background: red;
}
.pink {
background: pink;
}
.size {
font-size: 50px;
}
</style>
</head>
<body>
<div id="app">
<h1>class</h1>
<div :class="classStr">class属性</div>
<div :class="classArray">class属性</div>
<div :class="classObj">class属性</div>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
classStr: 'red size',
// 数组使用较多
classArray: ['pink', 'size'],
classObj: {red: true, pink: false, size: true},
}
})
</script>
</html>
四 条件渲染
需求:输入成绩,回车后显示分数对应的等级。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" v-model="score" @keyup.enter="handleUp">
<span v-if="score1>=90">优秀</span>
<span v-else-if="score1>=60 && score1<90">及格</span>
<span v-else-if="score1>0 && score1<60">不及格</span>
<span v-else>输入正确的成绩</span>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
score: '',
score1: '',
},
methods: {
handleUp() {
this.score1 = this.score
}
}
})
</script>
</html>
五 列表渲染
模拟购物车展示小实例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
</head>
<body>
<div id="app">
<div class="container-fluid">
<div class="row">
<div class="col-md-6 col-md-offset-3">
<button class="btn btn-success" @click="clickCar">加载购物车</button>
<div v-if="shopCar">
<table class="table table-striped">
<thead>
<tr>
<th>id</th>
<th>商品名</th>
<th>商品价格</th>
<th>购买数量</th>
</tr>
</thead>
<tbody>
<tr v-for="obj in shopCar">
<th scope="row">{{obj.id}}</th>
<td>{{obj.name}}</td>
<td>{{obj.price}}</td>
<td>{{obj.count}}</td>
</tr>
</tbody>
</table>
</div>
<div v-else>购物车为空</div>
</div>
</div>
</div>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
shopCar: ''
},
methods: {
clickCar() {
this.shopCar = [
{id: 1, name: '钢笔', 'price': 29, count: 1},
{id: 2, name: '铅笔', 'price': 2, count: 2},
{id: 3, name: '毛笔', 'price': 3, count: 3},
{id: 4, name: '圆珠笔', 'price': 1, count: 4},
{id: 5, name: '中性笔', 'price': 2.5, count: 5},
]
}
}
})
</script>
</html>
六 双向数据绑定
适用于input标签,在标签上加上v-model=变量名,数据就变为双向绑定。
登录功能小示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
username:<input type="text" v-model="username">
password:<input type="text" v-model="password">
<button @click="submitClick">提交</button>
<span>{{err}}</span>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
username: '',
password: '',
err: ''
},
methods: {
submitClick() {
if (this.username == 'xuxiaoxu' && this.password == '123') {
alert('登陆成功')
} else {
this.err = '用户名或密码错误'
}
}
}
})
</script>
</html>
七 事件处理
input事件:
blur:失去焦点触发
change:发生变化触发
input:输入时触发
7.1 过滤案例
补充:
数组的内置过滤方法filter:参数是一个箭头函数,每次从数组中取一个值,函数返回true就保留该值,返回false就丢弃该值。
判断字符串是都在另一个字符串里:字符串.indexof(字符串),返回索引,如果索引大于等于0,说明存在。
箭头函数:
如果只有一个参数,那也可以不用括号。只有没有参数,或者多个参数的情况下,才需要使用括号:
var func0 = () => {return true}
var func = a => {return a}
var func1 = (a,b) => {return a + b}
箭头函数也可以不用大括号,但这样会改变函数的行为。使用大括号就说明包含“函数体”,可以在一个函数中包含多条语句,跟常规的函数一样。
省略大括号箭头后面就只能有一行代码;
省略大括号会隐式返回这行代码的值;
省略大括号不能写return。
var func = () => true
var func1 = (a,b) => a + b //相当于return a + b
var func2 = a => true
条件过滤小示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" v-model="search" placeholder="输入搜索条件" @input="searchCondition">
<ul>
<li v-for="data in newDataArray">{{data}}</li>
</ul>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
dataArray: [
'a',
'abc',
'ace',
'b',
'bb',
'bios',
'cs',
'csrf',
'd',
'dddd',
],
newDataArray: ['a', 'abc', 'ace', 'b', 'bb', 'bios', 'cs', 'csrf', 'd', 'dddd',],
search: '',
},
methods: {
searchCondition() {
this.newDataArray = this.dataArray.filter(item =>
item.indexOf(this.search) >= 0)
// 复杂写法
// this.newDataArray = this.dataArray.filter(item => {
// if (item.indexOf(this.search) >= 0) {
// return true
// } else {
// return false
// }
// })
}
}
})
</script>
</html>
7.2 事件修饰符
.stop 只处理自己的事件,不向父控件冒泡
.self 只处理自己的事件,子控件冒泡的事件不处理
.prevent 阻止a链接的跳转
.once 事件只会触发一次(适用于抽奖页面)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<ul @click.self="clickParent">父标签
<li @click.stop="clickMe">子标签</li>
</ul>
<a href="https://www.baidu.com" @click.prevent>百度一下,你就知道</a>
<button @click.once="onceClick">点我弹窗,但是只能弹一次</button>
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {},
methods: {
// 如果没有加事件修饰符 点击子标签也会触发父标签的点击事件执行
clickParent() {
alert('父标签点了')
},
clickMe() {
alert('子标签点了')
},
onceClick(){
alert('在弹需要刷新页面')
}
}
})
</script>
</html>
7.3 按键修饰符
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" @keyup.enter="keyUp">
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {},
methods: {
keyUp(event) {
// 当没有指定按下什么键时 每次都会执行该函数
// console.log(event)
// if (event.keyCode == 13) {
// alert('按下了回车键')
// }
// 指定按下enter 当按下相应的键才会执行该函数
alert('按下了回车键')
}
}
})
</script>
</html>
八 表单控制
8.1 checkbox选中
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" placeholder="输入用户名">
<br>
<input type="password" placeholder="输入密码">
<br>
<input type="checkbox" v-model="isRemember">记住密码
<br>
{{isRemember}}
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {
isRemember: false
}
})
</script>
</html>
8.2 radio单选
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="radio" v-model="radio" value="1">男
<input type="radio" v-model="radio" value="2">女
<input type="radio" v-model="radio" value="0">未知
<br>
选择的性别是:{{radio}}
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {
radio: '',
}
})
</script>
</html>
8.3 checkbox多选
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="checkbox" v-model="multiChoice" value="sing">唱
<input type="checkbox" v-model="multiChoice" value="dump">跳
<input type="checkbox" v-model="multiChoice" value="rap">说唱
<input type="checkbox" v-model="multiChoice" value="basketball">篮球
<br>
{{multiChoice}}
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {
multiChoice: [],
}
})
</script>
</html>
九 购物车案例
补充:js的for循环
let shopArray = [
{id: 1, name: '汽车', price: 300000, count: 1},
{id: 2, name: '手机', price: 6799, count: 2},
{id: 3, name: '电脑', price: 12888, count: 1},
{id: 1, name: '铅笔', price: 2, count: 5},
{id: 1, name: '键盘', price: 399, count: 1},
]
// 按照索引循环
for (let i = 0; i < shopArray.length; i++) {
console.log(i, shopArray[i])
}
console.log('===================')
// 迭代循环
for (let i in shopArray) {
console.log(i, shopArray[i])
}
console.log('===================')
// 迭代循环
for (item of shopArray) {
console.log(item)
}
console.log('===================')
// 数组的循环方法
shopArray.forEach(item => {
console.log(item)
})
console.log('===================')
// jquery的循环
$.each(shopArray, (i, v) => {
console.log(i, v)
})
购物车示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
</head>
<body>
<div class="container-fluid" id="app">
<div class="row">
<div class="col-md-6 col-md-offset-3">
<h1 style="color: darkseagreen">购物车</h1>
<table class="table">
<thead>
<tr class="info">
<th>id</th>
<th>商品名</th>
<th>商品价格</th>
<th>商品数量</th>
<th>全选/全不选 <input type="checkbox" @change="allSelect" v-model="isAll"></th>
</tr>
</thead>
<tbody>
<tr class="danger" v-for="obj in shopArray">
<th scope="row">{{obj.id}}</th>
<td>{{obj.name}}</td>
<td>{{obj.price}}</td>
<td>
<button class="btn-xs" @click="downCount(obj)">-</button>
{{obj.count}}
<button class="btn-xs" @click="obj.count++">+</button>
</td>
<td><input type="checkbox" v-model="select" :value="obj" @change="checkOne"></td>
</tr>
</tbody>
</table>
{{select}}
<br>
<p>商品总价格:{{get_money()}}</p>
</div>
</div>
</div>
</body>
<script>
var vm = new Vue({
el: '#app',
data: {
shopArray: [
{id: 1, name: '汽车', price: 300000, count: 1},
{id: 2, name: '手机', price: 6799, count: 2},
{id: 3, name: '电脑', price: 12888, count: 1},
{id: 1, name: '铅笔', price: 2, count: 5},
{id: 1, name: '键盘', price: 399, count: 1},
],
select: [],
isAll: false
},
methods: {
allSelect() {
if (this.isAll) {
this.select = this.shopArray
} else {
this.select = []
}
},
checkOne() {
this.isAll = this.select.length === this.shopArray.length
},
get_money() {
let money = 0
for (obj of this.select) {
money += obj.price * obj.count
}
return money
},
downCount(obj) {
if (obj.count > 1) {
obj.count -= 1
} else {
alert('宝贝不能再少了')
}
}
}
})
</script>
</html>
十 v-model进阶
lazy:等待input框的数据绑定失去焦点之后再变化
number:数字开头,只保留数字,后面的字母不保留;字母开头,都保留
trim:去除首尾的空格
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" v-model.lazy="text1"> lazy=> {{text1}}
<br>
<input type="text" v-model.number="text2"> number=> {{text2}}
<br>
<input type="text" v-model.trim="text3"> trim=> {{text3}}
</div>
</body>
<script>
let vm = new Vue({
el: '#app',
data: {
text1: '',
text2: '',
text3: '',
}
})
</script>
</html>
更多推荐
所有评论(0)