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


Posted in Javascript onFebruary 10, 2017

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

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-select的插件,可以完美兼容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。

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

Javascript 相关文章推荐
jQuery提示效果代码分享
Nov 20 Javascript
浅谈jQuery.easyui的datebox格式化时间
Jun 25 Javascript
基于jQuery实现鼠标点击导航菜单水波动画效果附源码下载
Jan 06 Javascript
javascript面向对象程序设计高级特性经典教程(值得收藏)
May 19 Javascript
微信小程序 页面传参实例详解
Nov 16 Javascript
详解Vue.js动态绑定class
Dec 20 Javascript
React Native react-navigation 导航使用详解
Dec 01 Javascript
vue2.0实现音乐/视频播放进度条组件
Jun 06 Javascript
在vue中多次调用同一个定义全局变量的实例
Sep 25 Javascript
vue在自定义组件中使用v-model进行数据绑定的方法
Mar 25 Javascript
解决vue v-for src 图片路径问题 404
Nov 12 Javascript
javascript设计模式 ? 享元模式原理与用法实例分析
Apr 15 Javascript
基于jQuery实现弹幕APP
Feb 10 #Javascript
BOM之navigator对象和用户代理检测
Feb 10 #Javascript
基于JQuery及AJAX实现名人名言随机生成器
Feb 10 #Javascript
jQuery基于ajax方式实现用户名存在性检查功能示例
Feb 10 #Javascript
jQuery基于ajax实现页面加载后检查用户登录状态的方法
Feb 10 #Javascript
javascript自执行函数
Feb 10 #Javascript
完美解决jQuery的hover事件在IE中不停闪动的问题
Feb 10 #Javascript
You might like
Zend Studio 无法启动的问题解决方法
2008/12/04 PHP
基于PHP输出缓存(output_buffering)的深入理解
2013/06/13 PHP
Yii学习总结之数据访问对象 (DAO)
2015/02/22 PHP
PHP的Json中文处理解决方案
2016/09/29 PHP
PHP排序算法之基数排序(Radix Sort)实例详解
2018/04/21 PHP
JavaScript DOM 学习第三章 内容表格
2010/02/19 Javascript
Confirmer JQuery确认对话框组件
2010/06/09 Javascript
JS和jquery获取各种屏幕的宽度和高度的代码
2013/08/02 Javascript
qq悬浮代码(兼容各个浏览器)
2014/01/29 Javascript
JQuery右键菜单插件ContextMenu使用指南
2014/12/19 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
详解Bootstrap的iCheck插件checkbox和radio
2016/08/24 Javascript
javascript判断firebug是否开启的方法
2016/11/23 Javascript
JS实现的DIV块来回滚动效果示例
2017/02/07 Javascript
VUE多层路由嵌套实现代码
2017/05/15 Javascript
微信小程序获取微信运动步数的实例代码
2017/07/20 Javascript
Bootstrap Table 在指定列中添加下拉框控件并获取所选值
2017/07/31 Javascript
jQuery菜单实例(全选,反选,取消)
2017/08/28 jQuery
JS实现table表格内针对某列内容进行即时搜索筛选功能
2018/05/11 Javascript
js实现内置计时器
2019/12/16 Javascript
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
微信小程序返回上一级页面的实现代码
2020/06/19 Javascript
Python2.x版本中maketrans()方法的使用介绍
2015/05/19 Python
Python使用struct处理二进制的实例详解
2017/09/11 Python
基于python实现简单日历
2018/07/28 Python
在Python中分别打印列表中的每一个元素方法
2018/11/07 Python
Python实现字符型图片验证码识别完整过程详解
2019/05/10 Python
Python绘制频率分布直方图的示例
2019/07/08 Python
python3中关于excel追加写入格式被覆盖问题(实例代码)
2020/01/10 Python
python3通过subprocess模块调用脚本并和脚本交互的操作
2020/12/05 Python
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
AmazeUI 缩略图的实现示例
2020/08/18 HTML / CSS
英国最大的化装舞会服装网站:Fancydress.com
2017/08/15 全球购物
2015年党支部书记工作总结
2015/05/21 职场文书
2016国庆节活动宣传语
2015/11/25 职场文书
css display table 自适应高度、宽度问题的解决
2021/05/07 HTML / CSS