{"id":749,"date":"2024-12-10T20:40:19","date_gmt":"2024-12-10T12:40:19","guid":{"rendered":"https:\/\/eve2333.top\/?p=749"},"modified":"2024-12-10T20:40:19","modified_gmt":"2024-12-10T12:40:19","slug":"%e9%9d%9e%e5%b8%b8%e7%ae%80%e5%8d%95%e5%ae%9e%e7%94%a8%e7%9a%84%e5%89%8d%e5%90%8e%e7%ab%af%e5%88%86%e7%a6%bb%e9%a1%b9%e7%9b%ae-%e4%bb%93%e5%ba%93%e7%ae%a1%e7%90%86%e7%b3%bb%e7%bb%9f%ef%bc%88springbo-4","status":"publish","type":"post","link":"https:\/\/eve2333.top\/?p=749","title":{"rendered":"\u975e\u5e38\u7b80\u5355\u5b9e\u7528\u7684\u524d\u540e\u7aef\u5206\u79bb\u9879\u76ee-\u4ed3\u5e93\u7ba1\u7406\u7cfb\u7edf\uff08Springboot+Vue\uff09part 4"},"content":{"rendered":"\n<h1 class=\"wp-block-heading\">\u4e09\u5341\u4e09\u3001\u51fa\u5165\u5e93\u7ba1\u7406<\/h1>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"561\" src=\"https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-1024x561.png\" alt=\"\" class=\"wp-image-750\" srcset=\"https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-1024x561.png 1024w, https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-300x164.png 300w, https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-768x421.png 768w, https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-1536x842.png 1536w, https:\/\/eve2333.top\/wp-content\/uploads\/2024\/12\/1733834401-\u5c4f\u5e55\u622a\u56fe-2024-12-10-203956-2048x1122.png 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p>&nbsp;Header.vue\u5bfc\u4e00\u4e0b,RecordController\u52a0\u4e00\u4e2a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code> \/\/\u5c06\u5165\u5e93\u6570\u636e\u548c\u539f\u6709\u6570\u636e\u76f8\u52a0\u5427\n    \/\/\u65b0\u589e\n    @PostMapping(\"\/save\")\n    public Result save(@RequestBody Record record) {\n        return recordService.save(record) ? Result.success() : Result.fail();\n    }<\/code><\/pre>\n\n\n\n<p>GoodsManage.vue<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u7269\u54c1\u540d:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in storageData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-select v-model=\"goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in goodstypeData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\"&gt;\u65b0\u589e&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" style=\"margin-left:5px;\" @click=\"inGoods\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n              highlight-current-row\n              @current-change=\"selectCurrentChange\"\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u7269\u54c1\u540d\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"storage\" label=\"\u4ed3\u5e93\" :formatter=\"formatStorage\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"goodstype\" label=\"\u5206\u7c7b\" :formatter=\"formatGoodsType\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"count\" label=\"\u6570\u91cf\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"remark\" label=\"\u5907\u6ce8\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"operate\" label=\"\u64cd\u4f5c\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-button size=\"small\" type=\"success\" @click=\"mod(scope.row)\"&gt;\u7f16\u8f91&lt;\/el-button&gt;\n          &lt;el-popconfirm\n              title=\"\u786e\u5b9a\u5220\u9664\u5417\uff1f\"\n              @confirm=\"del(scope.row.id)\"\n              style=\"margin-left:8px;\"\n          &gt;\n            &lt;el-button slot=\"reference\" size=\"small\" type=\"danger\"&gt;\u5220\u9664&lt;\/el-button&gt;\n          &lt;\/el-popconfirm&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u63d0\u793a\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u4ed3\u5e93\" prop=\"storage\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in storageData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5206\u7c7b\" prop=\"goodstype\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in goodstypeData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n\n    &lt;el-dialog\n        title=\"\u63d0\u793a\"\n        :visible.sync=\"inDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form1\" :rules=\"rules1\" :model=\"form1\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.goodsname\" readonly&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form1.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"inDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"doInGoods\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\nexport default {\n  name: \"GoodsManage\",\n  data() {\n    let checkCount = (rule, value, callback) =&gt; {\n      if (value &gt; 9999) {\n        callback(new Error('\u6570\u91cf\u8f93\u5165\u8fc7\u5927'));\n      } else {\n        callback();\n      }\n    };\n    return {\n      user: JSON.parse(sessionStorage.getItem('CurUser')),\n      storageData: &#91;],\n      tableData: &#91;],\n      goodstypeData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      storage: '',\n      goodstype: '',\n      total: 0,\n      name: '',\n      centerDialogVisible: false,\n      inDialogVisible: false,\n      currentRow: {},\n      form: {\n        id: '',\n        name: '',\n        remark: '',\n        count: '',\n        storage: '',\n        goodstype: '',\n      },\n      form1: {\n        goods: '',\n        goodsname: '',\n        userid: '13',\n        adminId: '',\n        remark: ''\n      },\n      rules1: {},\n      rules: {\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u7269\u54c1\u540d', trigger: 'blur'},\n        ],\n        storage: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u4ed3\u5e93', trigger: 'blur'}\n        ],\n        goodstype: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u5206\u7c7b\u2019\uff0ctrigger:\u2018blur'}\n        ],\n        count: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u6570\u91cf', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,4}$\/, message: '\u6570\u91cf\u5fc5\u987b\u4e3a\u6b63\u6574\u6570', trigger: \"blur\"},\n          {validator: checkCount, trigger: 'blur'}\n        ]\n      }\n    }\n  },\n  methods: {\n    selectCurrentChange(val) {\n      this.currentRow = val;\n    },\n    formatStorage(row) {\n      let temp = this.storageData.find(item =&gt; {\n        return item.id === row.storage\n      })\n      return temp &amp;&amp; temp.name\n    },\n    formatGoodsType(row) {\n      let temp = this.goodstypeData.find(item =&gt; {\n        return item.id === row.goodstype\n      })\n      return temp &amp;&amp; temp.name\n    },\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n        this.form.id = ''\n      })\n    },\n    inGoods() {\n      if (!this.currentRow.id) {\n        alert('\u8bf7\u9009\u62e9\u8bb0\u5f55');\n        return;\n      }\n      this.inDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetInForm()\n\n      })\n      this.form1.goodsname = this.currentRow.name\n      this.form1.goods = this.currentRow.id\n      this.form1.adminId = this.user.id\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.remark = row.remark;\n        this.form.name = row.name;\n        this.form.storage = row.storage;\n        this.form.goodstype = row.goodstype;\n        this.form.count = row.count;\n      })\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/goods\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    resetForm() {\n      \/\/this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n      \/\/this.form.id = '';\n    },\n    resetInForm() {\n      this.$refs.form1.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/goods\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/goods\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/goods\/listPage', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          goodstype: this.goodstype + '',\/\/string\u548cint\u5f3a\u8f6c\u4e00\u4e0b\n          storage: this.storage + ''\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadStorage() {\n      this.$axios.get(this.$httpUrl + '\/storage\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.storageData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadGoodsType() {\n      this.$axios.get(this.$httpUrl + '\/goodstype\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.goodstypeData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.storage = ''\n      this.goodstype = ''\n    },\n    doInGoods() {\n      this.$axios.post(this.$httpUrl + '\/record\/save', this.form1).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.inDialogVisible = false\n          this.loadPost();\n          this.resetInForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    this.loadStorage()\n    this.loadGoodsType()\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>1. \u8868\u91cc\u6ca1\u6709\u64cd\u4f5c\u65f6\u95f4\u7684\uff0c\u6309\u6211\u8bf4\u7684\u6765\u505a\uff0c\u6570\u636e\u5e93\u91cc\u9762\u7c7b\u578b\u4fee\u6539\u4e3atimestamp\uff0c\u9ed8\u8ba4\u90a3\u91cc\u518d\u52a0\u4e0aCURRENT_TIMESTAMP\u8fd9\u4e2a\u9ed8\u8ba4\u503c,<\/p>\n\n\n\n<p>2.\u6ca1\u6709\u65f6\u95f4\u7684\u76f4\u63a5\u6539\u6210`createtime` TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '\u64cd\u4f5c\u65f6\u95f4' ON UPDATE CURRENT_TIMESTAMP<\/p>\n\n\n\n<p>3.\u64cd\u4f5c\u65f6\u95f4\u4e3a\u7a7a\u7684\u641c\u4e00\u4e0bmybaitsplus\u7684\u6ce8\u89e3@TableField\uff0c\u52a0\u5728\u5b9e\u4f53\u7c7b\u91cc<\/p>\n\n\n\n<p>\u65b9\u6cd5\u9009\u4e00\u4e2a\u5373\u53ef&nbsp;<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>CREATE TABLE `record` (\n  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '\u4e3b\u952e',\n  `goods` int(11) NOT NULL COMMENT '\u8d27\u54c1id',\n  `userId` int(11) DEFAULT NULL COMMENT '\u53d6\u8d27\u4eba\/\u8865\u8d27\u4eba',\n  `admin_id` int(11) DEFAULT NULL COMMENT '\u64cd\u4f5c\u4ebaid',\n  `count` int(11) DEFAULT NULL COMMENT '\u6570\u91cf',\n  `createtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '\u64cd\u4f5c\u65f6\u95f4',\n  `remark` varchar(1000) DEFAULT NULL COMMENT '\u5907\u6ce8',\n  PRIMARY KEY (`id`)\n) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;<\/code><\/pre>\n\n\n\n<p>\u8fdb\u4e00\u6b65\u8865\u5145goods\u7684\u76f8\u5173\u65b9\u6cd5<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>package com.wms.controller;\n\n\nimport com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;\nimport com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;\nimport com.baomidou.mybatisplus.core.metadata.IPage;\nimport com.baomidou.mybatisplus.core.toolkit.StringUtils;\nimport com.baomidou.mybatisplus.extension.plugins.pagination.Page;\nimport com.wms.common.QueryPageParam;\nimport com.wms.common.Result;\nimport com.wms.entity.Goods;\nimport com.wms.entity.Record;\nimport com.wms.service.GoodsService;\nimport com.wms.service.RecordService;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestMapping;\n\nimport org.springframework.web.bind.annotation.RestController;\n\nimport java.util.HashMap;\n\n\/**\n * &lt;p&gt;\n * \u524d\u7aef\u63a7\u5236\u5668\n * &lt;\/p&gt;\n *\n * @author wms\n * @since 2024-12-07\n *\/\n@RestController\n@RequestMapping(\"\/record\")\npublic class RecordController {\n    @Autowired\n    private RecordService recordService;\n\n    @Autowired\n    private GoodsService goodsService;\n\n    @PostMapping(\"\/listPage\")\n    public Result listPage(@RequestBody QueryPageParam query) {\n        HashMap param = query.getParam();\n        String name = (String) param.get(\"name\");\n        String storage = (String) param.get(\"storage\");\n        String goodstype = (String) param.get(\"goodstype\");\n\n        Page&lt;Record&gt; page = new Page();\n        page.setCurrent(query.getPageNum());\n        page.setSize(query.getPageSize());\n\n        QueryWrapper&lt;Record&gt; queryWrapper = new QueryWrapper();\n        queryWrapper.apply(\" a.goods=b.id and b.storage=c.id and b.goodsType=d.id \");\n        if (StringUtils.isNotBlank(name) &amp;&amp; !\"null\".equals(name)) {\n            \/\/lambdaQueryWrapper.like(Record::getName, name);\n            queryWrapper.like(\"b.name\", name);\n        }\n        if (StringUtils.isNotBlank(storage) &amp;&amp; !\"null\".equals(storage)) {\n            queryWrapper.eq(\"c.id\", storage);\n        }\n        if (StringUtils.isNotBlank(goodstype) &amp;&amp; !\"null\".equals(goodstype)) {\n            queryWrapper.eq(\"d.id\", goodstype);\n        }\n\n        IPage result = recordService.pageCC(page, queryWrapper);\n        return Result.success(result.getRecords(), result.getTotal());\n    }\n\n    \/\/\u5c06\u5165\u5e93\u6570\u636e\u548c\u539f\u6709\u6570\u636e\u76f8\u52a0\u5427\n    \/\/\u65b0\u589e\n    @PostMapping(\"\/save\")\n\n    public Result save(@RequestBody Record record) {\n        Goods goods = goodsService.getById(record.getGoods());\n        int n = record.getCount();\n        int num = goods.getCount() + n;\n        goods.setCount(num);\n        goodsService.updateById(goods);\n        return recordService.save(record) ? Result.success() : Result.fail();\n    }\n}\n<\/code><\/pre>\n\n\n\n<p>&nbsp;\u53ef\u4ee5\u5b9e\u73b0\u521d\u6b65\u529f\u80fd<\/p>\n\n\n\n<p>Record\u52a0\u4e00\u53e5<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">@TableField(exist=false)\nprivate String action;<\/pre>\n\n\n\n<p>&nbsp;RecordController\u6dfb\u52a0\u51fa\u5e93\u76f8\u5173\u7684\u5185\u5bb9<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code> \/\/\u5c06\u5165\u5e93\u6570\u636e\u548c\u539f\u6709\u6570\u636e\u76f8\u52a0\u5427\n    \/\/\u65b0\u589e\n    @PostMapping(\"\/save\")\n\n    public Result save(@RequestBody Record record) {\n        Goods goods = goodsService.getById(record.getGoods());\n        int n = record.getCount();\n        \/\/\u51fa\u5e93\n        if(\"2\".equals(record.getAction())) {\n            n = -n;\n            record.setCount(n);\n        }\n\n        int num = goods.getCount() + n;\n        goods.setCount(num);\n        goodsService.updateById(goods);\n        return recordService.save(record) ? Result.success() : Result.fail();\n    }<\/code><\/pre>\n\n\n\n<p>&nbsp;SelectUser.vue<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u540d\u5b57:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"sex\" filterableplacehoLder=\"\u8bf7\u9009\u62e9\u6027\u522b\" style=\"margin-left:5px\"&gt;\n        &lt;el-option\n            v-for=\"item in sexs\"\n            :key=\"item.value\"\n            :label=\"item.label\"\n            :value=\"item.value\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;!--&lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\"&gt;\u65b0\u589e&lt;\/el-button&gt;--&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n              highlight-current-row\n              @current-change=\"selectCurrentChange\"\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"no\" label=\"\u8d26\u53f7\" width=\"150\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u59d3\u540d\" width=\"120\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"age\" label=\"\u5e74\u9f84\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"sex\" label=\"\u6027\u522b\" width=\"80\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.sex === 1 ?'primary':'success'\"\n              disable-transitions&gt;{{ scope.row.sex === 1 ? '\u7537' : '\u5973' }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"roleId\" label=\"\u89d2\u8272\" width=\"120\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.roleId === 0 ?'danger':(scope.row.roleId === 1 ?'primary':'success')\"\n              disable-transitions&gt;\n            {{ scope.row.roleId === 0 ? '\u8d85\u7ea7\u7ba1\u7406\u5458' : (scope.row.roleId === 1 ? '\u7ba1\u7406\u5458' : '\u7528\u6237') }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"phone\" label=\"\u7535\u8bdd\" &gt;\n      &lt;\/el-table-column&gt;\n\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u63d0\u793a\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u8d26\u53f7\" prop=\"no\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.no\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5bc6\u7801\" prop=\"password\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.password\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u540d\u5b57\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5e74\u9f84\" prop=\"age\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.age\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6027\u522b\"&gt;\n          &lt;el-radio-group v-model=\"form.sex\"&gt;\n            &lt;el-radio label=\"1\"&gt;\u7537&lt;\/el-radio&gt;\n            &lt;el-radio label=\"0\"&gt;\u5973&lt;\/el-radio&gt;\n          &lt;\/el-radio-group&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u7535\u8bdd\" prop=\"phone\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.phone\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\nexport default {\n  name: \"SelectUser\",\n  data() {\n    let checkAge = (rule, value, callback) =&gt; {\n      if (value &gt; 150) {\n        callback(new Error('\u5e74\u9f84\u592a\u5927\uff01lbd\u518d\u6765\u6211\u8ba9\u4f60\u98de\u8d77\u6765\uff01'));\n      } else {\n        callback();\n      }\n    };\n    let checkDuplicate = (rule, value, callback) =&gt; {\n      if (this.form.id) {\n        return callback();\n      }\n      this.$axios.get(this.$httpUrl + \"\/user\/findByNo?no=\" + this.form.no).then(res =&gt; res.data).then(res =&gt; {\n        if (res.code !== 200) {\/\/es6\u89e3\u6784\u4e5f\u53ef\u4ee5\n          callback();\n        } else {\n          callback(new Error('\u8d26\u53f7\u5df2\u7ecf\u5b58\u5728'));\n        }\n      });\n    };\n    return {\n      tableData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      total: 0,\n      name: '',\n      sex: '',\n      sexs: &#91;\n        {\n          value: '1',\n          label: '\u7537'\n        }, {\n          value: '0',\n          label: '\u5973'\n        }\n      ],\n      centerDialogVisible: false,\n      form: {\n        name: '',\n        no: '',\n        age: '',\n        password: '',\n        phone: '',\n        sex: '0',\n        roleId: '2'\n      },\n      rules: {\n        no: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u8d26\u53f7', trigger: 'blur'},\n          {min: 3, max: 8, message: '\u957f\u5ea6\u57283-8\u4e2a\u5b57\u7b26', trigger: 'blur'},\n          {validator: checkDuplicate, trigger: 'blur'}\n        ],\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u540d\u5b57', trigger: 'blur'},\n        ],\n        password: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5bc6\u7801', trigger: 'blur'},\n          {min: 4, max: 10, message: '\u957f\u5ea6\u57284-10\u4e2a\u5b57\u7b26\u4e4b\u95f4', trigger: 'blur'}\n        ],\n        age: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5e74\u9f84', trigger: 'blur'},\n          {min: 1, max: 3, message: '\u957f\u5ea6\u57281\u52303\u4e2a\u4f4d', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,3}$\/, message: '\u5e74\u9f84\u5fc5\u987b\u4e3a\u6b63\u6574\u6570\u5b57', trigger: \"blur\"},\n          {validator: checkAge, trigger: 'blur'}\n        ],\n        phone: &#91;\n          {required: true, message: \"\u624b\u673a\u53f7\u4e0d\u80fd\u4e3a\u7a7a\", trigger: \"blur\"},\n          {pattern: \/^1&#91;3|4|5|6|7|8|9]&#91;0-9]\\d{8}$\/, message: \"\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u624b\u673a\u53f7\u7801\", trigger: \"blur\"}\n        ]\n      }\n    }\n  },\n  methods: {\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n      })\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.no = row.no;\n        this.form.name = row.name;\n        this.form.sex = row.sex + '';\n        this.form.age = row.age + '';\/\/\u8f6c\u5316\u6210\u5b57\u7b26\u4e32\u7c7b\u578b\n        this.form.phone = row.phone;\n        this.form.password = '';\n        this.form.roleId = row.roleId;\n      })\/\/\u4fee\u6539User\u7684\u65f6\u5019\u8981\u786e\u4fdd\u8d26\u53f7\u4e0d\u80fd\u4fee\u6539\uff0c\u5426\u5219\u6709\u53ef\u80fd\u4f1a\u6570\u636e\u5e93\u5b58\u5728\u8d26\u53f7\u76f8\u540c\u7684\u60c5\u51b5\uff01\uff01\uff01\uff01\u7ed9\u8d26\u53f7\u7684input\u91cc\u52a0\u4e2av-bind:disabled=\"isDisabled\u201c,\u5982\u679c\u662f\u4fee\u6539\u5c31\u628aisDisabled\u8bbe\u7f6e\u4e3atrue\uff0c\u6dfb\u52a0\u5c31false\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/user\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    resetForm() {\n      this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/user\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/user\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadGet() {\n      this.$axios.get(this.$httpUrl + '\/user\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n      })\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/user\/listPageC1', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          sex: this.sex,\n          roleId:'2'\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.sex = ''\n    },\n    selectCurrentChange(val) {\n      \/\/this.currentRow=val\n      this.$emit(\"doSelectUser\",val)\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    \/\/ this.loadGet();\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>GoodsManage.vue<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u7269\u54c1\u540d:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in storageData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-select v-model=\"goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in goodstypeData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\"&gt;\u65b0\u589e&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" style=\"margin-left:5px;\" @click=\"inGoods\"&gt;\u5165\u5e93&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" style=\"margin-left:5px;\" @click=\"outGoods\"&gt;\u51fa\u5e93&lt;\/el-button&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n              highlight-current-row\n              @current-change=\"selectCurrentChange\"\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u7269\u54c1\u540d\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"storage\" label=\"\u4ed3\u5e93\" :formatter=\"formatStorage\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"goodstype\" label=\"\u5206\u7c7b\" :formatter=\"formatGoodsType\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"count\" label=\"\u6570\u91cf\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"remark\" label=\"\u5907\u6ce8\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"operate\" label=\"\u64cd\u4f5c\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-button size=\"small\" type=\"success\" @click=\"mod(scope.row)\"&gt;\u7f16\u8f91&lt;\/el-button&gt;\n          &lt;el-popconfirm\n              title=\"\u786e\u5b9a\u5220\u9664\u5417\uff1f\"\n              @confirm=\"del(scope.row.id)\"\n              style=\"margin-left:8px;\"\n          &gt;\n            &lt;el-button slot=\"reference\" size=\"small\" type=\"danger\"&gt;\u5220\u9664&lt;\/el-button&gt;\n          &lt;\/el-popconfirm&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u7269\u54c1\u7ef4\u62a4\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u4ed3\u5e93\" prop=\"storage\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in storageData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5206\u7c7b\" prop=\"goodstype\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in goodstypeData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n\n    &lt;el-dialog\n        title=\"\u51fa\u5165\u5e93\"\n        :visible.sync=\"inDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-dialog\n          width=\"70%\"\n          title=\"\u7528\u6237\u9009\u62e9\"\n          :visible.sync=\"innerVisible\"\n          append-to-body&gt;\n        &lt;SelectUser @doSelectUser=\"doSelectUser\"&gt;&lt;\/SelectUser&gt;\n        &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"innerVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"confirmUser\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n        &lt;\/span&gt;\n      &lt;\/el-dialog&gt;\n\n      &lt;el-form ref=\"form1\" :rules=\"rules1\" :model=\"form1\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.goodsname\" readonly&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u7533\u8bf7\u4eba\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.username\" readonly @click.native=\"selectUser\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form1.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"inDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"doInGoods\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\n\nimport SelectUser from \"..\/user\/SelectUser\";\n\nexport default {\n  name: \"GoodsManage\",\n  components: {SelectUser},\n  data() {\n    let checkCount = (rule, value, callback) =&gt; {\n      if (value &gt; 9999) {\n        callback(new Error('\u6570\u91cf\u8f93\u5165\u8fc7\u5927'));\n      } else {\n        callback();\n      }\n    };\n    return {\n      user: JSON.parse(sessionStorage.getItem('CurUser')),\n      storageData: &#91;],\n      tableData: &#91;],\n      goodstypeData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      storage: '',\n      goodstype: '',\n      total: 0,\n      name: '',\n      centerDialogVisible: false,\n      inDialogVisible: false,\n      innerVisible: false,\n      currentRow: {},\n      tempUser: {},\n      form: {\n        id: '',\n        name: '',\n        remark: '',\n        count: '',\n        storage: '',\n        goodstype: '',\n      },\n      form1: {\n        goods: '',\n        goodsname: '',\n        count: '',\n        username: '',\n        userid: '',\n        adminId: '',\n        remark: '',\n        action:1,\n      },\n      rules1: {},\n      rules: {\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u7269\u54c1\u540d', trigger: 'blur'},\n        ],\n        storage: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u4ed3\u5e93', trigger: 'blur'}\n        ],\n        goodstype: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u5206\u7c7b\u2019\uff0ctrigger:\u2018blur'}\n        ],\n        count: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u6570\u91cf', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,4}$\/, message: '\u6570\u91cf\u5fc5\u987b\u4e3a\u6b63\u6574\u6570', trigger: \"blur\"},\n          {validator: checkCount, trigger: 'blur'}\n        ]\n      }\n    }\n  },\n  methods: {\n    confirmUser() {\n      this.username = this.tempUser.name\n      this.userid = this.tempUser.id\n      this.innerVisible = false\n    },\n    doSelectUser(val) {\n      console.log(val)\n      this.tempUser = val\n    },\n    selectCurrentChange(val) {\n      this.currentRow = val;\n    },\n    formatStorage(row) {\n      let temp = this.storageData.find(item =&gt; {\n        return item.id === row.storage\n      })\n      return temp &amp;&amp; temp.name\n    },\n    formatGoodsType(row) {\n      let temp = this.goodstypeData.find(item =&gt; {\n        return item.id === row.goodstype\n      })\n      return temp &amp;&amp; temp.name\n    },\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n        this.form.id = ''\n      })\n    },\n    inGoods() {\n      if (!this.currentRow.id) {\n        alert('\u8bf7\u9009\u62e9\u8bb0\u5f55');\n        return;\n      }\n      this.inDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetInForm()\n\n      })\n      this.form1.goodsname = this.currentRow.name\n      this.form1.goods = this.currentRow.id\n      this.form1.adminId = this.user.id\n      this.form1.action = '1'\n    },\n    outGoods() {\n      if (!this.currentRow.id) {\n        alert('\u8bf7\u9009\u62e9\u8bb0\u5f55');\n        return;\n      }\n      this.inDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetInForm()\n      })\n      this.form1.goodsname = this.currentRow.name\n      this.form1.goods = this.currentRow.id\n      this.form1.adminId = this.user.id\n      this.form1.action = '2'\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.remark = row.remark;\n        this.form.name = row.name;\n        this.form.storage = row.storage;\n        this.form.goodstype = row.goodstype;\n        this.form.count = row.count;\n      })\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/goods\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    selectUser() {\n      this.innerVisible = true;\n    },\n    resetForm() {\n      \/\/this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n      \/\/this.form.id = '';\n    },\n    resetInForm() {\n      this.$refs.form1.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/goods\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/goods\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/goods\/listPage', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          goodstype: this.goodstype + '',\/\/string\u548cint\u5f3a\u8f6c\u4e00\u4e0b\n          storage: this.storage + ''\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadStorage() {\n      this.$axios.get(this.$httpUrl + '\/storage\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.storageData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadGoodsType() {\n      this.$axios.get(this.$httpUrl + '\/goodstype\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.goodstypeData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.storage = ''\n      this.goodstype = ''\n    },\n    doInGoods() {\n      this.$axios.post(this.$httpUrl + '\/record\/save', this.form1).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.inDialogVisible = false\n          this.loadPost();\n          this.resetInForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    this.loadStorage()\n    this.loadGoodsType()\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>\u7533\u8bf7\u4eba\u4e0d\u77e5\u9053\u4e3a\u4ec0\u4e48\u6ca1\u4f20\u4e0a\u53bb&nbsp;\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21\ud83d\ude21<\/p>\n\n\n\n<h1 class=\"wp-block-heading\">\u4e09\u5341\u56db\u3001\u6743\u9650\u63a7\u5236\u4f18\u5316<\/h1>\n\n\n\n<p>\u5982\u679c\u8981\u4fdd\u9669\u5f97\u5728\u540e\u7aef\u7528\u8fc7\u6ee4\u5668\u8fdb\u884c\u76d1\u542c,\u4f46\u662f\u6211\u61d2\u5f97\u505a<\/p>\n\n\n\n<p>SelectUser<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u540d\u5b57:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"sex\" filterableplacehoLder=\"\u8bf7\u9009\u62e9\u6027\u522b\" style=\"margin-left:5px\"&gt;\n        &lt;el-option\n            v-for=\"item in sexs\"\n            :key=\"item.value\"\n            :label=\"item.label\"\n            :value=\"item.value\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;!--&lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\"&gt;\u65b0\u589e&lt;\/el-button&gt;--&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n              highlight-current-row\n              @current-change=\"selectCurrentChange\"\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"no\" label=\"\u8d26\u53f7\" width=\"150\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u59d3\u540d\" width=\"120\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"age\" label=\"\u5e74\u9f84\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"sex\" label=\"\u6027\u522b\" width=\"80\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.sex === 1 ?'primary':'success'\"\n              disable-transitions&gt;{{ scope.row.sex === 1 ? '\u7537' : '\u5973' }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"roleId\" label=\"\u89d2\u8272\" width=\"120\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.roleId === 0 ?'danger':(scope.row.roleId === 1 ?'primary':'success')\"\n              disable-transitions&gt;\n            {{ scope.row.roleId === 0 ? '\u8d85\u7ea7\u7ba1\u7406\u5458' : (scope.row.roleId === 1 ? '\u7ba1\u7406\u5458' : '\u7528\u6237') }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"phone\" label=\"\u7535\u8bdd\" &gt;\n      &lt;\/el-table-column&gt;\n\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u63d0\u793a\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u8d26\u53f7\" prop=\"no\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.no\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5bc6\u7801\" prop=\"password\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.password\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u540d\u5b57\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5e74\u9f84\" prop=\"age\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.age\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6027\u522b\"&gt;\n          &lt;el-radio-group v-model=\"form.sex\"&gt;\n            &lt;el-radio label=\"1\"&gt;\u7537&lt;\/el-radio&gt;\n            &lt;el-radio label=\"0\"&gt;\u5973&lt;\/el-radio&gt;\n          &lt;\/el-radio-group&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u7535\u8bdd\" prop=\"phone\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.phone\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\nexport default {\n  name: \"SelectUser\",\n  data() {\n    let checkAge = (rule, value, callback) =&gt; {\n      if (value &gt; 150) {\n        callback(new Error('\u5e74\u9f84\u592a\u5927\uff01lbd\u518d\u6765\u6211\u8ba9\u4f60\u98de\u8d77\u6765\uff01'));\n      } else {\n        callback();\n      }\n    };\n    let checkDuplicate = (rule, value, callback) =&gt; {\n      if (this.form.id) {\n        return callback();\n      }\n      this.$axios.get(this.$httpUrl + \"\/user\/findByNo?no=\" + this.form.no).then(res =&gt; res.data).then(res =&gt; {\n        if (res.code !== 200) {\/\/es6\u89e3\u6784\u4e5f\u53ef\u4ee5\n          callback();\n        } else {\n          callback(new Error('\u8d26\u53f7\u5df2\u7ecf\u5b58\u5728'));\n        }\n      });\n    };\n    return {\n      tableData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      total: 0,\n      name: '',\n      sex: '',\n      sexs: &#91;\n        {\n          value: '1',\n          label: '\u7537'\n        }, {\n          value: '0',\n          label: '\u5973'\n        }\n      ],\n      centerDialogVisible: false,\n      form: {\n        name: '',\n        no: '',\n        age: '',\n        password: '',\n        phone: '',\n        sex: '0',\n        roleId: '2'\n      },\n      rules: {\n        no: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u8d26\u53f7', trigger: 'blur'},\n          {min: 3, max: 8, message: '\u957f\u5ea6\u57283-8\u4e2a\u5b57\u7b26', trigger: 'blur'},\n          {validator: checkDuplicate, trigger: 'blur'}\n        ],\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u540d\u5b57', trigger: 'blur'},\n        ],\n        password: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5bc6\u7801', trigger: 'blur'},\n          {min: 4, max: 10, message: '\u957f\u5ea6\u57284-10\u4e2a\u5b57\u7b26\u4e4b\u95f4', trigger: 'blur'}\n        ],\n        age: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5e74\u9f84', trigger: 'blur'},\n          {min: 1, max: 3, message: '\u957f\u5ea6\u57281\u52303\u4e2a\u4f4d', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,3}$\/, message: '\u5e74\u9f84\u5fc5\u987b\u4e3a\u6b63\u6574\u6570\u5b57', trigger: \"blur\"},\n          {validator: checkAge, trigger: 'blur'}\n        ],\n        phone: &#91;\n          {required: true, message: \"\u624b\u673a\u53f7\u4e0d\u80fd\u4e3a\u7a7a\", trigger: \"blur\"},\n          {pattern: \/^1&#91;3|4|5|6|7|8|9]&#91;0-9]\\d{8}$\/, message: \"\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u624b\u673a\u53f7\u7801\", trigger: \"blur\"}\n        ]\n      }\n    }\n  },\n  methods: {\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n      })\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.no = row.no;\n        this.form.name = row.name;\n        this.form.sex = row.sex + '';\n        this.form.age = row.age + '';\/\/\u8f6c\u5316\u6210\u5b57\u7b26\u4e32\u7c7b\u578b\n        this.form.phone = row.phone;\n        this.form.password = '';\n        this.form.roleId = row.roleId;\n      })\/\/\u4fee\u6539User\u7684\u65f6\u5019\u8981\u786e\u4fdd\u8d26\u53f7\u4e0d\u80fd\u4fee\u6539\uff0c\u5426\u5219\u6709\u53ef\u80fd\u4f1a\u6570\u636e\u5e93\u5b58\u5728\u8d26\u53f7\u76f8\u540c\u7684\u60c5\u51b5\uff01\uff01\uff01\uff01\u7ed9\u8d26\u53f7\u7684input\u91cc\u52a0\u4e2av-bind:disabled=\"isDisabled\u201c,\u5982\u679c\u662f\u4fee\u6539\u5c31\u628aisDisabled\u8bbe\u7f6e\u4e3atrue\uff0c\u6dfb\u52a0\u5c31false\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/user\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    resetForm() {\n      this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/user\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/user\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadGet() {\n      this.$axios.get(this.$httpUrl + '\/user\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n      })\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/user\/listPageC1', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          sex: this.sex,\n          roleId:'2'\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.sex = ''\n    },\n    selectCurrentChange(val) {\n      \/\/this.currentRow=val\n      this.$emit(\"doSelectUser\",val)\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    \/\/ this.loadGet();\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>GoodsManage<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u7269\u54c1\u540d:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in storageData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-select v-model=\"goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in goodstypeData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\" v-if=\"user.roleId!=2\"&gt;\u65b0\u589e&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" style=\"margin-left:5px;\" @click=\"inGoods\" v-if=\"user.roleId!=2\"&gt;\u5165\u5e93&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" style=\"margin-left:5px;\" @click=\"outGoods\" v-if=\"user.roleId!=2\"&gt;\u51fa\u5e93&lt;\/el-button&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n              highlight-current-row\n              @current-change=\"selectCurrentChange\"\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u7269\u54c1\u540d\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"storage\" label=\"\u4ed3\u5e93\" :formatter=\"formatStorage\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"goodstype\" label=\"\u5206\u7c7b\" :formatter=\"formatGoodsType\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"count\" label=\"\u6570\u91cf\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"remark\" label=\"\u5907\u6ce8\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"operate\" label=\"\u64cd\u4f5c\" v-if=\"user.roleId!=2\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-button size=\"small\" type=\"success\" @click=\"mod(scope.row)\"&gt;\u7f16\u8f91&lt;\/el-button&gt;\n          &lt;el-popconfirm\n              title=\"\u786e\u5b9a\u5220\u9664\u5417\uff1f\"\n              @confirm=\"del(scope.row.id)\"\n              style=\"margin-left:8px;\"\n          &gt;\n            &lt;el-button slot=\"reference\" size=\"small\" type=\"danger\"&gt;\u5220\u9664&lt;\/el-button&gt;\n          &lt;\/el-popconfirm&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u7269\u54c1\u7ef4\u62a4\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u4ed3\u5e93\" prop=\"storage\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in storageData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5206\u7c7b\" prop=\"goodstype\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-select v-model=\"form.goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n              &lt;el-option\n                  v-for=\"item in goodstypeData\"\n                  :key=\"item.id\"\n                  :label=\"item.name\"\n                  :value=\"item.id\"&gt;\n              &lt;\/el-option&gt;\n            &lt;\/el-select&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n\n    &lt;el-dialog\n        title=\"\u51fa\u5165\u5e93\"\n        :visible.sync=\"inDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-dialog\n          width=\"70%\"\n          title=\"\u7528\u6237\u9009\u62e9\"\n          :visible.sync=\"innerVisible\"\n          append-to-body&gt;\n        &lt;SelectUser @doSelectUser=\"doSelectUser\"&gt;&lt;\/SelectUser&gt;\n        &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"innerVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"confirmUser\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n        &lt;\/span&gt;\n      &lt;\/el-dialog&gt;\n\n      &lt;el-form ref=\"form1\" :rules=\"rules1\" :model=\"form1\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u7269\u54c1\u540d\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.goodsname\" readonly&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u7533\u8bf7\u4eba\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.username\" readonly @click.native=\"selectUser\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6570\u91cf\" prop=\"count\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form1.count\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5907\u6ce8\" prop=\"remark\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input type=\"textarea\" v-model=\"form1.remark\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"inDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"doInGoods\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\n\nimport SelectUser from \"..\/user\/SelectUser\";\n\nexport default {\n  name: \"GoodsManage\",\n  components: {SelectUser},\n  data() {\n    let checkCount = (rule, value, callback) =&gt; {\n      if (value &gt; 9999) {\n        callback(new Error('\u6570\u91cf\u8f93\u5165\u8fc7\u5927'));\n      } else {\n        callback();\n      }\n    };\n    return {\n      user: JSON.parse(sessionStorage.getItem('CurUser')),\n      storageData: &#91;],\n      tableData: &#91;],\n      goodstypeData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      storage: '',\n      goodstype: '',\n      total: 0,\n      name: '',\n      centerDialogVisible: false,\n      inDialogVisible: false,\n      innerVisible: false,\n      currentRow: {},\n      tempUser: {},\n      form: {\n        id: '',\n        name: '',\n        remark: '',\n        count: '',\n        storage: '',\n        goodstype: '',\n      },\n      form1: {\n        goods: '',\n        goodsname: '',\n        count: '',\n        username: '',\n        userid: '',\n        adminId: '',\n        remark: '',\n        action: 1,\n      },\n      rules1: {},\n      rules: {\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u7269\u54c1\u540d', trigger: 'blur'},\n        ],\n        storage: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u4ed3\u5e93', trigger: 'blur'}\n        ],\n        goodstype: &#91;\n          {required: true, message: '\u8bf7\u9009\u62e9\u5206\u7c7b\u2019\uff0ctrigger:\u2018blur'}\n        ],\n        count: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u6570\u91cf', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,4}$\/, message: '\u6570\u91cf\u5fc5\u987b\u4e3a\u6b63\u6574\u6570', trigger: \"blur\"},\n          {validator: checkCount, trigger: 'blur'}\n        ]\n      }\n    }\n  },\n  methods: {\n    confirmUser() {\n      this.username = this.tempUser.name\n      this.userid = this.tempUser.id\n      this.innerVisible = false\n    },\n    doSelectUser(val) {\n      console.log(val)\n      this.tempUser = val\n    },\n    selectCurrentChange(val) {\n      this.currentRow = val;\n    },\n    formatStorage(row) {\n      let temp = this.storageData.find(item =&gt; {\n        return item.id === row.storage\n      })\n      return temp &amp;&amp; temp.name\n    },\n    formatGoodsType(row) {\n      let temp = this.goodstypeData.find(item =&gt; {\n        return item.id === row.goodstype\n      })\n      return temp &amp;&amp; temp.name\n    },\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n        this.form.id = ''\n      })\n    },\n    inGoods() {\n      if (!this.currentRow.id) {\n        alert('\u8bf7\u9009\u62e9\u8bb0\u5f55');\n        return;\n      }\n      this.inDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetInForm()\n\n      })\n      this.form1.goodsname = this.currentRow.name\n      this.form1.goods = this.currentRow.id\n      this.form1.adminId = this.user.id\n      this.form1.action = '1'\n    },\n    outGoods() {\n      if (!this.currentRow.id) {\n        alert('\u8bf7\u9009\u62e9\u8bb0\u5f55');\n        return;\n      }\n      this.inDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetInForm()\n      })\n      this.form1.goodsname = this.currentRow.name\n      this.form1.goods = this.currentRow.id\n      this.form1.adminId = this.user.id\n      this.form1.action = '2'\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.remark = row.remark;\n        this.form.name = row.name;\n        this.form.storage = row.storage;\n        this.form.goodstype = row.goodstype;\n        this.form.count = row.count;\n      })\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/goods\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    selectUser() {\n      this.innerVisible = true;\n    },\n    resetForm() {\n      \/\/this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n      \/\/this.form.id = '';\n    },\n    resetInForm() {\n      this.$refs.form1.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/goods\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/goods\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/goods\/listPage', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          goodstype: this.goodstype + '',\/\/string\u548cint\u5f3a\u8f6c\u4e00\u4e0b\n          storage: this.storage + ''\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadStorage() {\n      this.$axios.get(this.$httpUrl + '\/storage\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.storageData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadGoodsType() {\n      this.$axios.get(this.$httpUrl + '\/goodstype\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.goodstypeData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.storage = ''\n      this.goodstype = ''\n    },\n    doInGoods() {\n      this.$axios.post(this.$httpUrl + '\/record\/save', this.form1).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.inDialogVisible = false\n          this.loadPost();\n          this.resetInForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    this.loadStorage()\n    this.loadGoodsType()\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>RecordManage<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u7269\u54c1\u540d:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"storage\" placehoLder=\"\u8bf7\u9009\u62e9\u4ed3\u5e93\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in storageData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-select v-model=\"goodstype\" placeholder=\"\u8bf7\u9009\u62e9\u5206\u7c7b\" style=\"margin-left: 5px;\"&gt;\n        &lt;el-option\n            v-for=\"item in goodstypeData\"\n            :key=\"item.id\"\n            :label=\"item.name\"\n            :value=\"item.id\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n\n\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"goodsname\" label=\"\u7269\u54c1\u540d\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"storagename\" label=\"\u4ed3\u5e93\"  &gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"goodstypename\" label=\"\u5206\u7c7b\"  &gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"adminname\" label=\"\u64cd\u4f5c\u4eba\"  &gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"username\" label=\"\u7533\u8bf7\u4eba\"  &gt;\n    &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"count\" label=\"\u6570\u91cf\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"createtime\" label=\"\u64cd\u4f5c\u65f6\u95f4\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"remark\" label=\"\u5907\u6ce8\"&gt;\n      &lt;\/el-table-column&gt;\n\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\nexport default {\n  name: \"RecordManage\",\n  data() {\n\n    return {\n      user:JSON.parse(sessionStorage.getItem('CurUser')),\n      storageData: &#91;],\n      tableData: &#91;],\n      goodstypeData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      storage: '',\n      goodstype: '',\n      total: 0,\n      name: '',\n      centerDialogVisible: false,\n      form: {\n        id: '',\n        name: '',\n        remark: '',\n        count: '',\n        storage: '',\n        goodstype: '',\n      },\n    }\n  },\n  methods: {\n    formatStorage(row) {\n      let temp = this.storageData.find(item =&gt; {\n        return item.id === row.storage\n      })\n      return temp &amp;&amp; temp.name\n    },\n    formatGoodsType(row) {\n      let temp = this.goodstypeData.find(item =&gt; {\n        return item.id === row.goodstype\n      })\n      return temp &amp;&amp; temp.name\n    },\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n        this.form.id = ''\n      })\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.remark = row.remark;\n        this.form.name = row.name;\n        this.form.storage = row.storage;\n        this.form.goodstype = row.goodstype;\n        this.form.count = row.count;\n      })\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/goods\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    resetForm() {\n      this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n      this.form.id = '';\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/goods\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/goods\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/record\/listPage', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          goodstype: this.goodstype + '',\/\/string\u548cint\u5f3a\u8f6c\u4e00\u4e0b\n          storage: this.storage + '',\n          roleId:this.user.roleId+'',\n          userId:this.user.id+'',\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadStorage() {\n      this.$axios.get(this.$httpUrl + '\/storage\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.storageData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    loadGoodsType() {\n      this.$axios.get(this.$httpUrl + '\/goodstype\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.goodstypeData = res.data\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.storage = ''\n      this.goodstype = ''\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    this.loadGoodsType()\n    this.loadStorage()\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>RecordController<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>package com.wms.controller;\n\n\nimport com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;\nimport com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;\nimport com.baomidou.mybatisplus.core.metadata.IPage;\nimport com.baomidou.mybatisplus.core.toolkit.StringUtils;\nimport com.baomidou.mybatisplus.extension.plugins.pagination.Page;\nimport com.wms.common.QueryPageParam;\nimport com.wms.common.Result;\nimport com.wms.entity.Goods;\nimport com.wms.entity.Record;\nimport com.wms.service.GoodsService;\nimport com.wms.service.RecordService;\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestMapping;\n\nimport org.springframework.web.bind.annotation.RestController;\n\nimport java.util.HashMap;\n\n\/**\n * &lt;p&gt;\n * \u524d\u7aef\u63a7\u5236\u5668\n * &lt;\/p&gt;\n *\n * @author wms\n * @since 2024-12-07\n *\/\n@RestController\n@RequestMapping(\"\/record\")\npublic class RecordController {\n    @Autowired\n    private RecordService recordService;\n\n    @Autowired\n    private GoodsService goodsService;\n\n    @PostMapping(\"\/listPage\")\n    public Result listPage(@RequestBody QueryPageParam query) {\n        HashMap param = query.getParam();\n        String name = (String) param.get(\"name\");\n        String storage = (String) param.get(\"storage\");\n        String goodstype = (String) param.get(\"goodstype\");\n        String roleId = (String) param.get(\"roleId\");\n        String userId = (String) param.get(\"userId\");\n\n        Page&lt;Record&gt; page = new Page();\n        page.setCurrent(query.getPageNum());\n        page.setSize(query.getPageSize());\n\n        QueryWrapper&lt;Record&gt; queryWrapper = new QueryWrapper();\n        queryWrapper.apply(\" a.goods=b.id and b.storage=c.id and b.goodsType=d.id \");\n\n\n        if(\"2\".equals(roleId)) {\n            \/\/queryWrapper.eq(Record::getUserid, userId);\n\n            queryWrapper.apply(\"a.userId=\"+userId);\n        }\n\n\n\n\n        if (StringUtils.isNotBlank(name) &amp;&amp; !\"null\".equals(name)) {\n            \/\/lambdaQueryWrapper.like(Record::getName, name);\n            queryWrapper.like(\"b.name\", name);\n        }\n        if (StringUtils.isNotBlank(storage) &amp;&amp; !\"null\".equals(storage)) {\n            queryWrapper.eq(\"c.id\", storage);\n        }\n        if (StringUtils.isNotBlank(goodstype) &amp;&amp; !\"null\".equals(goodstype)) {\n            queryWrapper.eq(\"d.id\", goodstype);\n        }\n\n\n        IPage result = recordService.pageCC(page, queryWrapper);\n        return Result.success(result.getRecords(), result.getTotal());\n    }\n\n    \/\/\u5c06\u5165\u5e93\u6570\u636e\u548c\u539f\u6709\u6570\u636e\u76f8\u52a0\u5427\n    \/\/\u65b0\u589e\n    @PostMapping(\"\/save\")\n\n    public Result save(@RequestBody Record record) {\n        Goods goods = goodsService.getById(record.getGoods());\n        int n = record.getCount();\n        \/\/\u51fa\u5e93\n        if(\"2\".equals(record.getAction())) {\n            n = -n;\n            record.setCount(n);\n        }\n\n        int num = goods.getCount() + n;\n        goods.setCount(num);\n        goodsService.updateById(goods);\n        return recordService.save(record) ? Result.success() : Result.fail();\n    }\n}\n<\/code><\/pre>\n\n\n\n<p>UserManage<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div&gt;\n    &lt;div style=\"margin-left:5px\"&gt;\n      &lt;el-input v-model=\"name\" placeholder=\"\u8bf7\u8f93\u5165\u540d\u5b57:\" suffix-icon=\"el-icon-search\" style=\"width:200px;\"\n                @keyup.enter.native=\"loadPost\"&gt;&lt;\/el-input&gt;\n      &lt;el-select v-model=\"sex\" filterableplacehoLder=\"\u8bf7\u9009\u62e9\u6027\u522b\" style=\"margin-left:5px\"&gt;\n        &lt;el-option\n            v-for=\"item in sexs\"\n            :key=\"item.value\"\n            :label=\"item.label\"\n            :value=\"item.value\"&gt;\n        &lt;\/el-option&gt;\n      &lt;\/el-select&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"loadPost\"&gt;\u67e5\u8be2&lt;\/el-button&gt;\n      &lt;el-button type=\"success\" @click=\"resetParam\"&gt;\u91cd\u7f6e&lt;\/el-button&gt;\n      &lt;el-button type=\"primary\" style=\"margin-left:5px\" @click=\"add\"&gt;\u65b0\u589e&lt;\/el-button&gt;\n    &lt;\/div&gt;\n    &lt;el-table :data=\"tableData\"\n              :header-cell-style=\"{background:'#f2f5fc',color:'#555'}\"\n              border\n    &gt;\n      &lt;el-table-column prop=\"id\" label=\"ID\" width=\"60\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"no\" label=\"\u8d26\u53f7\" width=\"120\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"name\" label=\"\u59d3\u540d\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"age\" label=\"\u5e74\u9f84\" width=\"80\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"sex\" label=\"\u6027\u522b\" width=\"80\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.sex === 1 ?'primary':'success'\"\n              disable-transitions&gt;{{ scope.row.sex === 1 ? '\u7537' : '\u5973' }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"roleId\" label=\"\u89d2\u8272\" width=\"120\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-tag\n              :type=\"scope.row.roleId === 0 ?'danger':(scope.row.roleId === 1 ?'primary':'success')\"\n              disable-transitions&gt;\n            {{ scope.row.roleId === 0 ? '\u8d85\u7ea7\u7ba1\u7406\u5458' : (scope.row.roleId === 1 ? '\u7ba1\u7406\u5458' : '\u7528\u6237') }}\n          &lt;\/el-tag&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"phone\" label=\"\u7535\u8bdd\" width=\"120\"&gt;\n      &lt;\/el-table-column&gt;\n      &lt;el-table-column prop=\"operate\" label=\"\u64cd\u4f5c\"&gt;\n        &lt;template slot-scope=\"scope\"&gt;\n          &lt;el-button size=\"small\" type=\"success\" @click=\"mod(scope.row)\"&gt;\u7f16\u8f91&lt;\/el-button&gt;\n          &lt;el-popconfirm\n              title=\"\u786e\u5b9a\u5220\u9664\u5417\uff1f\"\n              @confirm=\"del(scope.row.id)\"\n              style=\"margin-left:8px;\"\n          &gt;\n            &lt;el-button  slot=\"reference\" size=\"small\" type=\"danger\"&gt;\u5220\u9664&lt;\/el-button&gt;\n          &lt;\/el-popconfirm&gt;\n        &lt;\/template&gt;\n      &lt;\/el-table-column&gt;\n    &lt;\/el-table&gt;\n    &lt;el-pagination\n        @size-change=\"handleSizeChange\"\n        @current-change=\"handleCurrentChange\"\n        :current-page=\"pageNum\"\n        :page-sizes=\"&#91;5, 10, 20, 50]\"\n        :page-size=\"pageSize\"\n        layout=\"total, sizes, prev, pager, next, jumper\"\n        :total=\"total\"&gt;\n    &lt;\/el-pagination&gt;\n    &lt;el-dialog\n        title=\"\u63d0\u793a\"\n        :visible.sync=\"centerDialogVisible\"\n        width=\"30%\"\n        center&gt;\n\n      &lt;el-form ref=\"form\" :rules=\"rules\" :model=\"form\" label-width=\"80px\"&gt;\n        &lt;el-form-item label=\"\u8d26\u53f7\" prop=\"no\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.no\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5bc6\u7801\" prop=\"password\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.password\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u540d\u5b57\" prop=\"name\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.name\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u5e74\u9f84\" prop=\"age\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.age\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u6027\u522b\"&gt;\n          &lt;el-radio-group v-model=\"form.sex\"&gt;\n            &lt;el-radio label=\"1\"&gt;\u7537&lt;\/el-radio&gt;\n            &lt;el-radio label=\"0\"&gt;\u5973&lt;\/el-radio&gt;\n          &lt;\/el-radio-group&gt;\n        &lt;\/el-form-item&gt;\n        &lt;el-form-item label=\"\u7535\u8bdd\" prop=\"phone\"&gt;\n          &lt;el-col :span=\"20\"&gt;\n            &lt;el-input v-model=\"form.phone\"&gt;&lt;\/el-input&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n\n      &lt;span slot=\"footer\" class=\"dialog-footer\"&gt;\n        &lt;el-button @click=\"centerDialogVisible=false\"&gt;\u53d6\u6d88&lt;\/el-button&gt;\n        &lt;el-button type=\"primary\" @click=\"save\"&gt;\u786e\u5b9a&lt;\/el-button&gt;\n  &lt;\/span&gt;\n    &lt;\/el-dialog&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n\n&lt;\/style&gt;\n&lt;script&gt;\nexport default {\n  name: \"UserManage\",\n  data() {\n    let checkAge = (rule, value, callback) =&gt; {\n      if (value &gt; 150) {\n        callback(new Error('\u5e74\u9f84\u592a\u5927\uff01lbd\u518d\u6765\u6211\u8ba9\u4f60\u98de\u8d77\u6765\uff01'));\n      } else {\n        callback();\n      }\n    };\n    let checkDuplicate = (rule, value, callback) =&gt; {\n      if (this.form.id) {\n        return callback();\n      }\n      this.$axios.get(this.$httpUrl + \"\/user\/findByNo?no=\" + this.form.no).then(res =&gt; res.data).then(res =&gt; {\n        if (res.code !== 200) {\/\/es6\u89e3\u6784\u4e5f\u53ef\u4ee5\n          callback();\n        } else {\n          callback(new Error('\u8d26\u53f7\u5df2\u7ecf\u5b58\u5728'));\n        }\n      });\n    };\n    return {\n      tableData: &#91;],\n      pageSize: 10,\n      pageNum: 1,\n      total: 0,\n      name: '',\n      sex: '',\n      sexs: &#91;\n        {\n          value: '1',\n          label: '\u7537'\n        }, {\n          value: '0',\n          label: '\u5973'\n        }\n      ],\n      centerDialogVisible: false,\n      form: {\n        name: '',\n        no: '',\n        age: '',\n        password: '',\n        phone: '',\n        sex: '0',\n        roleId: '2'\n      },\n      rules: {\n        no: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u8d26\u53f7', trigger: 'blur'},\n          {min: 3, max: 8, message: '\u957f\u5ea6\u57283-8\u4e2a\u5b57\u7b26', trigger: 'blur'},\n          {validator: checkDuplicate, trigger: 'blur'}\n        ],\n        name: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u540d\u5b57', trigger: 'blur'},\n        ],\n        password: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5bc6\u7801', trigger: 'blur'},\n          {min: 4, max: 10, message: '\u957f\u5ea6\u57284-10\u4e2a\u5b57\u7b26\u4e4b\u95f4', trigger: 'blur'}\n        ],\n        age: &#91;\n          {required: true, message: '\u8bf7\u8f93\u5165\u5e74\u9f84', trigger: 'blur'},\n          {min: 1, max: 3, message: '\u957f\u5ea6\u57281\u52303\u4e2a\u4f4d', trigger: 'blur'},\n          {pattern: \/^(&#91;1-9]&#91;0-9]*){1,3}$\/, message: '\u5e74\u9f84\u5fc5\u987b\u4e3a\u6b63\u6574\u6570\u5b57', trigger: \"blur\"},\n          {validator: checkAge, trigger: 'blur'}\n        ],\n        phone: &#91;\n          {required: true, message: \"\u624b\u673a\u53f7\u4e0d\u80fd\u4e3a\u7a7a\", trigger: \"blur\"},\n          {pattern: \/^1&#91;3|4|5|6|7|8|9]&#91;0-9]\\d{8}$\/, message: \"\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u624b\u673a\u53f7\u7801\", trigger: \"blur\"}\n        ]\n      }\n    }\n  },\n  methods: {\n    add() {\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.resetForm()\n      })\n    },\n    mod(row) {\n      \/\/this.form=row\u5c31\u53ef\u4ee5\u4e86\n      this.centerDialogVisible = true\n      this.$nextTick(() =&gt; {\n        this.form.id = row.id;\n        this.form.no = row.no;\n        this.form.name = row.name;\n        this.form.sex = row.sex + '';\n        this.form.age = row.age + '';\/\/\u8f6c\u5316\u6210\u5b57\u7b26\u4e32\u7c7b\u578b\n        this.form.phone = row.phone;\n        this.form.password = '';\n        this.form.roleId = row.roleId;\n      })\/\/\u4fee\u6539User\u7684\u65f6\u5019\u8981\u786e\u4fdd\u8d26\u53f7\u4e0d\u80fd\u4fee\u6539\uff0c\u5426\u5219\u6709\u53ef\u80fd\u4f1a\u6570\u636e\u5e93\u5b58\u5728\u8d26\u53f7\u76f8\u540c\u7684\u60c5\u51b5\uff01\uff01\uff01\uff01\u7ed9\u8d26\u53f7\u7684input\u91cc\u52a0\u4e2av-bind:disabled=\"isDisabled\u201c,\u5982\u679c\u662f\u4fee\u6539\u5c31\u628aisDisabled\u8bbe\u7f6e\u4e3atrue\uff0c\u6dfb\u52a0\u5c31false\n    },\n    del(id) {\n      this.$axios.get(this.$httpUrl + '\/user\/del?id=' + id).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.loadPost();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    resetForm() {\n      this.centerDialogVisible = true\n      this.$refs.form.resetFields();\n    },\n    doSave() {\n      this.$axios.post(this.$httpUrl + '\/user\/save', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f!',\n            type: 'success'\n          });\n          this.centerDialogVisible = false\n          this.loadPost();\n          this.resetForm()\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25!\u8bf7\u8fd4\u56de\u91cd\u65b0\u64cd\u4f5c...',\n            type: 'error'\n          });\n        }\n      });\n    },\n    doMod() {\n      this.$axios.post(this.$httpUrl + '\/user\/update', this.form).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res);\n        if (res.code == 200) {\n          this.$message({\n            message: '\u64cd\u4f5c\u6210\u529f\uff01',\n            type: 'success'\n          });\n          this.centerDialogVisible = false;\n          this.loadPost();\n          this.resetForm();\n        } else {\n          this.$message({\n            message: '\u64cd\u4f5c\u5931\u8d25\uff01',\n            type: 'error'\n          });\n        }\n      });\n    },\n    save() {\n      this.$refs.form.validate((valid) =&gt; {\n        if (valid) {\n          if (this.form.id) {\n            this.doMod();\n          } else {\n            this.doSave();\n          }\n\n        } else {\n          console.log('error submit!!');\n          return false;\n        }\n      });\n    },\n    loadGet() {\n      this.$axios.get(this.$httpUrl + '\/user\/list').then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n      })\n    },\n    loadPost() {\n      this.$axios.post(this.$httpUrl + '\/user\/listPageC1', {\n        pageSize: this.pageSize,\n        pageNum: this.pageNum,\n        param: {\n          name: this.name,\n          sex: this.sex,\n          roleId:'2'\n        }\n      }).then(res =&gt; res.data).then(res =&gt; {\n        console.log(res)\n        if (res.code === 200) {\n          this.tableData = res.data\n          this.total = res.total\n        } else {\n          alert('\u83b7\u53d6\u6570\u636e\u5931\u8d25\uff01\u8bf7\u5237\u65b0\u9875\u9762')\n        }\n      })\n    },\n    resetParam() {\n      this.name = ''\n      this.sex = ''\n    },\n    handleSizeChange(val) {\n      console.log(`\u6bcf\u9875 ${val} \u6761`);\n      this.pageNum = 1\/\/\u8fd9\u4e2a\u9519\u8bef\u662f\u5148\u7ffb\u5230\u7b2c\u4e8c\u9875\u5728\u8c03\u9875\u9762\u6761\u6570\uff0c\u663e\u793a\u65e0\u6570\u636e\n      this.pageSize = val\n      this.loadPost()\n    },\n    handleCurrentChange(val) {\n      console.log(`\u5f53\u524d\u9875: ${val}`);\n      this.pageNum = val\n      this.loadPost()\n    }\n  },\n  beforeMount() {\n    \/\/ this.loadGet();\n    this.loadPost()\n  }\n}\n\n&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<h1 class=\"wp-block-heading\">\u4e09\u5341\u4e94\u3001\u5982\u4f55\u90e8\u7f72\u524d\u540e\u7aef\u5206\u79bb\u9879\u76ee<\/h1>\n\n\n\n<p>\u9884\u8ba1\u5728linux\u7cfb\u7edf\u4e0a\u90e8\u7f72\u5e76\u4e14\u90e8\u7f72\u5230\u7f51\u7ad9\u4e2d\u53bb\ud83d\ude2d\ud83d\ude2d\ud83d\ude2d\ud83d\ude2d\ud83d\ude2d\ud83d\ude2d\ud83d\ude2d\u6211\u770b\u62d6\u62d6\u5927\u6cd5\u5c06\u4f1a\u53d1\u6325\u4f5c\u7528<\/p>\n\n\n\n<p>\u4e00\u3001&nbsp;\u8981\u6c42\uff1a<\/p>\n\n\n\n<p>1.\u540e\u7aef\uff1aIDEAmaven<br>2.\u524d\u7aef\uff1anode\u3001vue\u73af\u5883<br>3.\u6570\u636e\u5e93\uff1amysql<\/p>\n\n\n\n<p>\u4e8c\u3001\u6b65\u9aa4\uff1a<br>1.\u83b7\u53d6\u4ee3\u7801\u653e\u7f6e\u5230\u76f8\u5e94\u76ee\u5f55<br>2.\u540e\u7aef\u4ee3\u7801\u5904\u7406<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>jdk\u7248\u672c<\/li>\n\n\n\n<li>maven\u914d\u7f6e\uff08\u8def\u5f84\u914d\u7f6e\u3001\u662f\u5426\u751f\u6548\uff09<\/li>\n\n\n\n<li>\u6267\u884c\u6570\u636e\u5e93\u7684\u811a\u672c\u548c\u4fee\u6539\u6570\u636e\u5e93\u8fde\u63a5\u914d\u7f6e\u4e3b\u673aip<\/li>\n\n\n\n<li>\u542f\u52a8\u670d\u52a1\u9a8c\u8bc1<br><br>\u00a0\u53f3\u952epom\u6587\u4ef6add maven\u5373\u53ef<\/li>\n<\/ul>\n\n\n\n<p>3.\u524d\u7aef\u4ee3\u7801\u5904\u7406<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u52a0\u8f7d\u4f9d\u8d56\u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0npm i<\/li>\n\n\n\n<li>\u914d\u7f6e\u6267\u884c\u73af\u5883<\/li>\n\n\n\n<li>\u542f\u52a8\u9a8c\u8bc1<\/li>\n<\/ul>\n\n\n\n<h1 class=\"wp-block-heading\">\u4e09\u5341\u516d\u3001Vuex\u6301\u4e45\u5316\u540e\u6d4f\u89c8\u5668\u5237\u65b0\u4e22\u5931\u6570\u636e<\/h1>\n\n\n\n<h3 class=\"wp-block-heading\">1.\u5206\u6790<\/h3>\n\n\n\n<p>vuex\u6301\u4e45\u5316\u540e\uff0c\u6bcf\u5f53\u6d4f\u89c8\u5668\u5237\u65b0\u5c31\u4f1a\u4e22\u5931state\u4e2d\u7684\u6570\u636e<br>\u6709\u6ca1\u6709\u529e\u6cd5\u53ef\u4ee5\u4fdd\u5b58\u8fd9\u4e2astate\u7684\u6570\u636e\u5462\uff1f<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">2.\u63d2\u4ef6vuex-persistedstate\u4f7f\u7528<\/h3>\n\n\n\n<p>\u5b89\u88c5\uff1anpm i vuex-persistedstate<br>\u5728store\/index.js \u5f15\u5165\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">import createPersistedState from 'vuex-persistedstate'<\/pre>\n\n\n\n<p><br>\u4f7f\u7528\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">plugins:[createPersistedState()]<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">3.\u83dc\u5355\u95ee\u9898\u89e3\u51b3<\/h3>\n\n\n\n<p>\u83dc\u5355\u8fd8\u5728\u4f46\u662f\u8def\u7531\u6ca1\u4e86<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">4.\u52a8\u6001\u8def\u7531\u95ee\u9898<\/h3>\n\n\n\n<p>\u5728App.vue\u4e2d<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;template&gt;\n  &lt;div id=\"app\"&gt;\n    &lt;router-view&gt;&lt;\/router-view&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\n\n\n\nexport default {\n  name: 'App',\n  components: { },\n  data(){\n    return{\n      user:JSON.parse(sessionStorage.getItem('CurUser')),\n    }\n  },\n  watch:{\n    '$store.state.menu':{\n      handler(val,old){\n        if(!old&amp;&amp;this.user&amp;&amp;this.user.no){\n          this.$store.commit(\"setRouter\",val)\n        }\n      },\n      immediate:true\n    }\n  }\n}\n&lt;\/script&gt;\n\n&lt;style&gt;\n\n&lt;\/style&gt;\n<\/code><\/pre>\n\n\n\n<p>store\/index.js\u4e2d\u6dfb\u52a0<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">mutations: {\n    setMenu(state,menuList) {\n        state.menu=menuList\n        addNewRoute(menuList)\n    },\n    setRouter(state,menuList) {\n        addNewRoute(menuList)\n    }\n},<\/pre>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4e09\u5341\u4e09\u3001\u51fa\u5165\u5e93\u7ba1\u7406 &nbsp;Header.vue\u5bfc\u4e00\u4e0b,RecordController\u52a0\u4e00\u4e2a GoodsManage.vue &#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"emotion":"","emotion_color":"","title_style":"","license":"","footnotes":""},"categories":[3],"tags":[19,20],"class_list":["post-749","post","type-post","status-publish","format-standard","hentry","category-3","tag-java","tag-20"],"_links":{"self":[{"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/posts\/749","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/eve2333.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=749"}],"version-history":[{"count":1,"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/posts\/749\/revisions"}],"predecessor-version":[{"id":751,"href":"https:\/\/eve2333.top\/index.php?rest_route=\/wp\/v2\/posts\/749\/revisions\/751"}],"wp:attachment":[{"href":"https:\/\/eve2333.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=749"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/eve2333.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=749"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/eve2333.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=749"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}