若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试

这篇具有很好参考价值的文章主要介绍了若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文使用uView2的upload组件实现从手机相册上传,也可以拍照上传。此组件可以再小程序,h5,App端上传图片,使用方便。

若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试

1. 前端代码

<template>
	<view class="u-page">
		<view class="u-demo-block">
			<view class="u-demo-block__content">
				<!-- 注意,如果需要兼容微信小程序,最好通过setRules方法设置rules规则 -->
				<u--form
					labelPosition="left"
					:model="form"
					ref="form1"
				>		
            <u-form-item
				label="上传照片"
				prop="form.problemPhotos"
				borderBottom
				labelWidth="80"
				ref="item3"
			>
				<u-upload
					:fileList="fileList1"
					:previewFullImage="true"
					@afterRead="afterRead"
					@delete="deletePic"
					name="1"
					multiple
					:maxCount="10"
				></u-upload>
			</u-form-item>
		</u--form>
				<u-button
					type="primary"
					text="提交"
					customStyle="margin-top: 50px"
					@click="submit"
				></u-button>
            </view>
		</view>
	</view>
</template>

2. 读取照片或者上传照片

本文在uview2的upload上传组件基础上进行了修改Upload 上传 | uView 2.0 - 全面兼容nvue的uni-app生态框架 - uni-app UI框架

(1)上传文件,url写成自己的后台路径,header参照的是若依电脑端的写法。

     uni.uploadFile({
                url: '/dev-api/common/upload', 
                header: {
                        Authorization: "Bearer " + getToken(),
                      },
                filePath: url,
                name: 'file',

(2)将文件的路径/profile/upload/2023/02/27/123_20230227141005A061.jpg通过uploadFilePromise函数返回值resolve(JSON.parse(res.data).fileName)赋值给fileList数组对象的 rl。

(3)然后在submit提交的时候将数组转化成字符串用‘,’隔开赋值给this.form.problemPhotos。

                      let images = []    
                        this.fileList1.forEach((item) => {
                                     images.push(item.rl)
                                 })
                         this.form.problemPhotos=images.join(',');

具体代码如下:

import { getToken } from "@/utils/auth";
<script>
	export default {
		data() {
			return {
				fileList1: [],
			}
		},
		methods: {
		// 删除图片
			deletePic(event) {
			this[`fileList${event.name}`].splice(event.index, 1)
			},
						// 新增图片
			async afterRead(event) {
				
				// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式
				let lists = [].concat(event.file)		
				let fileListLen = this[`fileList${event.name}`].length
				lists.map((item) => {
				this[`fileList${event.name}`].push({
				...item,
				status: 'uploading',
				message: '上传中'
				})
				})
				console.log(this.fileList1)
				for (let i = 0; i < lists.length; i++) {
					const result = await this.uploadFilePromise(lists[i].url)		
					let item = this[`fileList${event.name}`][fileListLen]
					this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
					status: 'success',
					message: '',
					rl: result
					}))
					fileListLen++
					}

				console.log(this.fileList1);
				//this.problemPhotos=this.fileList1;
			},
		    uploadFilePromise(url) {
	            let _self=this;
		    	return new Promise((resolve, reject) => {
		    	let a = uni.uploadFile({
		    	url: '/dev-api/common/upload', 
				header: {
				        Authorization: "Bearer " + getToken(),
				      },
		    	filePath: url,
		    	name: 'file',
		    	success: (res) => {
					 let result = JSON.parse(res.data)
				   //	console.log(result.fileName);
		    		setTimeout(() => {				   
		    		resolve(JSON.parse(res.data).fileName)
		    		}, 1000)
		    	}
		    	});
		    	})
		    },
			submit() {
					 if (this.form.id == null) {
						 this.form.problemStatus=1;
						let images = []	
						this.fileList1.forEach((item) => {
						 			images.push(item.rl)
						 		})
						 this.form.problemPhotos=images.join(',');
					     addProblems(this.form).then(response => {
					     this.$modal.msgSuccess("新增成功");
					});
					}
			}
		},
	}
</script>

4. 在manifest.json进行配置如下,真机调试需配置target:http://127.0.0.1:8085。其中8085是后端端口号。

若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试

 "h5" : {
        "template" : "static/index.html",
        "devServer" : {
            "port" : 9092,
            "https" : false,
            "disableHostCheck" : true, //设置跳过host检查
            "proxy" : {
                "/dev-api" : {
                    "target" : "http://127.0.0.1:8085", //目标接口域名
                    "changeOrigin" : true, //是否跨域
                    "secure" : false, // 设置支持https协议的代理
                    "pathRewrite" : {
                        "^/dev-api" : ""
                    }
                },
                "/prod-api" : {
                    "target" : "http://127.0.0.1:8085", //目标接口域名
                    "changeOrigin" : true, //是否跨域
                    "secure" : false, // 设置支持https协议的代理
                    "pathRewrite" : {
                        "^/prod-api" : ""
                    }
                }
            }
        },

5. 使用微信工具的真机调试,可以在手机以小程序方式选择“拍照”或者“从手机相册选择”。

若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试

6. 使用h5在浏览器效果如下

若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试文章来源地址https://www.toymoban.com/news/detail-483444.html

到了这里,关于若依移动端Ruoyi-App——使用uview2.0开发拍照上传或者从手机相册上传,并进行真机调试的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ruoyi-app(uniapp) 解决持久化登录:退出应用后再次打开保持已登录状态以及登录页显示tabBar的问题

    在使用ruoyi-app开发移动端调试的时候发现已登录用户退出应用后台后重新打开需要重新登录, 于是想做一个持久保存登录状态的功能。 首先ruoyi-app自带的登录存储token的流程完全没问题,但是在 pages.json文件中第一个页面却是登录页;uniapp官网写道在pages第一项为应用首页  

    2024年02月04日
    浏览(61)
  • 【uview2.0】Keyboard 键盘 与 CodeInput 验证码输入 结合使用 uview

    https://www.uviewui.com/components/codeInput.html (CodeInput 验证码输入) https://www.uviewui.com/components/keyboard.html (Keyboard 键盘) css

    2024年02月01日
    浏览(43)
  • Aidex 移动端快速开发框架# RuoYi-Uniapp项目,uniapp vue app项目跨域问题

     参考地址: manifest.json官方配置文档:manifest.json 应用配置 | uni-app官网 Chrome 调试跨域问题解决方案之插件篇: uni-app H5跨域问题解决方案(CORS、Cross-Origin) - DCloud问答 其实uni-app官方有解决跨域的办法,官方推荐使用HBuilderX中内置的浏览器去预览,在内置的浏览器中不会存

    2024年02月11日
    浏览(34)
  • uview2.0自定义tabbar

    pages.json 样式覆盖 App.vue 消息设置角标 在三个主页面分别引入组件 传入对于的索引即可

    2024年02月11日
    浏览(42)
  • uview2.0 【uniapp】购物车样式

    2024年01月18日
    浏览(48)
  • uniapp+uview2.0实现表单校验实战

        表单提交是很常见的功能,本文基于uniapp+uview2.0实现表单常见属性校验处理,使用到组件有u–form、Form-item,基本使用说明如下:      u–form 此组件一般是用于表单验证使用,每一个表单域由一个u-form-item组成,表单域中可以放置u-input、u-checkbox、u-radio、u-switch等。 在表

    2023年04月11日
    浏览(45)
  • uniapp+uView2.0实现自定义动态tabbar

         1.需求说明      2.实现原理说明      3.实现过程          3.1集成uView2.0          3.2 自定义tabbar          3.3 vuex定义tabbar共享信息          3.4 tabbar显示个数控制      要求不同时间显示不同的tabbar.点击不同的tabbar跳转到不同的页面,能随时实现tabb

    2023年04月18日
    浏览(42)
  • uniapp+uview2.0+vuex实现自定义tabbar组件

    效果图 1.在components文件夹中新建MyTabbar组件 2.组件代码 3.父组件 4.创建store目录,下面创建index.js文件

    2024年02月04日
    浏览(54)
  • 使用vue2开发uni-app项目--引入uview-ui

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、安装 1、安装uview-ui 2、安装scss支持 二、配置 1、在main.js中引入uView库 2、uni.scss文件中引入uView的全局SCSS主题文件  3、在APP.vue文件中引入uView基础样式 4、在pages.json中 配置easycom组件模式

    2024年02月04日
    浏览(67)
  • uview2.0封装http请求实战以及常见请求传参实录

         1.前言      2.使用步骤          2.1 配置请求拦截器以及api集中管理配置          2.2 main.js中进行引入请求拦截器          2.3 页面中引入请求方法并使用     uview2.0是uniapp开发中使用频率相对来讲比较高的一款框架,今天从实战角度介绍一下关于http请求

    2023年04月26日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包