vue.js快速搭建图书管理平台

来源:互联网 发布:淘宝预售定金就是坑 编辑:程序博客网 时间:2024/06/05 00:21
  1、DEMO样式

 

  首先我们需要搭建一个简单的demo样式,推荐大家使用bootstrap,可以很快的搭建出一个清晰简洁的页面。

  给大家分享一段我的代码吧。

  

复制代码
        <div class="container">            <div class="col-md-6 col-md-offset-3">                <h1>Vue demo</h1>                                 <div id="app">                    <table class="table table-hover ">                          <caption></caption>                        <thead>                            <tr>                                <th>序号</th>                                <th>书名</th>                                <th>作者</th>                                <th>价格</th>                                <th>操作</th>                            </tr>                        </thead>                    </table>                                     <div id="add-book">                        <legend>添加书籍</legend>                        <div class="form-group">                            <label for="group">书名</label>                            <input type="text" class="form-control" id="group">                        </div>                        <div class="form-group">                            <label for="author">作者</label>                            <input type="text" class="form-control" id="author">                        </div>                        <div class="form-group">                            <label for="price">价格</label>                            <input type="text" class="form-control" id="price">                        </div>                        <button class="btn btn-primary btn-block">添加</button>                        <button class="btn btn-primary btn-block">查询</button>                    </div>                                        <div id="update-book">                        <legend>修改书籍</legend>                        <div class="form-group">                            <label for="group1">书名</label>                            <input type="text" class="form-control" id="group1">                        </div>                        <div class="form-group">                            <label for="author1">作者</label>                            <input type="text" class="form-control" id="author1">                        </div>                        <div class="form-group">                            <label for="price1">价格</label>                            <input type="text" class="form-control" id="price1">                        </div>                        <button class="btn btn-primary btn-block">完成</button>                    </div>                </div>            </div>        </div>
复制代码

  运用了bootstrap的栅格系统,和一些简单的组件,不光简单快捷,还能自动实现响应式呢。

  而且做出来的效果也不难看,挺整洁的。

  给大家看下刚开始的效果图。

  如果对这个CSS框架没有了解的话,自己写一下样式也没关系。

 

  2、创建vue实例

   

  接下来,我们导入自己的JS文件,创建一个vue实例。

  

复制代码
new Vue({    el: '#app',    data: {        book: {            id: 0,            author: '',            name: '',            price: ''        },        books: [{            id: 1,            author: '曹雪芹',            name: '红楼梦',            price: 32.0        }, {            id: 2,            author: '施耐庵',            name: '水浒传',            price: 30.0        }, {            id: '3',            author: '罗贯中',            name: '三国演义',            price: 24.0        }, {            id: 4,            author: '吴承恩',            name: '西游记',            price: 20.0        }]    } });
复制代码

 

  data中是一些初始的数据,可以随意填写。

 

3 、将各种指令添加到HTML

  

  我们说过,vue的核心聚焦在视图层,所以指令是最重要的一步,我们一点一点说。

  不过因为指令分布的比较乱,所以直接附上全部代码,然后我一个一个的解释。

  

复制代码
                <div id="app">                    <table class="table table-hover ">                          <caption></caption>                        <thead>                            <tr>                                <th>序号</th>                                <th>书名</th>                                <th>作者</th>                                <th>价格</th>                                <th>操作</th>                            </tr>                        </thead>                        <tbody>                            <tr v-cloak v-for="book in books">                                 <td>{{book.id}}</td>                                <td>{{book.name}}</td>                                <td>{{book.author}}</td>                                <td>{{book.price}}</td>                                <template v-if="book.id%2==0">                                    <td class="text-left">                                        <button type="button" class="btn btn-success" @click="delBook(book)" class="del">删除</button>                                        <button type="button" class="btn btn-success" @click="updateBook(book)">修改</button>                                    </td>                                </template>                                <template v-else>                                    <td class="text-left">                                        <button type="button" class="btn btn-danger" @click="delBook(book)" class="del">删除</button>                                        <button type="button" class="btn btn-danger" @click="updateBook(book)">修改</button>                                    </td>                                </template>                            </tr>                        </tbody>                    </table>                                     <div id="add-book">                        <legend>添加书籍</legend>                        <div class="form-group">                            <label for="group">书名</label>                            <input type="text" class="form-control" id="group" v-model="book.name">                        </div>                        <div class="form-group">                            <label for="author">作者</label>                            <input type="text" class="form-control" id="author" v-model="book.author">                        </div>                        <div class="form-group">                            <label for="price">价格</label>                            <input type="text" class="form-control" id="price" v-model="book.price">                        </div>                        <button class="btn btn-primary btn-block" v-on:click="addBook()">添加</button>                        <button class="btn btn-primary btn-block" v-on:click="searchBook()">查询</button>                    </div>                                        <div id="update-book">                        <legend>修改书籍</legend>                        <div class="form-group">                            <label for="group1">书名</label>                            <input type="text" class="form-control" id="group1" v-model="book.name">                        </div>                        <div class="form-group">                            <label for="author1">作者</label>                            <input type="text" class="form-control" id="author1" v-model="book.author">                        </div>                        <div class="form-group">                            <label for="price1">价格</label>                            <input type="text" class="form-control" id="price1" v-model="book.price">                        </div>                        <button class="btn btn-primary btn-block" v-on:click="updatesBook()">完成</button>                    </div>                </div>
复制代码

  

  首先,将id为app的vue实例挂载到DOM节点上,如果对于这些基本内容还不了解的话,可以去看我的上一篇博客,详细的介绍了关于vue的基础知识。

  下面的表格,在tr中通过一个v-for循环,将vue实例data中的数据,全部载入到表格里。

  细心的读者应该发现了,我在v-for前写了一个v-cloak,这是干什么的呢?

  用过angular,vue这种框架的人应该都知道,当我们用{{}}绑定数据的时候,当页面刷新的瞬间,会看到闪烁而过的原始代码。

  当信息量比较大的时候,这种体验无疑是十分恶劣的,这个时候,v-cloak这个指令保持在元素上直到关联实例结束编译。

  和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到实例准备完毕。

  这样就解决了刷新的瞬间页面出现大量乱码的情况。

  下面的v-if和v-else就是为了练习一下各种指令啦,让我们的按钮生成的时候可以轮流生成两种颜色~

  而v-model是为了在input中输入内容时,可以动态的取到输入的内容。

  还是那句话,这些基本指令不认识的话,可以去我的上一篇博客查看。

  那些v-on:click绑定的函数,一会一个一个详细解释,现在先来看一下效果。

【本文由“程序员汪汪”发布,2017年10月28日】