微信小程序(组件)----上传单张图片以及获取图片【wx.chooseMedia wx.uploadFile】

微信小程序(组件)----上传单张图片以及获取图片【wx.chooseMedia wx.uploadFile】

在这里插入图片描述
在这里插入图片描述

1.构建组件:

components/chooseMedia/chooseMedia.wxml

<view class="ipt">
  <image class="close1" src="/static/image/close1.png" bindtap="closeBtn" wx:if="{{isShow}}"></image>
  <image class="imgz" src="{{zwImg}}" wx:if="{{!isShow}}"  bindtap="chooseMedia"></image>
  <image class="imgz" src="{{bank_img}}" wx:if="{{isShow}}"  mode="aspectFill"></image>
</view>

components/chooseMedia/chooseMedia.js

// components/chooseMedia/chooseMedia.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    zwImg:{ //提交图片的默认图片
      type:String,
      value:'/static/image/jia.png'
    },
    bank_img:{ //上传的图片路径
      type:String,
      value:''
    },
    isShow:{
      type:Boolean,
      value:false
    }
  },

  /**
   * 组件的初始数据
   */
  data: {
  },

  /**
   * 组件的方法列表
   */
  methods: {
    // 选择图片
    chooseMedia() {
      wx.chooseMedia({
        count: 1,
        mediaType: ['image'],
        sourceType: ['album', 'camera'],
        maxDuration: 30,
        camera: 'back',
        success: (res) => {
          let tempFilePath = res.tempFiles[0].tempFilePath;
          this.uploadFile(tempFilePath)
        }
      })
    },
    // 上传图片到服务器
    uploadFile(tempFilePath) {
      wx.showLoading();
      wx.uploadFile({
        filePath: tempFilePath,
        name: 'file',
        url: getApp().globalData.url + 'common/upload',
        formData: {
          'data': 'bank_img'
        },
        success: (res) => {
          wx.hideLoading();
          const bank_img = JSON.parse(res.data).img; //把数据字符串转变成对象
          if(bank_img){
            this.setData({
              bank_img:bank_img,
              isShow:true
            })
          }     
          this.triggerEvent('chooseMedia', bank_img)      
        }
      })
    },

    // 删除上传图片
    closeBtn(){
      this.setData({
        isShow:false,
        bank_img:''
      })
    }
  }
})

components/chooseMedia/chooseMedia.wxss

/* components/chooseMedia/chooseMedia.wxss */
.imgz{
  width: 140rpx;
  height: 140rpx;
}
.close1{
  width: 50rpx;
  height: 50rpx;
  position: absolute;
  margin-left: 100rpx;
  margin-top: -20rpx;
}

2.引用组件:

在需要引进的json中引用组件:

"usingComponents": {
    "chooseMedia":"/components/chooseMedia/chooseMedia"
  },

在wxml中调用组件:

 <chooseMedia bindchooseMedia="chooseMedia" bank_img="{{infos.card_img}}" isShow="{{isShow}}"></chooseMedia>

在js中调用方法存入数据和发送给子组件数据:

  data: {
    user_id:'',
    isShow:false,
    infos:{}
  },
    // 获取信息
 async getInfos(){
    let infos = await return_method_desc();
    this.setData({
      infos:infos.data,
      isShow:true
    })
  },
  // 获取子组件数据
  chooseMedia(e){
    this.setData({
      ['infos.card_img']: e.detail
    })
  },
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值