之前花了两个月用vue做了一个建筑照片我的webApp,前端就我一人,负责用vue写页面对接接口,后台一个程序员负责写接口,嵌套个安卓ios的壳。搞的是风风火火,过程也是很心累,大多不在技术,在于所谓的产品乱改需求,其实产品也不是产品,只是一个资历尚浅的副总。看不得我们工作清闲一点,于是非得找个活。干了两个多月,中途流程走不通,各种改改改,好不容易上线了,运营两周之后就没下文了,放弃了,也是情理之中,至始至终没有人看好过这个东西,包括我们两个开发者。

不吐槽,不吐槽,过程中有个上传身份证,企业执照的功能,也就是上传图片,记录一下,以后说不定有用。

html:

<template>
<div class="personPic">
<myHeader :hTitle="hTitle" ref="myHeader" :noMore="noMore"></myHeader>
<div class="inner">
<div class="upload">
<div class="txt">
<p>点击上传</p>
<span>营业执照</span>
</div>
<img :src="front_pic" v-show="front_pic!=''">
<input type="file" @change="imgPreview($event, 1)"/>
</div>
<div class="msg">
<p>请保持姓名和身份证号信息与证件<span>信息一致!</span></p>
<p>保证所有信息<span>清晰完整</span></p>
</div>
<button class="flowBtn" @click="send">提交审核</button>
<prompt ref="prompt" :promptText="promptText"></prompt>
<loading ref="loading"></loading>
</div>
</div>
</template>
js:
data () {
return {
promptText: '',
front_pic: ''
}
},
// 上传图片
imgPreview: function (e, index) {
// 获取文件
var file = e.target.files[0]
var imageType = /^image\//
// 是否是图片
if (!imageType.test(file.type)) {
  this.promptText=‘请选择图片!’
return
}
var formData = new FormData()
formData.append('file', file)
this.$refs.loading.show()
this.$http.post(this.publicUrl + 'upload/picture', formData).then(function (response) {
this.$refs.loading.show()
if (response.data.status === -1) {
this.promptText = response.data.msg
this.$refs.prompt.show()
} else {
this.front_pic = this.publicUrl + response.data.data.url // 提交图片获取URL,返回
}
}, function () {
this.promptText = '请求失败'
this.$refs.prompt.show()
})
}
css:
.personPic{
padding-top: 1rem;
font-size: 0.3rem;
.inner{
padding: 0.8rem 0.8rem 0;
.upload{
position: relative;
width: 100%;
height: 7rem;
background:#f7f7f7 url("../../assets/images/upload.png") no-repeat 1.2rem center;
background-size: 0.7rem 0.7rem;
border-radius: 0.01rem;
margin-bottom: 0.4rem;
overflow: hidden;
p{
color: #1a4cbf;
margin-bottom: 0.1rem;
}
span{
color: #999999;
}
.txt{
text-align: center;
padding: 3.1rem 0 0 1rem;
}
input{
position: absolute;
top: 0;
width: 100%;
height: 100%;
opacity: 0;
}
img{
position: absolute;
top: 0;
width: 100%;
height: 100%;
display: block;
border-radius: 0.01rem;
}
}
.msg{
text-align: center;
line-height: 0.5rem;
font-size: 0.28rem;
p{
color: #666666;
span{
color: #fe5642;
}
}
}
}
}
 

vue图片上传的更多相关文章

  1. vue图片上传组件

    前言:很多项目中都需要用到图片上传功能,而其多处使用的要求,为了避免重复造轮子,让我决定花费一些时间去深入了解,最终封装了一个vue的图片上传组件.现将总结再次,希望有帮助. Layout <d ...

  2. vue 图片上传

    功能说明: 1.调用手机拍照功能 2.调用相册功能 3.图片上传功能 4.图片预览功能 5.图片删除功能 关键点: .input 新增multiple .accept="image/*处理I ...

  3. vue 图片上传功能

    这次做了vue页面的图片上传功能,不带裁剪功能的! 首先是html代码,在input框上添加change事件,如下:   <ul class="clearfix">   ...

  4. vue图片上传的简单组件

    <template> <div class="rili" id="rili"> <div class="updel&qu ...

  5. 保姆级SpringBoot+Vue图片上传到阿里云OSS教程

    小二是新来的实习生,作为技术 leader,我给他安排了一个非常简单的练手任务,把前端 markdown 编辑器里上传的图片保存到服务器端,结果他真的就把图片直接保存到了服务器上,这下可把我气坏了,就 ...

  6. vue图片上传到七牛云

    代码: <template> <div class="upload-info"> <div> <el-upload class=" ...

  7. vue图片上传及java存储图片(亲测可用)

    1.前言 在使用elementui的upload组件时,我一直无法做到上传的图片和其他数据一起提交.单纯的上传文件,java的存储图片的方式也有局限性. 我知道的后端保存图片有两种方式:一种是直接存储 ...

  8. 后台管理系统之“图片上传” --vue

    图片上传(基于vue) 相信上传图片是所有系统必备的功能吧,工作中的第一个管理系统就在上传图片的功能上卡顿了一整天. 当时用的elementUI组件,但是由于样式和设计图样式差别较大再加上原生相较好理 ...

  9. vue+axios实现移动端图片上传

    在利用vue做一些H5页面时,或多或少会遇到有图片上传的操作,主要是运用html5里面的input[type=file]来实现,传递到后端的数据是以二进制的格式传递,所以上传图片的请求与普通的请求稍微 ...

随机推荐

  1. ES6学习笔记(数组)

    1.扩展运算符:, 2, 3]) // 1 2 3 console.log(1, ...[2, 3, 4], 5) // 1 2 3 4 5 用于函数调用 function add(x, y) { r ...

  2. linux下查看动态链接库so文件的依赖的相关组建

    我们很多c程序在windows下是以dll形式展现的,在linux则是以so 形式展现的. windows一般不会因为编译dll文件的编译器版本不同而出先dll文件不能执行. 但是linux下,不同版 ...

  3. gitlab 与 jenkins 关联

    一.搭建 gitlab :https://www.cnblogs.com/carriezhangyan/p/10729158.html 二.搭建jenkins :https://www.cnblogs ...

  4. vue iview render里面写时间截取

    render: (h, params) => {params.row.execDate = (params.row.execDate ? params.row.execDate.substr(0 ...

  5. 在MyEclipse中使用spring-boot+mybatis+freemarker实现基本的增删改查

    一.基本环境 二.创建实体类 1.User.java package bjredcross.rainbowplans.model; import bjredcross.rainbowplans.com ...

  6. 多个表左联,要返回全部的结果,解决不能用where的问题

    qb.leftJoin('info_student', 'grouping_class_student.studentId', 'info_student.id'); qb.leftJoin('gro ...

  7. swift两种获取相册资源PHAsset的路径的方法(绝对路径)

    方法中使用到的phasset就是我们取到的PHAsset对象 方法一: let options = PHVideoRequestOptions() options.version = PHVideoR ...

  8. 校赛F

    问题描述 例如对于数列[1 2 3 4 5 6],排序后变为[6 1 5 2 4 3].换句话说,对于一个有序递增的序列a1, a2, a3, ……, an,排序后为an, a1, an-1, a2, ...

  9. [Python] 建 Django 项目

    Python和Django的安装见这里:http://www.runoob.com/django/django-install.html 安装 Django 之后,您现在应该已经有了可用的管理工具 d ...

  10. Python_格式化字符

    %% 百分号标记 #就是输出一个%%c 字符及其ASCII码%s 字符串 %r 是不管是什么打印出来%d 有符号整数(十进制)%u 无符号整数(十进制)%o 无符号整数(八进制)%x 无符号整数(十六 ...