IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> EasyUI项目之订单管理 -> 正文阅读

[JavaScript知识库]EasyUI项目之订单管理

3一、明确目标:
? ? ? ? 1、商家:

? ? ? ? ? ? ? ? ? ? ?1、查看订单(未发货、已发货、已签收、订单项)

? ? ? ? ? ? ? ? ? ? ?2、发货功能(状态:1:未发货、2:已发货、3:已签收、4:已撤单)

? ? ? ? ? ? ? ? ? ? ?3、订单项目查看

实现思路:

? ? ? ? 订单表的查询

? ? ? ? 将订单表的订单状态由1改成2

? ? ? ? 通过订单的id到订单项表查询出对应的订单项

? ? ? ? 2、买家:

? ? ? ? ? ? ? ? ? ? ?1、查看订单(未发货、已发货、已签收)

? ? ? ? ? ? ? ? ? ? ?2、撤单

? ? ? ? ? ? ? ? ? ? ?3、签收

实现思路:

? ? ? ? 订单表的查询

? ? ? ? 将订单表的订单状态由1改成4

? ? ? ? 将订单表的订单状态由2改成3

二、实现代码、思路以及运行效果:

商家

1、商家订单界面(listOrder1.jsp)

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>商家订单页面</title>
    <link rel="stylesheet" type="text/css"
          href="${pageContext.request.contextPath}/static/js/easyui/themes/default/easyui.css">
    <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/static/js/easyui/themes/icon.css">
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.js"></script>
    <script type="text/javascript"
            src="${pageContext.request.contextPath}/static/js/easyui/jquery.easyui.min.js"></script>
    <script src="${pageContext.request.contextPath}/static/js/main.js"></script>
</head>
<body>
<table id="dg" style="style=" width:400px;height:200px;
"></table>
 
<script>
    $(function () {
        $('#dg').datagrid({
            url: '${pageContext.request.contextPath}/order.action?methodName=list&&orderState=1',
            fit: true,
            fitColumns: true,
            pagination: true,
            singleSelect: true,
            columns: [[
                // {field:'id',title:'id',width:100},
                {field: 'id', title: '书籍名称', hidden: true},
                {field: 'postalcode', title: '收货人邮编', hidden: true},
                {field: 'uid', title: '用户', width: 50},
                {field: 'consignee', title: '收货人', width: 50},
                {field: 'phone', title: '手机号', width: 50},
                {field: 'address', title: '收获人地址', width: 50},
                {field: 'orderPrice', title: '价格', width: 50},
                {field: 'sendTime', title: '发货时间', width: 50},
                {field: 'orderTime', title: '订单时间', width: 50},
                {
                    field: 'sendType', title: '发送方式', width: 50, formatter: function (value, row, index) {
                        if (row.sendType == 1) {
                            return "平邮";
                        } else if (row.sendType == 2) {
                            return "快递";
                        }
                    }
                },
                {
                    field: 'orderState', title: '订单状态', width: 100, formatter: function (value, row, index) {
                        if (row.orderState == 1) {
                            return "未发货";
                        } else if (row.orderState == 2) {
                            return "已发货";
                        } else if (row.orderState == 3) {
                            return "已签收";
                        } else if (row.orderState == 4) {
                            return "已撤单";
                        }
                    }
                },
                {
                    field: 'xxxx', title: '操作', width: 100, formatter: function (value, row, index) {
                        return '<a href="#" onclick="sendOrder();">发货</a>';
 
                    }
                }
            ]]
        });
    })
    
    function sendOrder() {
        var row = $('#dg').datagrid('getSelected');
        var id=0;
        if (row) {
            id = row.id;
        }else {
            alert("请勾选数据...");
            return;
        }
        $.messager.confirm('确认', '您确认想要发货吗?', function (r) {
            if (r) {
                $.ajax({
                    url: '${pageContext.request.contextPath}/order.action?methodName=cancelAndReceive&&orderState=2&id='+id,
                    success: function (data) {
                        $('#dg').datagrid('reload');
                    }
                });
            }
        })
    }
</script>
</body>
</html>

2、订单表OrderDao方法

/**
 * 按照订单时间倒叙查询
 * @param order
 * @param pageBean
 * @return
 * @throws Exception
 */
public List<Order> list(Order order, PageBean pageBean) throws Exception {
	// String sql="select * from t_easyui_order order by orderTime desc";
	String sql = "select * from t_easyui_order where 1=1 ";
	long id = order.getId();
	int orderState = order.getOrderState();
	if (id != 0) {//意味着从前台传了订单号
		sql += " and id=" + id;//根据订单id进行查询
		
	}
	//用来根据订单状态分类查询
	if (orderState != 0) {
		sql += " and orderState=" + orderState;//根据订单的状态进行查询
	}
	 //使用sql的时候注意打空格,防止出现sql语句拼接错误
	sql += " order by orderTime desc";
	return super.executeQuery(sql, Order.class, pageBean);
}

3、子控制器OrderAction

package com.zxy.web;

import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.zking.framework.ActionSupport;
import com.zking.framework.ModelDriver;
import com.zking.util.PageBean;
import com.zking.util.R;
import com.zking.util.ResponseUtil;
import com.zxy.dao.OrderDao;
import com.zxy.entity.Order;

public class OrderAction extends ActionSupport implements ModelDriver<Order>{
 
	private Order order = new Order();
	private OrderDao orderDao=new OrderDao();
	
	public Order getModel() {
		return order;
	}
 
	
	public void list(HttpServletRequest req, HttpServletResponse resp) {
		PageBean pageBean = new PageBean();
		pageBean.setRequest(req);
		try {
			List<Order> list=orderDao.list(order, pageBean);
			ResponseUtil.writeJson(resp, new R().data("total",pageBean.getTotal()).data("rows",list));
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
	/**
	 * 关于发货,撤单,签收公用的方法
	 * @param req
	 * @param resp
	 */
	public void cancelAndReceive(HttpServletRequest req, HttpServletResponse resp) {
	//order就已经包含了,将要修改的状态以及对应的订单id
		try {
		orderDao.editState(order);
		ResponseUtil.writeJson(resp, 1);
	} catch (Exception e) {
		e.printStackTrace();
		try {
			ResponseUtil.writeJson(resp, 0);
		} catch (Exception e1) {
			e1.printStackTrace();
		}
	}
	}
}

4、配置MVC.xml

<action type="com.zxy.web.OrderAction" path="/order">
</action>

商家展示

未发货:

已发货:

三.订单项查看

1、订单项页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>商家订单页面</title>
    <link rel="stylesheet" type="text/css"
          href="${pageContext.request.contextPath}/static/js/easyui/themes/default/easyui.css">
    <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/static/js/easyui/themes/icon.css">
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.js"></script>
    <script type="text/javascript"
            src="${pageContext.request.contextPath}/static/js/easyui/jquery.easyui.min.js"></script>
    <script src="${pageContext.request.contextPath}/static/js/main.js"></script>
</head>
<body>
<table id="dg" style="style=" width:400px;height:200px;
"></table>
<div id="tb">
    <input class="easyui-textbox" id="oid" name="oid" style="width:20%;padding-left: 10px" data-options="label:'订单号:',required:true">
    <a id="btn-search" href="#" class="easyui-linkbutton" data-options="iconCls:'icon-search'">搜索</a>
</div>

<script>

    $(function () {
        $("#btn-search").click(function () {
            $('#dg').datagrid('load', {
                oid: $("#oid").val()
            });
        });

        $('#dg').datagrid({
            url: '${pageContext.request.contextPath}/orderItem.action?methodName=list',
            fit: true,
            fitColumns: true,
            pagination: true,
            singleSelect: true,
            toolbar:'#tb',
            columns: [[
                // {field:'id',title:'id',width:100},
                {field: 'id', title: '订单项流水号', hidden: true},
                {field: 'oid', title: '订单号', width: 50},
                {field: 'bid', title: '书籍名称', width: 50},
                {field: 'quantity', title: '数量', width: 50}
            ]]
        });
    })
    
</script>
</body>
</html>

?2、订单项OrderItemDao方法

/**
	 * 通过外键的订单id查询订单项
	 * @param orderItem
	 * @param pageBean
	 * @return
	 * @throws Exception
	 */
	public List<OrderItem> list(OrderItem orderItem, PageBean pageBean) throws Exception {
    String sql = "select * from t_easyui_orderItem where 1=1";
    //oid是订单项的外键,关联了订单表的主键
    long oid=orderItem.getOid();
    if(oid != 0) {
    	sql += " and oid ="+oid;
    }
    return super.executeQuery(sql,OrderItem.class, pageBean);
	}

3、子控制器OrderItemAction

package com.zxy.web;

import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.zking.framework.ActionSupport;
import com.zking.framework.ModelDriver;
import com.zking.util.PageBean;
import com.zking.util.R;
import com.zking.util.ResponseUtil;
import com.zxy.dao.OrderItemDao;
import com.zxy.entity.OrderItem;

public class OrderItemAction extends ActionSupport implements ModelDriver<OrderItem>{
   private OrderItem orderItem = new OrderItem();
   private OrderItemDao orderItemDao = new OrderItemDao();
   
	
	public OrderItem getModel() {
		return orderItem;
	}
 
		public String list(HttpServletRequest req, HttpServletResponse resp) {
			PageBean pageBean =new PageBean();
			pageBean.setRequest(req);
			try {
				List<OrderItem> list=orderItemDao.list(orderItem, pageBean);
				ResponseUtil.writeJson(resp, new R().data("total",pageBean.getTotal()).data("rows",list));
 
			} catch (Exception e) {
				e.printStackTrace();
			}
			return super.execute(req, resp);
		}
}

4、配置mvc.xml

<action type="com.zxy.web.OrderItemAction" path="/orderItem">
</action>

订单项展示:

四.买家功能(同上代码)

??查看订单(未发货、已发货、已签收)、撤单、签收的整体思路:

?这三个功能和商家的思路和代码都是一样的,查看订单都是调用查询方法,撤单、签收功能是调用了改变订单状态的方法。

1.查看订单运行效果

未发货:

?已发货:

?已签收:

?撤单功能:

撤单后:?

?签收功能:

点击ok 签收完之后,买家的已签收界面就会多一条数据,而已发货界面原有的订单就会消失

到此结束~~~~~~~~~~~~~~

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-11 17:25:59  更:2021-10-11 17:27:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 20:54:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码