Vue的v-for指令、事件处理、表单控制

一 条件渲染

指令 释义
v-if 相当于: if
v-else 相当于:else
v-else-if 相当于:else if
html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>if、else if、elsetitle>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    <h3>案例:if、else if、elseh3>
    <h2 v-if="type==='1'">Ah2>
    <h2 v-else-if="type==='2'">Bh2>
    <h2 v-else>Ch2>
div>
body>
<script>
    let vm = new Vue({
        el: '#box',
        data: {
            type: '1',
        }
    })
script>
html>

二 列表渲染

1. v-if+v-for+v-else控制购物车商品的显示

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if + v-for + v-else控制购物车商品的显示title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
    <style>
        table, td {
            border: 1px solid black;
            text-align: center;
        }
    style>
head>
<body>
<div id="box">
    <h2>我的购物车h2>
    <button @click="show">刷新购物车button>
    <br><br>
    <table v-if="!shopping_car.length==0">
        <tr>
            <td>商品名称td>
            <td>价格td>
        tr>
        <tr v-for="item in shopping_car">
            <td>{{item.name}}td>
            <td>{{item.price}}td>
        tr>
    table>
    <table v-else>
        <tr>
            <td>商品名称td>
            <td>价格td>
        tr>
        <tr>
            <td>暂无信息td>
            <td>暂无信息td>
        tr>
    table>
div>
body>
<script>
    let vm = new Vue({
        el: '#box',
        data: {
            isActive: false,
            shopping_car: []
        },
        methods: {
            show() {
                this.shopping_car = [
                    {name: 'Threadripper 3990X', price: '29999元'},
                    {name: 'NVIDIA RTX 8000', price: '59999元'},
                    {name: 'ROG ZENITH II EXTREME', price: '9999元'},
                ]
            }
        }
    })
script>
html>

2. v-for遍历数组(列表)、对象(字典)、数字

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-for遍历数组(列表)、对象(字典)title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
    <style>
        table, td {
            border: 1px solid black;
            text-align: center;
        }
    style>
head>
<body>

<div id="box">
    <h2>数组(列表)for循环遍历h2>
    <ul>
        <li v-for="(value,index) in list_test">{{index}} —— {{value}}li>
    ul>

    <h2>对象(字典)for循环遍历h2>
    <ul>
        <li v-for="(value,key) in dic_test">{{key}} —— {{value}}li>
    ul>

    <h2>数组(列表)套对象(字典)for循环遍历h2>
    <table>
        <tr>
            <td>姓名td>
            <td>年龄td>
            <td>性别td>
            <td>国籍td>
        tr>
        <tr v-for="info in summary_test">
            <td>{{info.name}}td>
            <td>{{info.age}}td>
            <td>{{info.gender}}td>
            <td>{{info.country}}td>
        tr>
    table>
div>
body>
<script>
    let vm = new Vue({
        el: '#box',
        data: {
            list_test: ['First', 'second', 'Third', 'Forth', 'Fifth'],
            dic_test:{name: 'Darker', age: 18, gender: 'male'},
            summary_test: [
                    {name: 'Alan', age: 23, gender: 'male', country: 'America'},
                    {name: 'Ben', age: 15, gender: 'male', country: 'Australia'},
                    {name: 'Cindy', age: 12, gender: 'female', country: 'Japan'},
                    {name: 'Darker', age: 18, gender: 'male', country: 'China'},
                    {name: 'Elisa', age: 26, gender: 'female', country: 'Mexico'},
                ]
        }
    })
script>
html>

注意!Vue中:

  • 数组indexvalue反的
  • 对象keyvalue也是反的

3. key值 的解释

vue中使用的是虚拟DOM,会和原生的DOM进行比较,然后进行数据的更新,提高数据的刷新速度(虚拟DOM用了diff算法)

  • v-for循环数组、对象时,建议在控件/组件/标签写1个key属性,属性值唯一
  • 页面更新之后,会加速DOM的替换(渲染)
  • :key="变量"

4. 数组更新与检测

可以检测到变动的数组操作:
  • push:最后位置添加
  • pop:最后位置删除
  • shift:第一个位置删除
  • unshift:第一个位置添加
  • splice:切片
  • sort:排序
  • reverse:反转
检测不到变动的数组操作:
  • filter():过滤
  • concat():追加另一个数组
  • slice():
  • map():
原因:

作者重写了相关方法(只重写了一部分方法,但是还有另一部分没有重写)

解决方法:
// 方法1:通过 索引值 更新数组(数据会更新,但是页面不会发生改变)
vm.arrayList[0]
"Alan"
vm.arrayList[0]='Darker'
"Darker"

// 方法2:通过 Vue.set(对象, index/key, value) 更新数组(数据会更新,页面也会发生改变)
Vue.set(vm.arrayList, 0, 'Darker')

三 事件处理

事件 释义
input 当输入框进行输入的时候 触发的事件
change 当元素的值发生改变时 触发的事件
blur 当输入框失去焦点的时候 触发的事件

change 和 blur 最本质的区别:

  • 如果输入框为空,失去焦点后,change不会触发,但是blur会触发

1.过滤案例

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>过滤案例title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    <p><input type="text" v-model="myText" @input="handleInput" placeholder="请输入要筛选的内容:">p>


    <ul>
        <li v-for="data in newList">{{data}}li>
    ul>
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            myText: '',
            dataList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],
            newList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],
        },
        methods: {
            handleInput() {
                this.newList = this.dataList.filter(item => {
                    // item.indexOf(this.myText):输入框中输入的字符串在筛选元素中的索引
                    return item.indexOf(this.myText) > -1   // 返回索引大于1的元素:>-1 就表示包含在其中
                })
            },
        },
    })
script>
html>

2.事件修饰符

事件修饰符 释义
.stop 只处理自己的事件,父控件冒泡的事件不处理(阻止事件冒泡)
.self 只处理自己的事件,子控件冒泡的事件不处理
.prevent 阻止a链接的跳转
.once 事件只会触发一次(适用于抽奖页面)

使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生

  • 用 v-on:click.prevent.self 会阻止所有的点击
  • 而 v-on:click.self.prevent 只会阻止对元素自身的点击
html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>事件修饰符title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">

    <ul @click.self="handleUl">

        <li v-for="data in dataList" @click.stop="handleLi">{{data}}li>
        <li><a href="http://www.baidu.com">不拦截a>li>
        <li><a href="http://www.baidu.com" @click="handleLink($event)">点击拦截a>li>
        <li><a href="https://www.baidu.com" @click.prevent="handleLink">点击拦截a>li>
        <li><button @click.once="test">只执行一次button>li>
    ul>
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            dataList: ['1','22','333','4444']
        },
        methods: {
            handleUl(ev){
                console.log('ul被点击了')
            },
            handleLi(){
                console.log('li被点击了')
                ev.stopPropagation()    // 点击事件停止 冒泡(向父组件传递时间)
            },
            handleLink(ev){
                ev.preventDefault()
            },
            test(){
                alert('只触发1次')
            }
        }
    })
script>
html>

3.按键修饰符

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>按键修饰符title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    
    
    <input type="text" @keyup="handleKey1">
    <input type="text" @keyup.enter="handleKey2">
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            dataList: ['1', '22', '333', '4444']
        },
        methods: {
            handleKey1(ev) {
                console.log('按下了' + ev)
                // if (ev.keyCode==13){
                //     console.log('回车键被按下了')
                // }
            },
            handleKey2(ev) {
                console.log('按下了回车键')
            }
        }
    })
script>
html>

四:数据双向绑定

v-model的使用

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    <input type="text" v-model="myText" placeholder="请输入内容">
    您输入的内容是:{{myText}}
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            myText: '',
        },
    })
script>
html>

五:表单控制

1.checkbox选中

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>checkboxtitle>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    <input type="text" placeholder="请输入用户名:"><br>
    <input type="password" placeholder="请输入密码:"><br>
    <input type="checkbox" v-model="radio">记住用户名
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            myText: '',
            textBig: '',
            radio: false,
        },
    })
script>
html>

2.单选

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>单选title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">
    <input type="radio" v-model="radio" value="男"><input type="radio" v-model="radio" value="女"><input type="radio" v-model="radio" value="保密">保密
    <br><br>您选择的性别:{{radio}}
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            radio: '',
        },

    })
script>
html>

3.多选

html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>多选title>
    <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js">script>
head>
<body>
<div id="box">

    <input type="checkbox" v-model="many" value="篮球">篮球
    <input type="checkbox" v-model="many" value="足球">足球
    <input type="checkbox" v-model="many" value="棒球">棒球
    <input type="checkbox" v-model="many" value="桌球">桌球
    <br><br>您喜欢的球类:{{many}}
div>
body>
<script>
    var vm = new Vue({
        el: '#box',
        data: {
            many: [],
        },
    })
script>
html>

你可能感兴趣的:(Vue,vue.js,前端,javascript,开发语言)