当前位置: 首页 > article >正文

原生 input 中的 “type=file“ 上传文件

目标:实现文件上传功能

原型图:

HTML部分:

<div class="invoice-item">
                <div class="invoice-title">增值税专用发票</div>
                <div class="invoice-box">
                  <el-form-item label="标准模版:" class="Standard-Template">
                    <div v-show="!isEdit && !ruleForm.taxInvoiceTemplateUrl">
                      <span>待上传</span>
                    </div>
                    <div v-show="isEdit && !ruleForm.taxInvoiceTemplateUrl">
                      <input
                        ref="taxInvoiceTemplateRef"
                        type="file"
                        style="
                        opacity: 0;
                        position: absolute;
                        left: -9999px;
                        top: -9999px;
                      "
                        @change="taxInvoiceTempalteChange"
                      >
                      <i
                        class="el-icon-upload2"
                        style="color: #0075ff; font-size: 22px; cursor: pointer"
                        @click="$refs.taxInvoiceTemplateRef.click()"
                      />
                      <span
                        style="margin-left: 8px"
                        :style="{ color: errorText3 ? 'red' : '#999999' }"
                      >{{ errorText3 || "支持上传5M以内.pdf格式的文档" }}</span>
                    </div>
                    <div v-show="ruleForm.taxInvoiceTemplateUrl">
                      <i class="el-icon-document" />
                      <span>{{ ruleForm.taxInvoiceTemplateName }}</span>
                      <i
                        v-if="isEdit"
                        class="el-icon-circle-close"
                        style="cursor: pointer"
                        @click="deleteDoc('taxDigitalInvoice')"
                      />
                    </div>
                  </el-form-item>
                  <el-form-item
                    label="备注信息超长模板:"
                    class="Standard-Template"
                  >
                    <div
                      v-show="!isEdit && !ruleForm.taxInvoiceRemarkTemplateUrl"
                    >
                      <span>待上传</span>
                    </div>
                    <div
                      v-show="isEdit && !ruleForm.taxInvoiceRemarkTemplateUrl"
                    >
                      <input
                        ref="taxInvoiceRemarkTemplateRef"
                        type="file"
                        style="
                        opacity: 0;
                        position: absolute;
                        left: -9999px;
                        top: -9999px;
                      "
                        @change="taxInvoiceRemarkTemplateChange"
                      >
                      <i
                        class="el-icon-upload2"
                        style="
                        color: #0075ff;
                        font-size: 22px;
                        cursor: pointer;
                        padding-top: 10px;
                      "
                        @click="$refs.taxInvoiceRemarkTemplateRef.click()"
                      />
                      <span
                        style="margin-left: 0px; padding-top: 3px"
                        :style="{ color: errorText4 ? 'red' : '#999999' }"
                      >{{ errorText4 || "支持上传5M以内.pdf格式的文档" }}</span>
                    </div>
                    <div v-show="ruleForm.taxInvoiceRemarkTemplateUrl">
                      <i class="el-icon-document" />
                      <span>{{ ruleForm.taxInvoiceRemarkTemplateName }}</span>
                      <i
                        v-if="isEdit"
                        class="el-icon-circle-close"
                        style="cursor: pointer"
                        @click="deleteDoc('taxDigitalInvoiceRemarkInfo')"
                      />
                    </div>
                  </el-form-item>
                </div>
              </div>

JS部分:

import * as Api from '@/api/invoiceBasic'

data() {
    return {
      errorText3: '',
      errorText4: '',
      ruleForm: {
        // 数电发票基础模板

        taxInvoiceTemplateUrl: '', // 增值税 标准模板
        taxInvoiceTemplateName: '',

        taxInvoiceRemarkTemplateUrl: '',
        taxInvoiceRemarkTemplateName: '',

        sellerShowAccount: '0',
        invoiceOperator: ''
      },
      rules: {
        invoiceOperator: [
          { required: true, message: '请输入开票人', trigger: 'submit' }
        ]
      }
    }
  },

methods: {
    init() {
      this.getDetailData()
    },
    getDetailData() {
      this.pageLoading = true
      Api.ticketConfigFind()
        .then((res) => {
          const {
            taxInvoiceTemplateUrl, taxInvoiceTemplateName,
            taxInvoiceRemarkTemplateUrl, taxInvoiceRemarkTemplateName,
           
            sellerShowAccount, invoiceOperator
          } = res.data.body
          this.ruleForm.taxInvoiceTemplateUrl = taxInvoiceTemplateUrl
          this.ruleForm.taxInvoiceTemplateName = taxInvoiceTemplateName
          this.ruleForm.taxInvoiceRemarkTemplateUrl = taxInvoiceRemarkTemplateUrl
          this.ruleForm.taxInvoiceRemarkTemplateName = taxInvoiceRemarkTemplateName
          

          // this.ruleForm.taxInvoiceTemplateUrl = taxInvoiceTemplateUrl
          // this.ruleForm.taxInvoiceTemplateName = taxInvoiceTemplateName
          // this.ruleForm.ordinaryInvoiceTemplateUrl = ordinaryInvoiceTemplateUrl
          // this.ruleForm.ordinaryInvoiceTemplateName =
          //   ordinaryInvoiceTemplateName

          this.ruleForm.invoiceOperator = invoiceOperator
          this.ruleForm.sellerShowAccount = String(Number(sellerShowAccount))
        })
        .finally((_) => {
          this.pageLoading = false
        })
    },
    // 增值税专用发票 标准模板
    taxInvoiceTempalteChange(e) {
      const file = e.target.files[0]
      if (file.name.indexOf('.pdf') === -1 || file.size > 5 * 1024 * 1000) {
        this.errorText3 = '支持上传5M以内.pdf格式的文档'
        return
      }
      const f2 = new FormData()
      f2.append('file', file)
      Api.fastdfsUpload(f2).then((res) => {
        this.ruleForm.taxInvoiceTemplateName = file.name
        this.ruleForm.taxInvoiceTemplateUrl = res.data.body
      })
    },
    // 增值税专用发票 - 备注信息超长
    taxInvoiceRemarkTemplateChange(e) {
      const file = e.target.files[0]
      if (file.name.indexOf('.pdf') === -1 || file.size > 5 * 1024 * 1000) {
        this.errorText4 = '支持上传5M以内.pdf格式的文档'
        return
      }
      const f3 = new FormData()
      f3.append('file', file)
      Api.fastdfsUpload(f3).then((res) => {
        this.ruleForm.taxInvoiceRemarkTemplateName = file.name
        this.ruleForm.taxInvoiceRemarkTemplateUrl = res.data.body
      })
    },
},

CSS部分:

.invoice-item {

      float: left;

      width: 430px;

      height: 140px;

      // height: 126px;

      border-radius: 12px;

      margin-top: 12px;

      margin-bottom: 22px;

      background: linear-gradient(to right, #cfe8ff, #f8fcff);

      .invoice-box {

        width: 100%;

        .remark-Template {

          /deep/ .el-form-item {

            margin-bottom: 0px;

          }

        }

        /deep/ .el-form-item__label {

          width: fit-content !important;

          padding-left: 20px;

          font-weight: 600;

          font-size: 12px;

          color: #101010;

        }

        /deep/ .el-form-item__content {

          text-align: right;

          padding-right: 20px;

          margin-left: 180px !important;

        }

      }

    }

    .invoice-title {

      font-weight: 600;

      font-size: 16px;

      color: #0075ff;

      padding: 20px;

      padding-bottom: 8px;

    }

效果:


http://www.kler.cn/a/300310.html

相关文章:

  • [德州扑克]
  • 【物联网】keil仿真环境设置 keilV5可以适用ARM7
  • Linux容器(初学了解)
  • .Net Core微服务入门全纪录(五)——Ocelot-API网关(下)
  • 开源许可证(Open Source Licenses)
  • 深入探索Python人脸识别技术:从原理到实践
  • CMU 10423 Generative AI:HW1(理论部分)
  • AUTOSARUDS 理论要点及isolar实战-通用配置/代码梳理
  • 移动安全需求分析与安全保护工程
  • Linux 环境下Mysql没有开放公网端口连接创建数据库
  • Qt_自定义信号
  • 深入浅出:Android屏幕刷新机制
  • 【CanMV K230 AI视觉】 跌倒检测
  • IBM AS/400 数据库介绍、使用及优缺点——详细说明
  • 使用Spring Boot开发自习室预定系统
  • 速盾:cdn加速效果明显吗?
  • 结构型模式-python版
  • uniapp 原生插件开发 UI
  • 模板语法
  • Linux 文件相关知识
  • Qt 布局管理 控件设置
  • 【北京迅为】《STM32MP157开发板使用手册》- 第二十章 Trusted Firmware-A 移植+第二十一章 U-Boot移植
  • 通信工程学习:什么是CSCF会话控制功能、P-CSCF代理会话控制功能、I-CSCF询问会话控制功能、S-CSCF服务会话控制功能
  • Prometheus与Grafana在DevOps中的应用与最佳实践
  • 828华为云征文 | Flexus X的力量,驱动Halo博客在云端飞驰
  • 使用程序方式获取与处理MySQL表数据