欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

基于jQuery实现咖啡订单管理简单应用

程序员文章站 2023-01-15 14:17:36
这款应用主要实现以下几个功能: 1.在表格中输入客户姓名并选择咖啡,点击“add”能够把数据传至table。 2.table的每生成一行新数据,其status列都会出现...

这款应用主要实现以下几个功能:

1.在表格中输入客户姓名并选择咖啡,点击“add”能够把数据传至table。
2.table的每生成一行新数据,其status列都会出现一个小咖啡图标,表示正在制作中。
3.点击这个小咖啡图标,可以变成一个绿色的勾勾,表示该订单已经完成。
4.点击export可以把表格数据导出为csv文件。

html:

<div class="container-fluid"> 
    <h1>coffee orders</h1> 
    <hr> 
    <div class="row"> 
      <!-- order form --> 
      <div class="col-xs-4 col-sm-4 col-md-4 col-lg-4 order-form"> 
        <form class="form-inline" role="form"> 
          <div class="form-group"> 
            <div class="input-group"> 
              <div class="input-group-addon"><i class="fa fa-user" aria-hidden="true"></i></div> 
              <input type="text" class="form-control order-name" id="name" required="required" placeholder="name"> 
            </div> 
            <select class="selectpicker" id="drink"> 
              <option>latte</option> 
              <option>moccha</option> 
              <option>cappuchino</option> 
              <option>fat white</option> 
            </select> 
          </div> 
          <button type="button" class="btn btn-primary add-order">add</button> 
          <button type="reset" class="btn btn-primary pull-right">reset</button> 
        </form> 
      </div> 
      <!-- order list --> 
      <div class="col-xs-8 col-sm-8 col-md-8 col-lg-8 order-list"> 
        <table class="table table-hover"> 
          <thead> 
            <tr> 
              <th>name</th> 
              <th>order</th> 
              <th>status</th> 
            </tr> 
          </thead> 
          <tbody></tbody> 
        </table> 
        <div> 
          <a class="pull-right export" data-export="export">export to csv</a> 
        </div> 
      </div> 
    </div> 
    <hr> 
    <div class="time"> 
      order list of <span class="today"></span> 
    </div> 
  </div> 
  <footer> 
    designed by <a href="http://blog.csdn.net/alenhhy" rel="external nofollow" target="_blank">alen hu</a> 
  </footer> 

*使用了bootstrap3框架
*选择咖啡的部分,我使用了一款叫的插件,可以完美兼容bootstrap的ui,但是写css的时候要注意一下,得通过浏览器f12查看dom后,方可根据dom来写,否则直接写select和option是没用的。

jquery:

$(document).ready(function() { 
 
 var $order = $("tbody"); 
 var $add = $(".add-order"); 
 var $name = $("#name"); 
 var $drink = $("#drink"); 
 
 //add new data to table 
 function addtotable() { 
  if ($name.val()) { 
   $order.append('<tr><td class="customer-name">' + $name.val() + '</td><td class="customer-order">' + $drink.val() + '</td><td class="customer-status"><i class="fa fa-coffee" aria-hidden="true"></i></td></tr>'); 
   $name.val(""); 
  } else {} 
 } 
 
 $add.on("click", addtotable); 
 $("form").keypress(function(event) { 
  if (event.keycode === 13) { 
   event.preventdefault(); 
   addtotable(); 
  } 
 }); 
 
 //click to tick 
 $order.delegate('.customer-status > i', 'click', 
 function() { 
  $(this).parent().html('<i class="fa fa-check" aria-hidden="true"></i>'); 
 }); 
 
 //date 
 var mydate = new date(); 
 var day = mydate.getdate(); 
 var month = mydate.getmonth() + 1; 
 var year = mydate.getfullyear(); 
 
 function pluszero(x) { 
  if (x < 10) { 
   x = "0" + x; 
  } else { 
   x = x; 
  } 
  return x; 
 } 
 
 var today = pluszero(day) + "." + pluszero(month) + "." + year; 
 $(".today").text(today); 
 
 //export table data to csv 
 $(".export").click(function() { 
  $(".table").tabletocsv(); 
 }); 
 
}); 

*导出为csv的这个功能我使用到了一个叫tabletocsv的插件,用法和源代码可以点击链接进去看看。但是这款插件功能比较单一,真的就是只能导出csv,不能选择导出哪部分内容,也无法指定文件名称等等,如果你有什么更好的相关插件,欢迎来分享啦~

这里只是简单的做了一下这款应用的表面效果,没有做数据交换方面的事情。
创建json文件,使用ajax(get,post,delete,post...)可以储存相关数据。

demo在这里,欢迎fork。

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