六十四、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>

函数传参:

  1. 函数需要一个参数,但是没有传

    <!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>
    

    在这里插入图片描述

  2. 参数传少了

    <!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>
    

    在这里插入图片描述

  3. 需要两个参数,第一个是事件对象,第二个是字符串

    <!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>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值