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文件服务器的问题花了我足足两天的时间,因此,有必要写下自己所学到的,同时,也能让广大的博友学习学习一下. 本 ...
随机推荐
- cmd下查看应用端口情况
在win10开始窗口右侧的空白处点击CMD,在上方弹出窗口中选择命令提示符,双击进入 在弹出命令界面中,输入netstat -na命令后回车,如下图所示,可以看到所有目前打开的端口 如果要查看打开端口 ...
- php获取客户端ip地址方法
/** * 获取客户端IP地址 * @param integer $type 返回类型 0 返回IP地址 1 返回IPV4地址数字 * @param boolean $adv 是否进行高级模式获取(有 ...
- 微信小程序云函数 添加数据到数据库
1.新建小程序,建立云开发快速启动模板 这里和普通小程序的区别有三点 一是 project.config.json写上云函数所在目录"cloudfunctionRoot": &qu ...
- Ajax与XMLHttpRequest随笔
1.XMLHttpRequest对象 创建XHR对象:let xhr = new XMLHttpRequest(); open():启动一个请求准备发送 open()接收3个参数:请求类型('GET' ...
- 【2018北京集训十二】 coin 矩阵快速幂
矩阵快速幂原来还可以这么用?? 你们城里人还真会玩. 我们令$f[i][j][k]$表示总的钱数为i,当前使用的最大面值硬币的面值为$v_j$,最小为$v_k$的方案数量. 不难发现$f[i][j][ ...
- zookeeper知识点学习
单机模式配置: Zookeeper 的启动脚本在 bin 目录下,Linux 下的启动脚本是 zkServer.sh 在你执行启动脚本之前,还有几个基本的配置项需要配置一 下,Zookeeper 的配 ...
- IDEA里点击Build,再Build Artifacts没反应,灰色的?解决办法(图文详解)
不多说,直接上干货! 问题详情 如下:点击Build ,再 Build -> Build Artifacts,没反应??? 解决办法 1.File,再Project Structure 2.然后 ...
- 解决LNMP环境下WordPress后台缺少”WP-ADMIN”路径
LNMP一键安装包也是老左比较喜欢使用的环境之一,昨天帮助一个网友搭建LNMP环境后发现登陆WP后台之后点击左侧的菜单发现直接跳转404错误,开始还以为数据库问题,视线朝上一看原来在地址栏中的路径缺少 ...
- centos中软件源码简单的编译安装./configure,make ,make install
参考 Linux下源码编译安装详解 源码编译安装分三个步骤 1. 编译参数配置 2. 编译 3. 安装 1. 源码编译安装环境检查以及编译参数配置 编译器在开始工作之前,需要知道当前的系统环境,比如标 ...
- 机器学习中规范化项:L1和L2
规范化(Regularization) 机器学习中几乎都可以看到损失函数后面会添加一个额外项,常用的额外项一般有两种,一般英文称作ℓ1-norm和ℓ2-norm,中文称作L1正则化和L2正则化,或者L ...