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文件服务器的问题花了我足足两天的时间,因此,有必要写下自己所学到的,同时,也能让广大的博友学习学习一下. 本 ...
随机推荐
- jvm内存结构(一)(结构总览)
jvm内存结构:<Java虚拟机原理图解>3.JVM运行时数据区 程序计数器: ,是执行的字节码的行号指示器,记录的是正在执行的虚拟机字节码指令的地址. ,每个线程都有独立计数器,互不干扰 ...
- java 0 开始
利用了61天的时间学习了 se 不过忘得也很多 .在这里开一个帖子 打算利用几天的时间进行复习,把凡是能用到的都放在这边. 不带图形界面的第一个项目已经弄完 (看视频加看书..而且自己往上面加东 ...
- 快速排序的理解和实现(Java)
快速排序介绍 快速排序(Quick Sort)使用分治法策略,其基本思想是:通过一趟排序将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另外一部分记录的关键字小,则可分别对这两部分记录继续进 ...
- 用Python玩转数据第六周——高级数据处理与可视化
1.matplotlib中有两个模块,pyplot和pylab import matplotlib.pyplot as plt ///plt.plot(x,y) import pylab as pl ...
- Eclipse for android 实现代码自动提示智能提示功能
Eclipse for android 实现代码自动提示智能提示功能,介绍 Eclipse for android 编辑器中实现两种主要文件 java 与 xml 代码自动提示功能,解决 eclips ...
- Zabbix3.2邮件告警python脚本
一.概述及环境要求 1.概述 zabbix监控也起到重要作用,以下是使用python脚本发送告警邮件配置方法.之前使用过sendemail邮件报警但是发现邮件主题为中文时候会出现乱码的问题. 2.环境 ...
- jquery.lazyload插件实现图片延迟加载
jquery.lazyload是一个实现图片延迟加载的jQuery 插件,它可以延迟加载长页面中的图片.在浏览器可视区域外的图片在初始状态下不会被载入,直到用户将页面滚动到它们所在的位置. 1.引入j ...
- android瓦片地图技术研究
最近根据公司项目需求,需要制作场馆的室内图并且实现根据rfid信号的自动定位功能,研究了好久找到了一个目前为止还算好用的瓦片地图工具——TileView. github连接:https://githu ...
- javascript对象属性的命名规则
JS标识符的命名规则,即变量的命名规则: 标识符只能由字母.数字.下划线和‘$’组成 数字不可以作为标识符的首字符 对象属性的命名规则 通过[]操作符为对象添加属性时,属性名称可以是任何字符串(包括只 ...
- OpenGL10-骨骼动画原理篇(2)
接上一篇的内容,上一篇,简单的介绍了,骨骼动画的原理,给出来一个 简单的例程,这一例程将给展示一个最初级的人物动画,具备多细节内容 以人走路为例子,当人走路的从一个站立开始,到迈出一步,这个过程是 一 ...