原生微信小程序做视频和图片上传wx.chooseMedia({})

原来的旧的方法已经被遗弃,现在最新上传视频和图片的方法用的是wx.chooseMedia({}),共同用这个方法,参数不一样;

code:

wxml:


                          <!-- 上传图片 -->
<view class="upload-box" bindtap="uploadImage">
    上传图片
</view>

js:


  uploadImage(){
    wx.chooseMedia({
      count: 1,
      // mediaType: ['image','video'], ==》注意:都兼容上传就这么写,只是单上传其中一个,就只是一个
      mediaType: ['image'],
      sourceType: ['album', 'camera'],
      maxDuration: 30,
      camera: 'back',
      success(res) {
        // console.log(res.tempFiles[0].tempFilePath)
      }
    })

  },

总结:

1.注意参数mediaType参数,该参数为数组,想要点击分别都可以上传图片和视频,就mediaType: ['image','video'],这么写,只是图片就mediaType: ['image'],当然视频就是:mediaType: ['video']!

<think>好的,用户需要实现微信小程序中通过点击头像并输入司机号进行注册登录的功能代码示例。首先,我需要明确用户的具体需求。用户提到了点击头像、输入司机号、注册登录这几个功能点。可能用户是想让用户通过点击头像选择上传头像,然后输入司机号进行注册登录操作。 接下来,我需要考虑微信小程序的开发框架。根据提供的引用,用户可能使用的是原生小程序开发者mpvue框架。引用[3]提到了mpvuevuex的使用,但用户这次的问题可能更偏向于原生小程序的实现,因为用户直接询问的是页面代码示例。不过,为了全面性,可能需要考虑两种方式的代码示例,但根据引用中的代码示例,例如引用[1]中的uni.login,看起来像是使用uni-app的代码,但用户提供的引用也有提到mpvue。不过,用户可能更希望得到原生小程序的代码,因为uni-appmpvue都是跨框架的,但原生代码更直接。 然后,分析功能点: 1. 点击头像:需要绑定点击事件,触发选择图片上传头像的功能。微信小程序提供了wx.chooseImagewx.chooseMedia API(根据版本不同)。引用[2]提到小程序可以调用原生接口,如图片选择。 2. 输入司机号:需要一个输入框,绑定输入事件,获取用户输入的司机号。 3. 注册登录:需要调用后端API,发送司机号头像信息。需要处理登录逻辑,可能涉及wx.login获取code,然后发送到服务器换取openidsession_key。引用[1]中的uni.login示例,但原生小程序应使用wx.login。 4. 页面结构:包括头像图片显示、输入框、按钮等元素。 接下来,需要整合这些功能到wxml、wxss、jsjson文件中。例如,在wxml中,使用image组件显示头像,并绑定tap事件;使用input组件获取司机号;按钮触发注册登录事件。 在JS部分,处理头像选择,使用wx.chooseImagewx.chooseMedia,更新页面的头像URL。输入框通过bindinput事件更新data中的driverId。注册登录按钮点击后,验证输入,调用wx.login获取code,然后发送请求到服务器,携带code、driverIdavatarUrl。需要处理成功失败的回调,比如跳转页面提示错误。 还需要考虑引用中的相关内容。例如,引用[4]提供了微信支付文档链接,虽然当前问题不涉及支付,但可能登录后需要用到支付功能,但用户当前的问题主要集中在注册登录部分。引用[3]提到vuex的使用,但如果是原生小程序,可能需要使用全局变量缓存,比如wx.setStorageSync来保存登录状态。 另外,引用[2]提到小程序调用原生接口的优势,比如导航、登录等,所以登录功能应使用wx.login接口。同时,上传头像可能需要用到wx.uploadFile接口,将头像上传到服务器。 可能的代码结构: - WXML:头像图片,绑定点击事件;输入框绑定driverId;按钮绑定提交事件。 - JS:处理头像选择,更新data;收集driverId;调用登录注册API。 - WXSS:样式调整,如头像圆形,布局居中。 - JSON:配置页面,可能需要权限声明,如chooseImage需要的权限。 需要注意的细节: - 头像上传可能需要服务器支持,代码中需要处理上传路径。 - 司机号的输入验证,如非空、格式等。 - 注册登录的逻辑是否合并,比如根据司机号是否存在决定是注册还是登录。 - 使用wx.showToast等反馈用户操作结果。 最后,根据用户提供的引用,特别是引用[1]中的uni.login示例,但需要转换为原生小程序wx.login。同时引用[3]的vuex可能在状态管理上使用,但原生小程序可以用globalData缓存代替。 总结步骤: 1. 页面布局:头像、输入框、按钮。 2. 头像选择功能。 3. 输入框数据绑定。 4. 登录注册逻辑,调用后端API。 5. 处理响应,跳转提示。</think>以下是微信小程序实现点击头像、输入司机号注册登录功能的代码示例: ### 1. 页面结构(index.wxml) ```html <view class="container"> <!-- 头像点击区域 --> <view class="avatar-container" bindtap="chooseAvatar"> <image src="{{avatarUrl}}" class="avatar" mode="aspectFill"/> <text class="tip-text">点击上传头像</text> </view> <!-- 司机号输入 --> <input class="input-box" placeholder="请输入司机号" maxlength="20" bindinput="onDriverIdInput" /> <!-- 提交按钮 --> <button class="submit-btn" type="primary" bindtap="handleSubmit" >立即注册/登录</button> </view> ``` ### 2. 页面样式(index.wxss) ```css .container { padding: 40rpx; display: flex; flex-direction: column; align-items: center; } .avatar-container { position: relative; margin-bottom: 60rpx; } .avatar { width: 200rpx; height: 200rpx; border-radius: 50%; border: 4rpx solid #eee; } .tip-text { position: absolute; bottom: -40rpx; left: 50%; transform: translateX(-50%); font-size: 24rpx; color: #888; } .input-box { width: 80%; height: 80rpx; margin: 40rpx 0; padding: 0 20rpx; border: 2rpx solid #ddd; border-radius: 8rpx; } .submit-btn { width: 80%; margin-top: 60rpx; } ``` ### 3. 页面逻辑(index.js) ```javascript Page({ data: { avatarUrl: '/images/default-avatar.png', // 默认头像 driverId: '' }, // 选择头像 chooseAvatar() { wx.chooseMedia({ count: 1, mediaType: ['image'], success: res => { this.setData({ avatarUrl: res.tempFiles[0].tempFilePath }) this.uploadAvatar(res.tempFiles[0].tempFilePath) // 上传到服务器 } }) }, // 上传头像到服务器 uploadAvatar(tempFilePath) { wx.uploadFile({ url: 'https://your-domain.com/upload', filePath: tempFilePath, name: 'avatar', success: res => { const data = JSON.parse(res.data) if (data.code === 200) { this.setData({ avatarUrl: data.url }) } } }) }, // 输入司机号 onDriverIdInput(e) { this.setData({ driverId: e.detail.value.trim() }) }, // 提交表单 handleSubmit() { if (!this.data.driverId) { wx.showToast({ title: '请输入司机号', icon: 'none' }) return } wx.login({ success: res => { if (res.code) { wx.request({ url: 'https://your-domain.com/api/login', method: 'POST', data: { code: res.code, driverId: this.data.driverId, avatar: this.data.avatarUrl }, success: res => { if (res.data.code === 200) { wx.setStorageSync('token', res.data.token) // 存储登录凭证 wx.showToast({ title: '登录成功' }) wx.switchTab({ url: '/pages/home/index' }) // 跳转到首页 } } }) } } }) } }) ``` ### 4. 页面配置(index.json) ```json { "usingComponents": {}, "navigationBarTitleText": "司机注册登录" } ``` ### 功能说明: 1. **头像上传**:使用`wx.chooseMedia`选择图片,通过`wx.uploadFile`上传到服务器[^2] 2. **登录流程**:通过`wx.login`获取临时code,发送到后台换取用户唯一标识[^1] 3. **数据存储**:登录成功后使用`wx.setStorageSync`存储会话凭证 4. **界面交互**:使用`wx.showToast`进行操作反馈,符合小程序交互规范[^2]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

we_前端全家桶

同行的老铁支援点银两哇,????

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值