【Vue】Re05 操作数组的API

一、响应式处理的操作:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<div id="v">
    <ul>
        <li v-for="l in letters">{{l}}</li>
    </ul>

    <hr>

    <p>
        <button @click="arrayElPush" >push - 增加</button>
        <br>
        <button @click="changeElReAssignment" >assignment - 重新赋值</button>
        <br>
        <button @click="arrayElPop" >pop - 删除</button>
        <br>
        <button @click="arrayShift" >shift - 从头部删除</button>
        <br>
        <button @click="arrayUnshift" >unshift - 从头部添加</button>
        <br>
        <!--<button @click="arraySplice" >splice - 无参splice</button>-->
        <button @click="arraySetElement" >set - 使用set赋值处理</button>
    </p>
</div>
<script src="./../dependencies/vue.js"></script>
<script type="text/javascript">
    const v = new Vue({
        el : '#v',
        data : {
            letters : ['a', 'b', 'c', 'd', 'e']
        },
        methods : {
            arrayElPush() {
                // 1、在数组的结尾处增加一个元素 [会触发响应更新]
                this.letters.push('element');
            },
            changeElReAssignment() {
                // 2、赋值方法并不刷新页面 [不会触发响应更新]
                this.letters[0] = 'sss';
            },
            arrayElPop() {
                // 3、从最后一位删除元素 [会触发响应更新]
                this.letters.pop();
            },
            arrayShift() {
                // 4、删除数组第一位元素 [会触发响应更新]
                this.letters.shift();
            },
            arrayUnshift() {
                // 5、从第一位前面添加元素 [会触发响应更新]
                this.letters.unshift('from-head-insert');
            },
            // push方法和unshift方法都支持了可变参数,意思是添加时可以支持多个元素一起注入添加
            arraySplice() {
                // 6、splice方法
                this.letters.splice();
                // 可用于删除元素 参数1 + 参数2  1指定起始位置, 2指定删除个数
                // 可用于插入元素 参数1 + 参数2 + 参数3  1指定插入起始位置,2指定0,表示不删除,3 ~ n 添加要插入的元素
                // 可用于替换元素 参数1 + 参数2 + 参数3  1指定替换位置,2指定要替换的个数, 3 ~ n 要替换的元素

                // 参数1表示start 要执行数组操作的起始位置
                // 参数2表示size 要执行删除操作的元素个数,注意,如果你没有提供此参数,注入了参数1,此函数将删除所有元素
                // 参数3 ~ 参数n 要执行插入的具体元素
            },
            arrayChangeElement() {
                Vue.set(this.letters, 0, 'sss');
            },
            arraySetElement() {
                // 如果要更改元素的值,并且响应化处理,使用set方法实现
                // 参数1表示要更改的数组,参数二表示更换的索引,参数表示更新的元素
                Vue.set(this.letters, 0, 'sss');
            }
        }
    });
</script>

</body>
</html>

购物车演示案例:

【index.html】

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link type="text/css" rel="stylesheet" href="style.css">

</head>
<body>

<div id="v">
    <table border="1px">
        <thead>
            <th></th>
            <th>书籍名称</th>
            <th>出版日期</th>
            <th>单价金额</th>
            <th>购买数量</th>
            <th>操作选择</th>
        </thead>

        <tbody>
            <tr v-for="(book, i) in bookList">
                <!--<td v-for="value in book">{{value}}</td>-->
                <td>{{book.id}}</td>
                <td>{{book.name}}</td>
                <td>{{book.date}}</td>

                <!-- 解决不显示小数点后两位的问题 <td>{{book.price}}</td> -->
                <!-- 需要显示羊角符号 ¥ <td>{{'¥' + book.price.toFixed(2)}}</td> -->
                <!-- 最后移交到函数中处理显示 -->
                <td>{{showCompletePrice(book.price)}}</td>

                <td>
                    <button @click="decrement(i)" :disabled="book.count === 0"> - </button>
                    {{book.count}}
                    <button @click="increment(i)" :disabled="book.count === 10"> + </button>
                </td>
                <td>
                    <button @click="removeItem(i)">移除</button>
                </td>
            </tr>

            <tr>
                <td colspan="6" style="text-align: center"> 合计金额 :{{totalPrice}}</td>
            </tr>
        </tbody>
    </table>
</div>

<script type="text/javascript" src="../dependencies/vue.js"></script>
<script type="text/javascript" src="main.js"></script>

</body>
</html>

【mains,js】

const v = new Vue({
    el : '#v',
    data : {
        bookList : [
            { id : 1, name : 'aaa', date : '2020-10-26', price : 34.5, count : 0 },
            { id : 2, name : 'bbb', date : '2020-10-26', price : 31.5, count : 0 },
            { id : 3, name : 'ccc', date : '2020-10-26', price : 32.5, count : 0 },
            { id : 4, name : 'ddd', date : '2020-10-26', price : 33.5, count : 0 },
            { id : 5, name : 'eee', date : '2020-10-26', price : 33.5, count : 0 },
            { id : 6, name : 'fff', date : '2020-10-26', price : 31.5, count : 0 },
            { id : 7, name : 'ggg', date : '2020-10-26', price : 32.5, count : 0 },
        ]
    },
    methods : {
        showCompletePrice(val) {
            return '¥' + val.toFixed(2);
        },
        increment(index) {
            this.bookList[index].count ++;
        },
        decrement(index) {
            this.bookList[index].count --;
        },
        removeItem(index) {
            this.bookList.splice(index, 1);
        }
    },
    computed : {
        totalPrice() {
            let t = 0;
            // for (let i = 0; i < this.bookList.length; i++) {
            //     t += this.bookList[i].price * this.bookList[i].count;
            // }
            for (let book of this.bookList) {
                t += book.price * book.count;
            }
            return '¥' + t.toFixed(2);
        }
    }
});

css样式设计

table {
    border: 1px solid #e9e9e9;
    border-collapse: collapse;
    border-spacing: 0;
}
th, td {
    padding: 8px 16px;
    border: 1px solid #e9e9e9;
    text-align: left;
}

th {
    background-color: #f7f7f7;
    color: #5c6b77;
    font-weight: 600;
}

posted @ 2020-10-26 14:16  emdzz  阅读(903)  评论(0编辑  收藏  举报