• vue实现图书管理demo


    年后公司的项目要求用到vue.js知识,我angular没有学,node.js和react也只是了解了一点点,所以学起来比较困难。如果你想学vue.js的知识,推荐网址:http://vuejs.org/

    详细内容如下:

    一、图书管理demo用的知识点

    1、bootstrap    http://getbootstrap.com/

    2、vuejs    http://getbootstrap.com/

    具体代码如下:

    html部分

    <div id="app" class="container">
                <table class="table table-bordered">
                    <div v-for = "book in books">
                        <tr>
                            <th>书名</th>
                            <th>书的价格</th>
                            <th>书的数量</th>
                            <th>小计</th>
                            <th>操作</th>
                        </tr>
                        <tr v-for = "(index,book ) in books">
                            <td>{{book.name}}</td>
                            <td>{{book.price}}</td>
                            <td><button @click="book.count&&book.count--">-</button><input type="text" v-model="book.count" /><button @click="book.count++">+</button></td>
                            <td>{{book.price*book.count}}</td>
                            <td><button class="btn btn-danger" @click="deleteBook(book)">删除</button></td>
                        </tr>
                        <tr>
                            <td colspan="5">
                                总价{{total}}
                            </td>
                        </tr>
                    </div>
                </table>
                <div class="form-group">
                    <label for="bookname" id="bookname">书名</label>
                    <input type="text" v-model="list.name" class="form-control"/>
                </div>
                <div class="form-group">
                    <label for="bookprice" id="bookprice">价格</label>
                    <input type="text" v-model="list.price" class="form-control"/>
                </div>
                <div class="form-group">
                    <label for="bookcount" id="bookcount">数量</label>
                    <input type="text" v-model="list.count" class="form-control"/>
                </div>
                <div class="form-group">
                    <button class="btn btn-primary" @click="add">添加</button>
                </div>
            </div>

    脚本部分

    <script src="js/vue.js"></script>
            <script>
                var vm = new Vue({
                    el:"#app",
                    data:{
                        books:[
                        {name:'VUE js',price:40,count:1},
                        {name:'NODE js',price:20,count:1},
                        {name:'REACT js',price:30,count:1},
                        {name:'ANGULAR js',price:100,count:1},
                        {name:'JQUERY js',price:50,count:1},
                        ],
                        list:{
                            name:'',
                            price:'',
                            count:''
                        }
                    },
                    methods:{
                        deleteBook(book){
                            // vue 给我们提供了一个 $remove的方法,在数组中删除
                            this.books.$remove(book);
                            /*this.books = this.books.filter((item)=>{
                                return item != book
                            })*/
                        },
                        add(){
                            this.books.push(this.list);
                            this.list = {
                                name:'',
                                price:'',
                                count:''
                            }
                        }
                    },
                    computed:{
                        total(){
                            var sum = 0;
                            this.books.forEach(item =>{
                                sum += item.price*item.count;
                            })
                            return sum;
                        }
                    }
                });
            </script>

    遇到难点总结

    当数量小于0时,判断方法,解决方法有很多种,下面总结有3中方法

    (一)最简单的方法

    根据逻辑判断,这里要注意逻辑判断的顺序,代码如下:

    <td><button @click="book.count&&book.count--">-</button><input type="text" v-model="book.count" /><button @click="book.count++">+</button></td>

    (二)这里要注意this指向问题

    <td><button @click="min(index,book.count)">-</button><input type="text" v-model="book.count" /><button @click="book.count++">+</button></td>
    
    methods:{
                        min(index){
                            if(this.books[index].count>0){
                                 this.books[index].count = parseInt(this.books[index].count) - 1;
                            }
                        },
                        deleteBook(book){
                            // vue 给我们提供了一个 $remove的方法,在数组中删除
                            this.books.$remove(book);
                            /*this.books = this.books.filter((item)=>{
                                return item != book
                            })*/
                        },
                        add(){
                            this.books.push(this.list);
                            this.list = {
                                name:'',
                                price:'',
                                count:''
                            }
                        }
                    }

    (三) v-on执行时传参问题

    <td><button @click="min(book)">-</button><input type="text" v-model="book.count" /><button @click="book.count++">+</button></td>
    min(book){
    	if(book.count>0){
    		book.count = parseInt(book.count) - 1;
    	}
    }
    

    总结:

    v-on执行方法的时候需要传递参数的时候添加(),如果不需要传递参数就不用加上() 
    如果需要传递参数,我们需要手动传入事件源

    建议:

    1、如果您有充足的时间来学习vue,务必要把js基础打好,学习下angular.js

    2、学会在网上找资料。

    作者:白开水

    出处:http://www.cnblogs.com/hongxp/

    本文以学习、总结和分享为主,如需转载,请联系本人,标明作者和出处,非商业用途!

     

  • 相关阅读:
    [LintCode] Single Number 单独的数字
    [LeetCode] 444. Sequence Reconstruction 序列重建
    [LeetCode] K-th Smallest in Lexicographical Order 字典顺序的第K小数字
    [LeetCode] Arranging Coins 排列硬币
    [LeetCode] Ternary Expression Parser 三元表达式解析器
    [LeetCode] 436. Find Right Interval 找右区间
    在Mac上配置全局的Git忽略文件
    Git『Everything up-to-date』问题解决
    Android组件化框架项目详解
    Android架构设计之插件化、组件化
  • 原文地址:https://www.cnblogs.com/hongxp/p/6420716.html
Copyright © 2020-2023  润新知