第12讲创建图文投票实现

创建图文投票实现

图文投票和文字投票基本一样,就是在投票选项里面,多了一个选项图片;

bash 复制代码
<view class="option_item" v-for="(item,index) in options" :key="item.id">
					<view class="option_input">
						<text class="removeOption" @click="removeOption(item.id)">&#xe618;</text><input type="text" v-model="item.name" placeholder="输入选项名称" placeholder-style="color:#bababa;font-size:14px">
					</view>				
					<view class="option_upload">
						<uni-file-picker
						@select="selectVoteItemFileFunc($event,index)"
						:auto-upload="false" 
						limit="1"
						:del-icon="false" 
						disable-preview 
						file-mediatype="image" 
						:imageStyles="voteItemImageStyles">
							<view class="upload">
								<text class="smallUploadImg">&#xe727;</text>
							</view>
						</uni-file-picker>
					</view>
				</view>
bash 复制代码
.option_item{
					margin-top: 10px;
					border-radius: 5px;
					background-color: white;
					padding: 10px;
					.option_input{
						display: flex;
					}
					.option_upload{
						margin-top: 20rpx;
						.upload{
							margin: 10rpx;
							background-color: #f4f5f7;
							width:90rpx;
							height: 90rpx;
							display: flex;
							align-items: center;
							justify-content: center;
						}
					}
				}
bash 复制代码
			voteItemImageStyles:{
				width:"150rpx",
				height:"120rpx",
				border:false
			},
bash 复制代码
selectVoteItemFileFunc:function(e,index){
				console.log("index="+index)
				console.log(e.tempFilePaths[0])
				uni.uploadFile({
					header:{token:uni.getStorageSync("token")},
					url:getBaseUrl()+"/vote/uploadVoteItemImage",
					filePath:e.tempFilePaths[0],
					name:"voteItemImage",
					success: (res) => {
						let result=JSON.parse(res.data);
						if(result.code==0){
							this.options[index].image=result.voteItemImageFileName;
						}
					}
				})
			},

加个image属性

提交加上验证:

bash 复制代码
// 验证投票选项,如果有名称的,必须要上传图片
				for(var i=0;i<this.options.length;i++){
					var option=this.options[i];
					if(!isEmpty(option.name)){
						if(isEmpty(option.image)){
							console.log("请上传第"+(i+1)+"个投票选项图片")
							uni.showToast({
								icon:"error",
								title:"请上传第"+(i+1)+"个投票选项图片"
							})
							return;
						}
					}
				}

后端:

bash 复制代码
voteItemImagesFilePath: D://uniapp/voteItemImgs/
bash 复制代码
@Value("${voteItemImagesFilePath}")
private String voteItemImagesFilePath;
bash 复制代码
/**
 * 上传投票选项图片
 * @param voteItemImage
 * @return
 * @throws Exception
 */
@RequestMapping("/uploadVoteItemImage")
public Map<String,Object> uploadVoteItemImage(MultipartFile voteItemImage)throws Exception{
    System.out.println("filename:"+voteItemImage.getName());
    Map<String,Object> resultMap=new HashMap<>();
    if(!voteItemImage.isEmpty()){
        // 获取文件名
        String originalFilename = voteItemImage.getOriginalFilename();
        String suffixName=originalFilename.substring(originalFilename.lastIndexOf("."));
        String newFileName= DateUtil.getCurrentDateStr()+suffixName;
        FileUtils.copyInputStreamToFile(voteItemImage.getInputStream(),new File(voteItemImagesFilePath+newFileName));
        resultMap.put("code",0);
        resultMap.put("msg","上传成功");
        resultMap.put("voteItemImageFileName",newFileName);
    }
    return resultMap;
}
相关推荐
零雲几秒前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码几秒前
实现 Trie (前缀树)
开发语言·c#
前端开发爱好者7 分钟前
VSCode 重磅更新!要收费了?
前端·javascript·visual studio code
laocooon52385788610 分钟前
插入法排序 python
开发语言·python·算法
你的冰西瓜33 分钟前
C++中的list容器详解
开发语言·c++·stl·list
wuhen_n44 分钟前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
就不掉头发44 分钟前
I/O复用
运维·服务器·c语言·开发语言
梦里小白龙1 小时前
JAVA 策略模式+工厂模式
java·开发语言·策略模式
假装我不帅1 小时前
jquery.nicescroll使用
前端·javascript·jquery
安_1 小时前
js 数组splice跟slice
开发语言·前端·javascript