账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    vue-element-admin中的表单提交上传图片问题
    30
    0

    父组件中有个表单,表单中使用了上传组件,如何提交表单再上传图片,我post使用了qs要不然我后端接收不到数据,是不是没法设置'Content-Type': 'multipart/form-data',上传组件应该传给父组件什么值?我直接传的file,传file的话再使用qs就有问题了,这个没弄过,不知道怎么办了

    上传组件中我是这样传值的:

    handleChange (file, fileList) {
      console.log('file:'+JSON.stringify(file))
      //这个输出为什么是这个{"status":"ready","name":"abc.jpg","size":1945,"percentage":0,"uid":1564044810591,"raw":{"uid":1564044810591}}这种给后端是不是不行啊?以往都是'name' => 'abc.jpg' 'type' =>'image/jpg' 'tmp_name' => 'E:\wamp\tmp\php240B.tmp' 'error' => 0 'size' => 1945
      var windowURL = window.URL || window.webkitURL;
      this.dialogImageUrl=window.URL.createObjectURL(file.raw);//上传图显示
      this.$emit('paramstxt',file);//传的file,不知道这样行不行,应该传给父组件什么?
    },
    
    

    父组件表单中:

    <el-form ref="postForm" :model="postForm" :rules="rules" class="form-container" label-width="100px">
      <sticky :z-index="10" :class-name="'sub-navbar '+postForm.status">
        <el-button v-loading="loading" type="success" @click="submitForm">
          提交保存
        </el-button>
      </sticky>
      <div class="createPost-main-container">
    
        <el-form-item style="margin-bottom: 35px;"  label="标题:" prop="title">
          <el-input v-model="postForm.title" :rows="1" type="textarea" :maxlength="100" required/>
        </el-form-item>
    
    
        <el-form-item prop="image_uri" style="margin-bottom: 30px;">
          <Upload @paramstxt="listenToMyBoy"/>
        </el-form-item>
    
      </div>
    </el-form>
    js部分:
    methods: {
    listenToMyBoy(data){
      console.log('data:'+JSON.stringify(data))
      this.postForm.image_uri = data
    },
    
    submitForm() {
      this.$refs['postForm'].validate((valid) => {
        if (valid) {
          this.loading = true
          this.postForm.act='newadd'
          newAdd(this.postForm).then(response => {
            this.$notify({
              title: '成功',
              message: '发布文章成功',
              type: 'success',
              duration: 2000
            })
            this.loading = false
          })
        } else {
          console.log('error submit!!')
          return false
        }
      })
    },

    }

    request.js

    // 创建axios实例
    const service = axios.create({
      baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
      // withCredentials: true, // 跨域请求时发送cookie
      transformRequest: data => qs.stringify(data),
      timeout: 5000 // request timeout
    })
    
    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    更多回答
    扫一扫访问手机版

    回答动态

    师傅被妖怪抓走了:发布了悬赏问题火爆全网的“元宇宙”到底是什么?预计能赚取 1积分收益
    酒后略带风情:发布了悬赏问题Android内存中Graphics与Code占用过高预计能赚取 10积分收益
    扛起拖把扫天下:发布了悬赏问题typescript如何导出接口配置?求解,谢谢!预计能赚取 10积分收益
    发布了悬赏问题Vue 如何改变返回页面的路径?如让B页面只能返回到A页面.预计能赚取 11积分收益
    发布了悬赏问题vue H5移动端;底部bottom固定定位,安卓弹起键盘导致页面变形如何解决?预计能赚取 10积分收益
    发布了悬赏问题请问为什么tomcat8.5 GET请求中文正常,POST请求还需要设置UTF-8.预计能赚取 10积分收益
    发布了悬赏问题vue2.5+ts创建以及引入jq的方法预计能赚取 11积分收益
    情场浪女:发布了悬赏问题import ggplot时报错module 'pandas' has no attribute 'tslib'预计能赚取 10积分收益
    见心书画许老师18753375161:发布了悬赏问题echarts3 legend禁止点击事件,允许悬浮事件预计能赚取 11积分收益
    aa_92cb0bd09f:发布了悬赏问题codewar上的一个问题预计能赚取 11积分收益