{"id":950,"date":"2025-08-18T14:44:22","date_gmt":"2025-08-18T06:44:22","guid":{"rendered":"https:\/\/www.ikaros.love\/?p=950"},"modified":"2025-08-18T14:44:22","modified_gmt":"2025-08-18T06:44:22","slug":"vue%e8%b8%a9%e5%9d%91%ef%bc%9a%e5%bc%82%e6%ad%a5%e6%93%8d%e4%bd%9c%e4%b8%8e%e6%95%b0%e6%8d%ae%e5%bc%95%e7%94%a8","status":"publish","type":"post","link":"https:\/\/www.ikaros.love\/?p=950","title":{"rendered":"Vue\u8e29\u5751\uff1a\u5f02\u6b65\u64cd\u4f5c\u4e0e\u6570\u636e\u5f15\u7528"},"content":{"rendered":"\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"386\" height=\"386\" src=\"https:\/\/www.ikaros.love\/wp-content\/uploads\/2025\/08\/163.png\" alt=\"\" class=\"wp-image-952\" srcset=\"https:\/\/www.ikaros.love\/wp-content\/uploads\/2025\/08\/163.png 386w, https:\/\/www.ikaros.love\/wp-content\/uploads\/2025\/08\/163-300x300.png 300w, https:\/\/www.ikaros.love\/wp-content\/uploads\/2025\/08\/163-150x150.png 150w, https:\/\/www.ikaros.love\/wp-content\/uploads\/2025\/08\/163-200x200.png 200w\" sizes=\"(max-width: 386px) 100vw, 386px\" \/><\/figure>\n\n\n\n<p>\u5728\u524d\u7aef\u5f00\u53d1\u4e2d\uff0c\u4f7f\u7528<code>Vue<\/code>\u548c<code>Element UI<\/code>\u7684<code>el-upload<\/code>\u7ec4\u4ef6\u5b9e\u73b0\u6587\u4ef6\u4e0a\u4f20\u662f\u5e38\u89c1\u9700\u6c42\u3002\u7136\u800c\uff0c\u5f53\u9700\u8981\u5904\u7406\u6279\u91cf\u4e0a\u4f20\u65f6\uff0c\u4e00\u4e2a\u770b\u4f3c\u7b80\u5355\u7684\u529f\u80fd\u53ef\u80fd\u4f1a\u57cb\u4e0b\u6df1\u5751\u3002\u672c\u6587\u5c06\u590d\u76d8\u4e00\u4e2a\u6211\u5728\u5b9e\u8df5\u4e2d\u9047\u5230\u7684\u95ee\u9898\uff1a<code>el-upload<\/code>\u6279\u91cf\u4e0a\u4f20\u529f\u80fd\u5931\u6548\uff0c\u660e\u660e\u7f51\u7edc\u8bf7\u6c42\u548c\u6570\u636e\u8fd4\u56de\u90fd\u6b63\u5e38\uff0c\u4f46\u6570\u636e\u5374\u65e0\u6cd5\u6b63\u786e\u540c\u6b65\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\">\u95ee\u9898\u91cd\u73b0\uff1a\u73b0\u8c61\u4e0e\u521d\u6b65\u5206\u6790<\/h3>\n\n\n\n<p>\u6211\u5728\u4e00\u4e2a\u8868\u5355\u4e2d\u9700\u8981\u4e0a\u4f20\u591a\u4efd\u94f6\u884c\u6d41\u6c34\u548c\u7528\u836f\u660e\u7ec6\u3002\u4e24\u8005\u90fd\u4f7f\u7528<code>el-upload<\/code>\uff0c\u5e76\u5f00\u542f\u4e86<code>multiple<\/code>\u5c5e\u6027\u4ee5\u652f\u6301\u6279\u91cf\u9009\u62e9\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;el-upload action=\"\" multiple :http-request=\"({ file }) => handleBankStatementUpload({ file }, index)\">\r\n  &lt;\/el-upload>\r\n\r\n&lt;el-upload action=\"\" multiple :http-request=\"({ file }) => handleMedicationBreakdownUpload({ file }, item)\">\r\n  &lt;\/el-upload><\/code><\/pre>\n\n\n\n<p>\u4e24\u4e2a\u4e0a\u4f20\u51fd\u6570\u90fd\u63a5\u53d7\u4e00\u4e2a\u6570\u636e\u5bf9\u8c61\u4f5c\u4e3a\u53c2\u6570\uff0c\u5e76\u5728\u6587\u4ef6\u4e0a\u4f20\u6210\u529f\u540e\uff0c\u5c06\u6587\u4ef6\u4fe1\u606f<code>push<\/code>\u5230\u8be5\u5bf9\u8c61\u7684\u5b50\u5217\u8868\u4e2d\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ \u4ee5\u7528\u836f\u660e\u7ec6\u4e3a\u4f8b\r\nhandleMedicationBreakdownUpload({ file }, targetObject) {\r\n  \/\/ ... \u4e0a\u4f20\u903b\u8f91\r\n  uploadCommonFile(formData).then(res => {\r\n    \/\/ \u6210\u529f\u540e\uff0c\u5c06\u6587\u4ef6\u4fe1\u606f\u6dfb\u52a0\u5230\u76ee\u6807\u5bf9\u8c61\u7684\u5217\u8868\r\n    targetObject.listOfMedicationBreakdown.push({\r\n      \/\/ ... \u6587\u4ef6\u6570\u636e\r\n    });\r\n    \/\/ \u901a\u77e5\u7236\u7ec4\u4ef6\u66f4\u65b0\u6570\u636e\r\n    this.emitUpdate();\r\n  });\r\n}<\/code><\/pre>\n\n\n\n<p>\u94f6\u884c\u6d41\u6c34\u529f\u80fd\u4e00\u5207\u6b63\u5e38\uff0c\u800c\u7528\u836f\u660e\u7ec6\u5374\u51fa\u4e86\u95ee\u9898\u3002\u5f53\u6211\u4e00\u6b21\u6027\u4e0a\u4f204\u5f20\u56fe\u7247\u65f6\uff0c\u7f51\u7edc\u8bf7\u6c42\u663e\u793a4\u4e2a\u6587\u4ef6\u90fd\u4e0a\u4f20\u6210\u529f\u5e76\u8fd4\u56de\u4e86\u6b63\u786e\u7684\u6570\u636e\uff0c\u4f46\u9875\u9762\u4e0a\u53ea\u663e\u793a\u4e86\u7b2c\u4e00\u5f20\u56fe\u7247\uff0c\u540e\u7eed\u76843\u5f20\u56fe\u7247\u6570\u636e\u90fd\u201c\u51ed\u7a7a\u6d88\u5931\u201d\u4e86\u3002<\/p>\n\n\n\n<p>\u6211\u4e00\u5ea6\u6000\u7591\u662f<code>emitUpdate()<\/code>\u51fd\u6570\u6709\u95ee\u9898\uff0c\u56e0\u4e3a\u5b83\u4f1a\u901a\u77e5\u7236\u7ec4\u4ef6\u66f4\u65b0\u6570\u636e\uff0c\u53ef\u80fd\u5bfc\u81f4\u5b50\u7ec4\u4ef6\u91cd\u65b0\u6e32\u67d3\uff0c\u4ece\u800c\u4e2d\u65ad\u4e86\u540e\u7eed\u7684\u4e0a\u4f20\u64cd\u4f5c\u3002\u4f46\u5f53\u6211\u6ce8\u91ca\u6389\u5b83\u540e\uff0c\u6279\u91cf\u4e0a\u4f20\u786e\u5b9e\u6062\u590d\u4e86\u6b63\u5e38\uff0c\u8fd9\u4f3c\u4e4e\u8bc1\u5b9e\u4e86\u6211\u7684\u731c\u6d4b\u3002\u7136\u800c\uff0c\u8fd9\u5e76\u4e0d\u662f\u4e00\u4e2a\u771f\u6b63\u7684\u89e3\u51b3\u65b9\u6848\uff0c\u56e0\u4e3a\u7236\u5b50\u7ec4\u4ef6\u7684\u6570\u636e\u540c\u6b65\u4f9d\u7136\u662f\u5fc5\u987b\u7684\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\">\u6df1\u5165\u63a2\u7a76\uff1a\u95ee\u9898\u7684\u672c\u8d28<\/h3>\n\n\n\n<p>\u7ecf\u8fc7\u53cd\u590d\u8c03\u8bd5\u548c\u601d\u8003\uff0c\u6211\u610f\u8bc6\u5230\u95ee\u9898\u5e76\u975e\u51fa\u5728<code>emitUpdate()<\/code>\u672c\u8eab\uff0c\u800c\u662f\u51fa\u5728 <strong><code>el-upload<\/code>\u7684\u5f02\u6b65\u5e76\u884c\u7279\u6027<\/strong> \u4e0e <strong>Vue\u7684\u54cd\u5e94\u5f0f\u6570\u636e\u5f15\u7528<\/strong> \u4e4b\u95f4\u7684\u51b2\u7a81\u3002<\/p>\n\n\n\n<ol start=\"1\">\n<li><strong>\u5f02\u6b65\u5e76\u884c\u4e0a\u4f20\uff1a<\/strong> \u5f53\u6211\u4eec\u6279\u91cf\u9009\u62e9\u591a\u4e2a\u6587\u4ef6\u65f6\uff0c<code>el-upload<\/code>\u4f1a\u4e3a\u6bcf\u4e2a\u6587\u4ef6\u5355\u72ec\u53d1\u8d77\u4e00\u4e2a<code>http-request<\/code>\u8bf7\u6c42\u3002\u8fd9\u4e9b\u8bf7\u6c42\u662f <strong>\u5e76\u884c<\/strong> \u7684\uff0c\u800c\u4e0d\u662f\u4e32\u884c\u7684\u3002<\/li>\n\n\n\n<li><strong><code>v-for<\/code>\u7684\u4e34\u65f6\u53d8\u91cf\u5f15\u7528\uff1a<\/strong> \u5728\u6211\u7684\u4ee3\u7801\u4e2d\uff0c<code>handleMedicationBreakdownUpload<\/code> \u51fd\u6570\u7684\u7b2c\u4e8c\u4e2a\u53c2\u6570<code>item<\/code>\u662f\u6765\u81ea<code>v-for<\/code>\u5faa\u73af\u751f\u6210\u7684\u4e34\u65f6\u53d8\u91cf\u3002\u5b83\u662f\u4e00\u4e2a\u6307\u5411\u5f53\u524d\u6570\u636e\u5bf9\u8c61\u7684<strong>\u5f15\u7528<\/strong>\u3002<\/li>\n\n\n\n<li><strong>\u81f4\u547d\u7684\u5f02\u6b65\u51b2\u7a81\uff1a<\/strong>\n<ul>\n<li><code>el-upload<\/code>\u540c\u65f6\u53d1\u8d774\u4e2a\u4e0a\u4f20\u8bf7\u6c42\uff0c\u6bcf\u4e2a\u8bf7\u6c42\u7684<code>handleMedicationBreakdownUpload<\/code>\u51fd\u6570\u90fd\u62ff\u5230\u4e86\u5404\u81ea\u7684<code>item<\/code>\u5f15\u7528\u3002<\/li>\n\n\n\n<li>\u7b2c\u4e00\u4e2a\u8bf7\u6c42\u5f88\u5feb\u5b8c\u6210\uff0c\u5e76\u6267\u884c<code>targetObject.listOfMedicationBreakdown.push(...)<\/code>\u3002<\/li>\n\n\n\n<li>\u7d27\u63a5\u7740\uff0c<code>this.emitUpdate()<\/code>\u88ab\u8c03\u7528\uff0c\u901a\u77e5\u7236\u7ec4\u4ef6\u6570\u636e\u5df2\u66f4\u65b0\u3002Vue\u7684\u54cd\u5e94\u5f0f\u7cfb\u7edf\u4f1a\u91cd\u65b0\u6e32\u67d3\u7ec4\u4ef6\uff0c\u8fd9\u53ef\u80fd\u5bfc\u81f4<code>v-for<\/code>\u5faa\u73af\u4e2d<strong>\u539f\u6709\u7684<code>item<\/code>\u5f15\u7528\u5931\u6548\u6216\u88ab\u91cd\u65b0\u521b\u5efa<\/strong>\u3002<\/li>\n\n\n\n<li>\u6b64\u65f6\uff0c\u5176\u4ed63\u4e2a\u8bf7\u6c42\u4ecd\u5728\u8fdb\u884c\u4e2d\u3002\u5f53\u5b83\u4eec\u6210\u529f\u5b8c\u6210\u540e\uff0c\u4f1a\u5c1d\u8bd5\u64cd\u4f5c\u5404\u81ea\u7684<code>item<\/code>\u5f15\u7528\u3002\u7136\u800c\uff0c\u8fd9\u4e9b\u5f15\u7528\u6307\u5411\u7684\u5185\u5b58\u5730\u5740\u5df2\u7ecf\u4e0d\u518d\u662f\u6b63\u786e\u7684\u3001\u53ef\u7528\u7684\u6570\u636e\u5bf9\u8c61\u4e86\u3002\u56e0\u6b64\uff0c\u6570\u636e\u6dfb\u52a0\u64cd\u4f5c\u5931\u8d25\uff0c\u6587\u4ef6\u4eff\u4f5b\u201c\u6d88\u5931\u201d\u4e86\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<p>\u8fd9\u5c31\u50cf\u56db\u4e2a\u4eba\u540c\u65f6\u5f80\u4e00\u4e2a\u62bd\u5c49\u91cc\u653e\u4e1c\u897f\uff0c\u4f46\u6bcf\u653e\u4e00\u6b21\uff0c\u62bd\u5c49\u7684\u4f4d\u7f6e\u5c31\u4f1a\u79fb\u52a8\u4e00\u4e0b\u3002\u6700\u7ec8\uff0c\u53ea\u6709\u7b2c\u4e00\u4e2a\u4eba\u6210\u529f\u4e86\uff0c\u5269\u4e0b\u7684\u4eba\u90fd\u627e\u4e0d\u5230\u539f\u6765\u7684\u62bd\u5c49\u4e86\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\">\u6700\u7ec8\u89e3\u51b3\u65b9\u6848\uff1a\u76f4\u63a5\u64cd\u4f5c\u6839\u6570\u636e\u7ed3\u6784<\/h3>\n\n\n\n<p>\u65e2\u7136\u4e34\u65f6\u53d8\u91cf\u7684\u5f15\u7528\u4e0d\u53ef\u9760\uff0c\u90a3\u4e48\u6b63\u786e\u7684\u505a\u6cd5\u5c31\u662f <strong>\u76f4\u63a5\u64cd\u4f5c\u7a33\u5b9a\u3001\u6301\u4e45\u7684\u6570\u636e\u7ed3\u6784<\/strong>\u3002<\/p>\n\n\n\n<p>\u6211\u4fee\u6539\u4e86<code>handleMedicationBreakdownUpload<\/code>\u51fd\u6570\uff0c\u4e0d\u518d\u4f9d\u8d56\u4f20\u5165\u7684<code>item<\/code>\u53c2\u6570\uff0c\u800c\u662f\u901a\u8fc7<strong>\u7d22\u5f15<\/strong>\u76f4\u63a5\u5b9a\u4f4d\u5230\u6839\u6570\u636e\u5bf9\u8c61\uff0c\u4ece\u800c\u907f\u514d\u4e86\u5f15\u7528\u5931\u6548\u7684\u95ee\u9898\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ \u4fee\u6539\u540e\u7684\u6b63\u786e\u4ee3\u7801\r\nhandleMedicationBreakdownUpload({ file }, index) {\r\n  const formData = new FormData();\r\n  formData.append('file', file);\r\n  return uploadCommonFile(formData).then(res => {\r\n    \/\/ \u68c0\u67e5\u91cd\u590d\u6587\u4ef6\r\n    for (let i = 0; i &lt; this.localCostOfCareData.listOfHospitalisationRecords&#91;index].listOfMedicationBreakdown.length; i++) {\r\n      if (this.localCostOfCareData.listOfHospitalisationRecords&#91;index].listOfMedicationBreakdown&#91;i].name === res.fileName) {\r\n        this.$message.error('\u7981\u6b62\u4e0a\u4f20\u91cd\u590d\u6587\u4ef6');\r\n        return Promise.reject();\r\n      }\r\n    }\r\n    \/\/ \u76f4\u63a5\u901a\u8fc7\u6839\u6570\u636e\u7ed3\u6784\u548c\u7d22\u5f15\u6765\u64cd\u4f5c\u76ee\u6807\u6570\u7ec4\r\n    this.localCostOfCareData.listOfHospitalisationRecords&#91;index].listOfMedicationBreakdown.push({\r\n      id: Date.now(),\r\n      url: res.url,\r\n      name: res.fileName,\r\n      dynamicTags: &#91;],\r\n      check: true\r\n    });\r\n    \/\/ \u4ec5\u5728\u6570\u636e\u6b63\u786e\u6dfb\u52a0\u540e\uff0c\u901a\u77e5\u7236\u7ec4\u4ef6\u66f4\u65b0\r\n    this.emitUpdate();\r\n    return res;\r\n  }).catch(error => {\r\n    console.log(error);\r\n    this.$message.error('\u4e0a\u4f20\u5931\u8d25\uff01');\r\n    return Promise.reject(error);\r\n  });\r\n},<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u603b\u7ed3\u4e0e\u8b66\u793a<\/h3>\n\n\n\n<p>\u8fd9\u4e2a\u95ee\u9898\u7684\u6838\u5fc3\u5728\u4e8e\uff1a\u5728\u5904\u7406<strong>\u5f02\u6b65\u5e76\u884c\u64cd\u4f5c<\/strong>\u65f6\uff0c\u4e0d\u8981\u4f9d\u8d56\u5faa\u73af\u751f\u6210\u7684<strong>\u4e34\u65f6\u53d8\u91cf<\/strong>\u4f5c\u4e3a\u6570\u636e\u5f15\u7528\u7684\u76ee\u6807\u3002<\/p>\n\n\n\n<ul>\n<li><strong>\u9519\u8bef\u505a\u6cd5\uff1a<\/strong> <code>v-for=\"(item, index)\" ... :http-request=\"({ file }) =&gt; handleUpload(file, item)\"<\/code>\u3002\u8fd9\u79cd\u65b9\u5f0f\u5728\u5f02\u6b65\u5e76\u53d1\u573a\u666f\u4e0b\uff0c<code>item<\/code>\u7684\u5f15\u7528\u53ef\u80fd\u4f1a\u56e0\u54cd\u5e94\u5f0f\u66f4\u65b0\u800c\u5931\u6548\u3002<\/li>\n\n\n\n<li><strong>\u6b63\u786e\u505a\u6cd5\uff1a<\/strong> <code>v-for=\"(item, index)\" ... :http-request=\"({ file }) =&gt; handleUpload(file, index)\"<\/code>\u3002\u901a\u8fc7\u4f20\u9012\u7a33\u5b9a\u7684<strong>\u7d22\u5f15<\/strong>\uff0c\u7136\u540e\u5728\u51fd\u6570\u5185\u90e8\u901a\u8fc7\u6839\u6570\u636e\u7ed3\u6784\u6765\u5b9a\u4f4d\u76ee\u6807\u6570\u7ec4\uff0c\u4ece\u800c\u786e\u4fdd\u64cd\u4f5c\u7684\u6b63\u786e\u6027\u548c\u4e00\u81f4\u6027\u3002<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u5728\u524d\u7aef\u5f00\u53d1\u4e2d\uff0c\u4f7f\u7528Vue\u548cEle&#46;&#46;&#46;<\/p>\n","protected":false},"author":1,"featured_media":952,"comment_status":"open","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[251,253,252],"_links":{"self":[{"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/posts\/950"}],"collection":[{"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=950"}],"version-history":[{"count":1,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/posts\/950\/revisions"}],"predecessor-version":[{"id":953,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/posts\/950\/revisions\/953"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=\/wp\/v2\/media\/952"}],"wp:attachment":[{"href":"https:\/\/www.ikaros.love\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=950"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=950"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.ikaros.love\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=950"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}