zoukankan      html  css  js  c++  java
  • 前后端分离开发vue+Elementyui+abpcorewebapi商城管理系统(十二)订单列表页面

    功能分析

    效果图

    接口定义

     

    代码orders/Order.vue

    <template>
      <div>
        <el-breadcrumb separator-class="el-icon-arrow-right">
          <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
          <el-breadcrumb-item>订单管理</el-breadcrumb-item>
          <el-breadcrumb-item>订单列表</el-breadcrumb-item>
        </el-breadcrumb>
    
        <el-card>
          <el-row :gutter="20">
            <el-col :span="8">
              <el-input
                placeholder="请输入内容"
                clearable
                v-model="queryInfo.query"
                @clear="getOrderList"
              >
                <el-button
                  slot="append"
                  icon="el-icon-search"
                  @click="
                    handleCurrentChange(1);
                    getOrderList;
                  "
                ></el-button>
              </el-input>
            </el-col>
          </el-row>
    
          <el-table :data="orderlist" stripe border style=" 100%">
            <el-table-column type="index"> </el-table-column>
            <el-table-column prop="order_number" label="订单编号"></el-table-column>
            <el-table-column prop="order_price" label="订单价格"></el-table-column>
            <el-table-column label="是否付款">
              <template v-slot="scope">
                <el-tag type="success" v-if="scope.row.pay_status === '1'"
                  >已付款</el-tag
                >
                <el-tag type="warning" v-if="scope.row.pay_status === '0'"
                  >未付款</el-tag
                >
              </template>
            </el-table-column>
            <el-table-column prop="is_send" label="是否发货"></el-table-column>
            <el-table-column label="下单时间">
              <template v-slot="scope">
                {{ scope.row.create_time | dateFormat }}
              </template>
            </el-table-column>
            <el-table-column label="操作" width="130px">
              <template>
                <el-button
                  size="mini"
                  type="primary"
                  icon="el-icon-edit"
                  @click="showBox"
                ></el-button>
                <el-button
                  size="mini"
                  type="warning"
                  icon="el-icon-location"
                  @click="showProgressBox"
                ></el-button>
              </template>
            </el-table-column>
          </el-table>
    
          <el-pagination
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
            :current-page="queryInfo.pagenum"
            :page-sizes="[5, 15, 20]"
            :page-size="queryInfo.pagesize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
            background
          >
          </el-pagination>
        </el-card>
    
        <el-dialog title="修改地址" :visible.sync="addressVisible" width="50%">
          <el-form
            ref="addressFormRef"
            :model="addressForm"
            :rules="addressFormRules"
            @close="addressDialogClosed"
            label-width="100px"
          >
            <el-form-item label="省市区/县" prop="address1">
              <el-cascader :options="cityDate" v-model="addressForm.address1">
              </el-cascader>
            </el-form-item>
            <el-form-item label="详细地址" prop="address2">
              <el-input v-model="addressForm.address2" placeholder=""></el-input>
            </el-form-item>
          </el-form>
          <div slot="footer">
            <el-button @click="addressVisible = false">取 消</el-button>
            <el-button type="primary" @click="addressVisible = false"
              >确 定</el-button
            >
          </div>
        </el-dialog>
    
        <el-dialog
          title="物流进度"
          :visible.sync="progressVisible"
          width="50%">
          <el-timeline>
            <el-timeline-item
              v-for="(activity, index) in progressInfo"
              :key="index"
              :timestamp="activity.time">
              {{activity.context}}
            </el-timeline-item>
          </el-timeline>
          <div slot="footer">
            <el-button @click="progressVisible = false">取 消</el-button>
            <el-button type="primary" @click="progressVisible = false">确 定</el-button>
          </div>
        </el-dialog>
      </div>
    </template>
    
    <script>
    import cityDate from "./citydata.js";
    
    export default {
      data() {
        return {
          queryInfo: {
            query: "",
            pagenum: 1,
            pagesize: 10
          },
          orderlist: [],
          total: 0,
          addressVisible: false,
          addressForm: {
            address1: [],
            address2: ""
          },
          addressFormRules: {
            address1: [
              { required: true, message: "请选择省市区/县", trigger: "blur" }
            ],
            address2: [
              { required: true, message: "请输入详细地址", trigger: "blur" }
            ]
          },
          cityDate,
          progressVisible:false,
          progressInfo:[]
        };
      },
      methods: {
        async getOrderList() {
          const { data } = await this.$http.get("orders", {
            params: this.queryInfo
          });
          if (data.meta.status !== 200) {
            return this.$message.error(data.meta.msg);
          }
          this.orderlist = data.data.goods;
          this.total = data.data.total;
        },
        handleSizeChange(newSize) {
          this.queryInfo.pagesize = newSize;
          this.getOrderList();
        },
        handleCurrentChange(newPage) {
          this.queryInfo.pagenum = newPage;
          this.getOrderList();
        },
        showBox() {
          this.addressVisible = true;
        },
        addressDialogClosed() {
          this.$refs.addressFormRef.resetFields();
        },
        async showProgressBox() {
          const {data} = await this.$http.get('/kuaidi/804909574412544580')
          if (data.meta.status !== 200) {
            return this.$message.error(data.meta.msg);
          }
          this.progressInfo = data.data
          this.progressVisible = true
        }
      },
      created() {
        this.getOrderList();
      }
    };
    </script>
    
    <style lang="less" scoped>
    .el-cascader {
       100%;
    }
    </style>
  • 相关阅读:
    使用jquery的get,ajax,post三种方式实现ajax效果
    在javascript中Json字符串的解析
    (转)C#发送邮件及附件
    jQuery的combobox绑定失去焦点blur事件
    windows2008R2 x64位架设IIS7.x的支持SQLServer2008的PHP服务器
    PyCharm的几个常用设置
    转: 震惊小伙伴的单行代码 Python篇
    virtualBox安装Ubuntu16.4遇到的问题解决办法
    PHP里面把16进制的图片数据显示在html的img标签上
    转:Python:sitecustomize 和 usercustomize
  • 原文地址:https://www.cnblogs.com/xiewenyu/p/13110501.html
Copyright © 2011-2022 走看看