zoukankan      html  css  js  c++  java
  • 从零开始学VUE之模板语法(阶段案例及其过滤器)

    阶段案例

    案例效果

    新建index.html

    复制代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <link rel="stylesheet" href="style.css">
    </head>
    <body>
    <div id="app">
        <table>
            <thread>
                <tr>
                    <th></th>
                    <th>书籍名称</th>
                    <th>出版日期</th>
                    <th>价格</th>
                    <th>购买数量</th>
                    <th>操作</th>
                </tr>
            </thread>
            <tbody>
            <tr v-for="(item,index) in books">
                <td>{{item.id}}</td>
                <td>{{item.name}}</td>
                <td>{{item.date}}</td>
                <!--使用过滤器 过滤价格-->
                <td>{{item.price | finalPrice}}</td>
                <td>
                    <button @click="decr(index)">-</button>
                    {{item.count}}
                    <button @click="incr(index)">+</button>
                </td>
                <td>
                    <button @click="rem(index)">移除</button>
                </td>
            </tr>
            </tbody>
        </table>
        <div>总价:{{totalPrice | finalPrice}}</div>
    </div>
    
    <script src="../../../js/vue.js"></script>
    <script src="main.js"></script>
    </body>
    </html>
    复制代码

    新建style.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;
    }
    复制代码

    新建main.js

    复制代码
    const app = new Vue({
        el: '#app',
        data: {
            books:[
                {
                    id:1,
                    name:'<<算法导论>>',
                    date:'2006-9',
                    price:85.00,
                    count:1
                },
                {
                    id:2,
                    name:'<<UNIX编程艺术>>',
                    date:'2006-2',
                    price:59.00,
                    count:1
                },
                {
                    id:3,
                    name:'<<编程珠玑>>',
                    date:'2008-10',
                    price:39.00,
                    count:1
                },
                {
                    id:4,
                    name:'<<代码大全>>',
                    date:'2006-3',
                    price:128.00,
                    count:1
                },
            ]
        },
        methods: {
            incr(index) {
                this.books[index].count++;
            },
            decr(index) {
                if (this.books[index].count === 0) {
                    return;
                }
                this.books[index].count--;
            },
            rem(index) {
                this.books.splice(index, 1);
            }
        },
        computed:{
            totalPrice(){
                let totalPrice = 0;
                for (const item of this.books) {
                    totalPrice += item.price * item.count;
                }
                return totalPrice;
            }
        },
        // 过滤器
        filters:{
            finalPrice(price){
                // 拼接特殊符号,并保留两位小数
                return '¥' + price.toFixed(2);
            }
        }
    })
    复制代码

    运行效果和上面一致

    该案例是对上面的知识的综合运用,里面还提及了新的知识,filters过滤器

    作者:彼岸舞

    时间:2021531

    内容关于:VUE

    本文属于作者原创,未经允许,禁止转发

  • 相关阅读:
    dede自定义表单增加添加时间怎么弄
    今天微信群需要人家通过吗?是微信bug吗
    6.3.28微信需群主确认才可进群&发GIF动图功能内测开始了
    聚类分析初探
    一小时了解数据挖掘⑤数据挖掘步骤&常用的聚类、决策树和CRISP-DM概念
    Bayesian optimisation for smart hyperparameter search
    【模式识别】Learning To Rank之RankBoost
    UVA 816
    设计一个算法,输出从u到v的全部最短路径(採用邻接表存储)
    禅道——測试流程
  • 原文地址:https://www.cnblogs.com/flower-dance/p/14832107.html
Copyright © 2011-2022 走看看