Vue实现图书管理小案例

本文实例为大家分享了Vue实现图书管理的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
     .grid{
      margin:auto;
      width:500px;
      text-align:center;
     }
     .grid table{
      width:100%;
      border-collapse:collapse;
     }
     .grid th,td{
      padding:10px;
      border:1px solid orange;
      height:35px;
      line-height:35px;
     }
     .grid th{
      background-color:orange;
     }
     .book{
      background-color:orange;
      border-bottom:1px solid #ccc;
      padding:5px;
     }
     input{
      width:150px;
      outline:none;
     }
     .grid .total{
      height:30px;
      line-height:30px;
      background-color:orange;
      border-bottom:1px solid #ccc;
     }
  </style>
</head>
<body>
<div id="app">
  <div class="grid">
   <div>
     <h1>图书管理</h1>
     <div class="book">
      <label for="id">编号:</label>
      <input type="text" id="id" v-model='id' :disabled='flag' v-focus>
      <label for="name">名称:</label>
      <input type="text" id="name" v-model='name'>
      <button @click='handle' :disabled='submitFlag'>提交</button>
     </div>
   </div>
   <div class="total">
     <span>图书总数:</span>
     <span>{{total}}</span>
   </div>
   <table>
     <thead>
       <tr>
        <th>编号</th>
        <th>名称</th>
        <th>时间</th>
        <th>操作</th>
       </tr>
     </thead>
     <tbody>
     <tr :key='item.id' v-for='item in books'>
       <td>{{item.id}}</td>
       <td>{{item.name}}</td>
       <td>{{item.date | format('yyyy-MM-dd hh:mm:ss')}}</td>
       <td>
         <a href="" @click.prevent='toEdit(item.id)'>修改</a>
         <span>|</span>
         <a href="" @click.prevent='deleteBook(item.id)'>删除</a>
       </td>
     </tr>
     </tbody>
   </table>
</div>
<script src="js/vue.js"></script>
<script>
  //自定义指令
  Vue.directive('focus',{
    inserted:function(el){
      el.focus();
    }
  })
  //过滤器(格式化日期)
  Vue.filter('format', function(value, arg) {
      function dataFormat(date, format) {
        if (typeof date === "string") {
          var mts = date.match(/(\/Date\((\d+)\)\/)/);
          if (mts && mts.length >= 3) {
            date = parseInt(mts[2]);
          }
        }
        date = new Date(date);
        if (!date || date.toUTCString() == "Invalid Date") {
          return "";
        }
        var map = {
          "M": date.getMonth() + 1, //月
          "d": date.getDate(), //日
          "h": date.getHours(), //小时
          "m": date.getMinutes(), //分
          "s": date.getSeconds(), //秒
          "q": Math.floor((date.getMonth() + 3) / 3), //季度
          "S": date.getMilliseconds() //毫秒
        };
        format = format.replace(/([yMdhmsqS])+/g, function(all, t) {
          var v = map[t];
          if (v !== undefined) {
            if (all.length > 1) {
              v = '0' + v;
              v = v.substr(v.length - 2);
            }
            return v;
          } else if (t == 'y') {
            return (date.getFullYear() + '').substr(4 - all.length);
          }
          return all;
        });
        return format;
      }
      return dataFormat(value, arg);
    })

    var vm=new Vue({
      el:'#app',
      data:{
       flag:false,
       submitFlag:false,
       id:'',
       name:'',
       books:[]
      },
      methods:{
       handle:function(){
         if(this.flag){
          //修改操作:就是根据当前的id去更新数组中对应的数据
          //箭头函数的this不是window
          //some方法判断什么时候终止循环
          this.books.some((item)=>{
            if(item.id==this.id){
              item.name=item.name;
              //完成更新操作之后,要终止循环
              return true;
            }
          });
          this.flag=false;
         }else{
          //添加操作
          //添加图书
          var book={};
          book.id=this.id;
          book.name=this.name;
          book.date=new Date();
          this.books.push(book);
         }
         //清空表单
         this.id='';
         this.name='';
       },//handle结束
       toEdit:function(id){
         //禁止修改id
         this.flag=true;
         //根据id查询出要编辑的数据
         var book=this.books.filter(function(item){
           return item.id==id;
         });
         //把获取的信息填充到表单
         this.id=book[0].id;
         this.name=book[0].name;
       },//toEdit结束
       deleteBook:function(id){
         //删除图书
         //根据id从数组中查找元素的索引
         var index=this.books.findIndex(function(item){
           return item.id==id;
         });
         //根据索引删除数组元素
         this.books.splice(index,1);

         //方法二:通过filter方法进行删除
         //this.books=this.books.filter(function(item){
          //return item.id!=id;
         //});
       }//deleteBook结束
      },
      computed:{
       total:function(){
         //计算图书的总数
         return this.books.length;
       }
      },//computed结束
      watch:{
       name:function(val){
         //验证图书名称是否已经存在
         var flag=this.books.some(function(item){
          return item.name==val;
         });
         if(flag){
          //图书名称存在
          this.submitFlag=true;
         }else{
          this.submitFlag=false;
         }
       }
      },//watch结束
      mounted:function(){
       //该生命周期钩子函数被触发的时候,模板已经可以使用
       //一般用于获取后台数据,然后把数据填充到模板
       //模拟接口
       var data=[{
         id:1,
         name:'三国演义',
         date:1585609975000
       },{
         id:2,
         name:'水浒传',
         date:1586609975000
       },{
         id:3,
         name:'红楼梦',
         date:1587609975000
       },{
         id:4,
         name:'西游记',
         date:1588609975000
       }];
       this.books=data;
      }
    });
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

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

    Vue.js是当下很火的一个JavaScript MVVM(Model-View-ViewModel)库,它是以数据驱动和组件化的思想构建的.相比于Angular.js,Vue.js提供了更加简洁.更易于理解的API,使得我们能够快速地上手并使用Vue.js. 上一期简单讲解了vue的基本语法,这一次我们做一个小项目,搭建一个简单的图书管理平台,能够让我们更深刻的理解这门语言的妙用. 1.DEMO样式 首先我们需要搭建一个简单的demo样式,推荐大家使用bootstrap,可以很快的搭建出一个清

  • 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="cont

  • vue.js实现图书管理功能

    本文实例为大家分享了vue.js实现图书管理功能的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta

  • 基于Vue实现图书管理功能

    本文实例为大家分享了vue简单的图书管理具体代码,供大家参考,具体内容如下 <table class="table table-bg table-border table-bordered"> <tr> <th>ID</th> <th>书名</th> <th>作者</th> <th>价格</th> <th>操作</th> </tr>

  • Vue实现图书管理小案例

    本文实例为大家分享了Vue实现图书管理的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>

  • Vue实现图书管理案例

    本文实例为大家分享了Vue实现图书管理的具体代码,供大家参考,具体内容如下 案例效果 案例思路 1.图书列表 实现静态列表效果 基于数据实现模板效果 处理每行的操作按钮 2.添加图书 实现表单的静态效果 添加图书表单域数据绑定 添加按钮事件绑定 实现添加业务逻辑 3.修改图书 修改信息填充到表单 修改后重新提交到表单 重用添加和修改方法 4.删除图书 删除按钮绑定时间处理方法 实现删除业务逻辑 5.常用特性应用场景 过滤器(格式化日期) 自定义指令(获取表单焦点) 计算属性(统计图书数量) 侦听

  • Vue实现简单购物车小案例

    本文实例为大家分享了Vue实现简单购物车的具体代码,供大家参考,具体内容如下 HTML首页 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="vi

  • vue实现购物车小案例

    本文实例为大家分享了vue实现购物车小案例的具体代码,供大家参考,具体内容如下 最终效果 HTML部分: <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>shopcar.html</title> <script src="https://cdn.jsdelivr.net/npm/vue&q

  • vue实现选项卡小案例

    本文实例为大家分享了vue实现选项卡小案例的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en">   <head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name=

  • vue.js+boostrap项目实践(案例详解)

    一.为什么要写这篇文章 最近忙里偷闲学了一下vue.js,同时也复习了一下boostrap,发现这两种东西如果同时运用到一起,可以发挥很强大的作用,boostrap优雅的样式和丰富的组件使得页面开发变得更美观和更容易,同时vue.js又是可以绑定model和view(这个相当于MVC中的,M和V之间的关系),使得对数据变换的操作变得更加的简易,简化了很多的逻辑代码. 二.学习这篇文章需要具备的知识 1.需要有vue.js的知识 2.需要有一定的HTML.CSS.JavaScript的基础知识 3

随机推荐