MyChat.vue 3.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
<template>
  <div>
    <el-container>
      <el-header style="text-align: right; font-size: 12px">
        <i class="el-icon-refresh header-button-item" @click="refreshPage"></i>
        <el-dropdown>
          <i class="el-icon-setting header-button-item"></i>
          <el-dropdown-menu slot="dropdown">
            <el-dropdown-item>新增</el-dropdown-item>
          </el-dropdown-menu>
        </el-dropdown>
        <span class="header-button-item">kwan</span>
      </el-header>

      <el-main>
        <el-table :data="userlist" v-loading="loading">
          <el-table-column prop="id" label="序号" width="50"></el-table-column>
          <el-table-column
            prop="question"
            label="问题"
            width="240"
          ></el-table-column>
          <el-table-column prop="response" label="答案"></el-table-column>
          <el-table-column label="创建时间" width="170">
            <template slot-scope="props">
              {{ props.row.createTime | dateFormat }}
            </template>
          </el-table-column>
          <el-table-column prop="详情" label="详情" width="100">
            <template slot-scope="props">
              <a href="#" @click.prevent="gotoDetail(props.row.id)">详情</a>
            </template>
          </el-table-column>
        </el-table>
        <el-pagination
          class="pagination"
          background
38 39
          :key="elementui_page_component_key"
          :current-page.sync="currentPage"
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
          :page-size="pageSize"
          :total="total"
          @current-change="handleCurrentChange"
        ></el-pagination>
      </el-main>
    </el-container>
  </div>
</template>

<script>
import axios from "axios";
export default {
  name: "MyChat",

  data() {
    return {
      // 用户列表数据
      userlist: [],
      loading: false,
59 60
      elementui_page_component_key: 0,
      currentPage: Number(localStorage.getItem("lastPage")) || 1,
61 62 63 64 65 66 67 68 69
      pageSize: 5,
      total: 0,
    };
  },

  created() {
    // 调用请求数据的方法
    this.initCartList();
  },
70
  mounted() {
71 72
    this.currentPage = Number(localStorage.getItem("lastPage")) || 1;
    this.elementui_page_component_key++;
73
  },
74 75 76 77 78 79 80 81 82 83 84
  methods: {
    refreshPage() {
      location.reload();
    },
    gotoDetail(id) {
      this.$router.push("/home/chatinfo/" + id);
    },

    async initCartList() {
      this.loading = true;
      const { data: res } = await axios.get(
85
        "http://120.79.36.53:8888/chatbot/page",
86 87 88 89 90 91 92 93 94 95
        {
          params: {
            page: this.currentPage,
            pageSize: this.pageSize,
          },
        }
      );
      if (res.code === 200) {
        this.userlist = res.result.records;
        this.total = res.result.total;
96
        localStorage.setItem("lastPage", this.currentPage);
97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
      }
      this.loading = false;
    },

    handleCurrentChange(currentPage) {
      this.currentPage = currentPage;
      this.initCartList();
    },
  },
};
</script>

<style lang="less" scoped>
.el-header {
  background-color: #b3c0d1;
  color: #333;
  line-height: 60px;
}

.el-aside {
  color: #333;
}

.pagination {
  margin-top: 16px;
  text-align: right;
}
.header-button-item {
  margin-right: 15px;
  font-size: 20px;
}
128
</style>