vue实现上传上删除压缩图片
<script>
import {Config} from '@/config.js'
import {mapState} from 'vuex'
import {LocalData, toast, WX} from '@/utils/common'
import {FileUtil} from '@/utils/FileUtil'
import {PayUtil} from '@/utils/PayUtil'
import Vue from 'vue'
import {Checklist, Indicator, Popup} from 'mint-ui'
import xImg from '@/components/x-img' Vue.component(Checklist.name, Checklist)
Vue.component(Popup.name, Popup)
let imgLimit = 100
let vm
export default {
name: 'signing',
components: {
xImg
},
data() {
return {
contractno:undefined,//合同号
totle_sum: undefined,//总车辆数
totle_r: undefined,//常规租赁总租金
totle_s: undefined,//以租代购总租金
totle_b: undefined,//总保证金
first_t: undefined,//首付款总金额
sign_address: '',//签约地点
sing_time: '',//签约时间
sign_remark: '',//备注
operator_name: '',//经办人
imgs: {},
imgLen:0,
updataImg: '../../static/img/update.jpg ', selectImgs: [{}],
images: [],
}
},
computed: {
...mapState({
signContract: state => state.signing.signContract,
totleRent: function () {
this.totle_sum = 0
this.totle_r = 0
this.totle_s = 0
this.totle_b = 0
this.first_t = 0
let _length = this.signContract.cardetail.length
let _array = this.signContract.cardetail
for (let i = 0; i < _length; i++) {
//获取车辆数
this.totle_sum += parseInt(_array[i].number)
//获取常规租赁租金
this.totle_r += parseInt(_array[i].rent_total)
//获取以租代购租金
this.totle_s += parseInt(_array[i].rent_sum)
//获取保证金
this.totle_b += parseInt(_array[i].bond_total)
//获取首付款总额
this.first_t += parseInt(_array[i].first_total) }
},
}),
},
methods: {
getSignContract: function () {
let rel = this;
rel.$store.dispatch('signing/getsignContract', {
params: {
contractno: this.contractno
},
// callBack(data) {
// rel.operator_name = data.operator_name
// }
})
},
selectImage () {
if (this.$refs.fileInput[0].files.length > 0) {
const file = this.$refs.fileInput[0].files[0]
const vm = this
const temp = this.selectImgs[this.selectImgs.length - 1]
Vue.set(temp, 'src', 'loadding')
FileUtil.compress(file, {
onSuccess (result) {
let rst = result[0]
temp.src = rst.base64
temp.file = rst.file
temp.name = rst.origin.name
vm.images.push({
src: rst.base64
})
if (vm.selectImgs.length < imgLimit) {
vm.selectImgs.push({})
}
},
onFail (err) {
temp.src = undefined
toast.show(JSON.stringify(err))
},
onFinish () {
}
})
}
},
delImg (index) {
this.selectImgs.splice(index, 1)
this.images.splice(index, 1)
if (this.selectImgs.length > 0) {
let temp = this.selectImgs[this.selectImgs.length - 1]
if (temp.src) {
this.selectImgs.push({})
}
}
else {
this.selectImgs.push({})
}
},
submit() {
if (!this.sing_time) {
toast.show('请选着签约时间')
return
}
else if(!this.sign_address){
toast.show('请填写签约地址')
return
}
else if(!this.sign_remark){
toast.show('请简要填写备注')
return
}
let formData = new FormData()
formData.append('token', LocalData.getToken())
formData.append('contractno', this.contractno)
formData.append('sing_time', this.sing_time)
formData.append('sign_address', this.sign_address)
formData.append('sign_remark', this.sign_remark)
for (let index = 0; index < this.selectImgs.length - 1; index++) {
if (this.selectImgs[index] != null) {
formData.append('uploadImg', this.selectImgs[index].file, this.selectImgs[index].name)
}
}
let config = {
headers: {
'Content-Type': 'multipart/form-data'
}
}
Indicator.open()
this.$axios.post('applease/internallySignedImg', formData, config).then(
response => {
Indicator.close()
if (response.data.code == 0) { }
toast.show(response.data.message)
}).catch(error => {
console.log(error)
Indicator.close()
toast.show('网络异常,上传失败')
})
}
},
created: function () {
vm = this
this.contractno = this.$route.query.contractNo
this.getSignContract()//合同车辆信息接口处理
}
}
</script>
<div class="img-box">
<div class="up-img">
<template v-for="(img,index) of selectImgs">
<template v-if="!img || !img.src">
<em>
<input type="file" accept="image/jpeg,image/jpg,image/png,image/x-png,image/gif" @change="selectImage"
ref="fileInput"/>
<img :src="updataImg"/>
</em>
</template>
<template v-else>
<label>
<template v-if="img.src && img.src != 'loadding'">
<i slot="icon" class="item-icon parent-h-right icon-close" @click="delImg(index)"></i>
</template>
<x-img :src="img.src" @on-click="preview(index)"></x-img>
</label>
</template>
</template>
</div>
</div>
vue实现上传上删除压缩图片的更多相关文章
- js实现上传前删除指定图片
"上传之前"移除选错图片代码: 此处效果为:点击需要删除的图片,确认删除就可以了.
- [java]文件上传下载删除与图片预览
图片预览 @GetMapping("/image") @ResponseBody public Result image(@RequestParam("imageName ...
- vue代码上传服务器后背景图片404解决方法
问题:代码上传服务器后,图片404,使用的font-awesome图标也是404 解决办法: 如果你用了vue-cil,那么在build目录下找到utils.js中的ExtractTextPlugin ...
- iOS 使用AFN 进行单图和多图上传 摄像头/相册获取图片,压缩图片
图片上传时必要将图片进行压缩,不然会上传失败 首先是同系统相册选择图片和视频.iOS系统自带有UIImagePickerController,可以选择或拍摄图片视频,但是最大的问题是只支持单选,由于项 ...
- 又拍云 Node.js 实现文件上传、删除
Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require("express"); const app = ...
- hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images
hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images, 本例子主要是使用HTML5 的File API,建立一個可存取到该file的url, 一个空的img标签,ID为img0,把 ...
- 【转】asp.net(c#)使用HttpWebRequest附加携带请求参数以post方式模拟上传大文件(以图片为例)到Web服务器端
原文地址:http://docode.top/Article/Detail/10002 目录: 1.Http协议上传文件(以图片为例)请求报文体内容格式 2.完整版HttpWebRequest模拟上传 ...
- 从web编辑器 UEditor 中单独提取图片上传,包含多图片单图片上传以及在线涂鸦功能
UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码.(抄的...) UEditor是非常好用的富文 ...
- php用jquery-ajax上传多张图片限制图片大小
php用jquery-ajax上传多张图片限制图片大小 /** * 上传图片,默认大小限制为3M * @param String $fileInputName * @param number $siz ...
- 使用C#WebClient类访问(上传/下载/删除/列出文件目录)由IIS搭建的http文件服务器
前言 为什么要写这边博文呢?其实,就是使用C#WebClient类访问由IIS搭建的http文件服务器的问题花了我足足两天的时间,因此,有必要写下自己所学到的,同时,也能让广大的博友学习学习一下. 本 ...
随机推荐
- nacicat premium 快捷键
1.ctrl+q 打开查询窗口 2.ctrl+/ 注释sql语句 3.ctrl+shift +/ 解除注释 4.ctrl+r 运行查询窗口的s ...
- 利用Django和装饰器做一个简单的修改密码页面
view视图代码: from django.shortcuts import render,redirect from django.http import HttpResponse from PIL ...
- 使用sqlyog连接到服务器数据库,实现可视化数据操作。(完美解决版。)《亲测!!!!》
服务器中的表 select Host ,User ,Select_priv ,Insert_priv ,Update_priv ,Delete_priv ,Create_priv ,Drop_pr ...
- 【数组】Set Matrix Zeroes
题目: Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. cl ...
- Windows下如何正确下载并安装可视化的Redis数据库管理工具(redis-desktop-manager)(图文详解)
不多说,直接上干货! Redis Desktop Manager是一个可视化的Redis数据库管理工具,使用非常简单. 官网下载:https://redisdesktop.com/down ...
- Flow中的Switch分析
A switch statement can complete normally iff at least one of the following is true: (1)The switch bl ...
- windows 下的bash 环境安装npm
1.Git下载 node.js下载2.安装 git 和 node.js3.将git\bin node.js安装目录加入环境变量path中4.在D盘下建立目录gitrep 打开Git Bash初始 ...
- Spring+Druid+SpringMVC的搭建(附Demo)
最近公司事情比较少,便想利用这段空闲时间做一个自己的博客. 前端界面已经搞好,感谢杨姐的模板,自己稍微把模板没有的模块给补全了. 今天便开始自己的SSM框架搭建,数据库链接是采用数据库连接池.先上个项 ...
- mongodb与关系型数据库优缺点比较
1.与关系型数据库相比,MongoDB的优点:①弱一致性(最终一致),更能保证用户的访问速度②文档结构的存储方式,能够更便捷的获取数据③内置GridFS,支持大容量的存储.④内置Sharding.⑤第 ...
- 自动换行的两种代码(C#)
最近有个需求,需要将C# winform中的listBox中的内容自动换行, 其实在用listBox前,已经用textBox实现了大部分功能,可惜最后还是有个焦点的问题, 就是textBox中的文字会 ...