后台管理系统之“图片上传” --vue
图片上传(基于vue)
相信上传图片是所有系统必备的功能吧,工作中的第一个管理系统就在上传图片的功能上卡顿了一整天。
当时用的elementUI组件,但是由于样式和设计图样式差别较大再加上原生相较好理解,便使用了原生实现图片上传功能。
菜鸟上路,望多多指点。
- 图片上传原理(csdn里看到的比较通俗易懂的图片上传原理)
参考地址:https://blog.csdn.net/q857277886/article/details/79092591
前端网页文件上传一般使用 <input type="file" />来实现。
- 在 HTML 文档中 <input type="file" />标签每出现一次,一个 FileUpload 对象就会被创建。
2.该标签包含一个文本输入字段,用来输入文件名,还有一个按钮,用来打开文件选择对话框以便图形化选择文件,该标签的 value属性保存了用户指定的文件的名称。
3.多选:标签可以通过添加 multiple 属性来支持多选;如果选择了多个文件, 这个值表示第一个被选择的文件路径. JavaScript 可以通过 Input 的 FileList 属性获取到其他的文件路径.
4.文件信息:可以通过 input.files 属性返回 — 返回值是一个 FileList 对象,这个对象是一个包含了许多 File 文件的列表,列表包含图片的name,type,size等属性。
5.限制文件类型:你可以使用 input 的 accept 属性,accept 属性接受一个逗号分隔的 MIME 类型字符串。如: accept="image/png, image/jpeg" or accept=".png, .jpg, .jpeg" — PNG/JPEG
6.选择文件会触发input的onchange事件;
7.上传:上传文件前 使用FileReader对象读取指定file的文件,并将文件转换为二进制字符串, 并将xhr对象, overrideMimeType 属性设置为text/plain; charset=x-user-defined-binary, 最终后台接收到二进制后再做具体处理。(注:小编用的是FormData对象)
- 实现步骤
①:样式的实现
代码:
<el-form-item label="产品图片" id="img_box">
<form ref="form" enctype="multipart/form-data" id="formImg" style="position:relative">
<input type="file" name="uploadFile" @change="creatUrl($event)" accept="image/png,image/jpg,image/jpeg" class="imgInput" style="position:absolute; z-index:9999999">
<img v-if="imageUrl" :src="data:imageUrl" style="position:absolute; top:0; left:0; height:80px; width:80px"></img>
<span style="position:absolute; bottom:20px; left:100px; width:400px; color:#999999; font-size:12px">图片格式为JPG/JPEG/PNG,图片大小不超过2M</span>
<em v-if="imgSytle" style="width:280px;display:block;position:absolute;top:70px;color:#f56c6c; font-size:12px;font-style:normal">{{msg2}}</em>
</form>
</el-form-item>
②:在用户确定了要上传的图片时,页面要显示本地要上传的图片
注:input.files 属性返回 — 返回值是一个 FileList 对象,这个对象是一个包含了许多 File 文件的列表,列表包含图片的name,type,size等属性。
HTML代码 :
<input type="file" name="uploadFile" @change="creatUrl($event)">
首先给input标签绑定“onchange”事件,在确定了要选择后的图片时,触发 creatUrl($event),然后通过 event.target.files[0] 找到图片信息
创建本地图片URL,属性 URL.createObjectURL 实现,然后将创建好的imageUrl,绑定到标签img的src上,OK!!!!
也可用 event.target.files[0] .size, event.target.files[0] .type 进行判断以此来限制用户上传图片的大小和类型
JS代码:
let imageUrl=URL.createObjectURL( event.target.files[] )

③:上传图片到后台
通过FormData对象可以组装一组用XMLHttpRequest发送请求的键/值对。它可以更灵活方便的发送表单数据,因为可以独立于表单使用。表单的编码类型设置为multipart/form-data 并且form要绑定vue的ref属性,方便获取form对象。
代码:
<form ref="form" enctype="multipart/form-data" >
步骤:提交按钮绑定onclick事件,submit方法
在submit方法里,利用vue的this.$refs属性获取form对象,var fd = new FormData(this.$refs.form)
利用axios将数据fd发送给后台,后台会返回此图片的fileName
然后调用上传表单的接口,将返回的fileName和表单填写的信息一起发送给后台,此时上传图片就成功了。
图片渲染时,先请求渲染接口获取图片的线上imgName,再通过img的src拼接图片的线上地址,代码如下:
<img :src="`http://***.***.***.***:8080/product/getFtpImage.do?filePath=`+item.imgName" style="width:120px; height:120px"></img>
以上便是图片上传的实现,方法有很多种,小编只用了其中之一(formData),具体功能具体对待吧。
比心。。。。
后台管理系统之“图片上传” --vue的更多相关文章
- ASP.NET MVC+Easyui 后台管理系统的图片上传
实现图片的上传 easyui代码部分: //添加按钮 var URL; $("#btnCreate").click(function () { $('#UserDialog').d ...
- vue 剪切图片上传头像,使用 cropperjs 实现
我使用的是vue,移动端的项目. 官网地址:cropperjs GitHub地址:https://github.com/fengyuanchen/cropperjs/blob/master/READM ...
- Asp.Net Mvc 使用WebUploader 多图片上传
来博客园有一个月了,哈哈.在这里学到了很多东西.今天也来试着分享一下学到的东西.希望能和大家做朋友共同进步. 最近由于项目需要上传多张图片,对于我这只菜鸟来说,以前上传图片都是直接拖得控件啊,而且还是 ...
- vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
一.前言 三年.net开发转前端已经四个月了,前端主要用webpack+vue,由于后端转过来的,前端不够系统,希望分享下开发心得与园友一起学习. 图片的上传之前都是用的插件(ajaxupload), ...
- 图片上传JS插件梳理与学习
项目的oper端和seller端,用了两个不同插件,简单了解一下: 一.seller端:AjaxUpload.js seller端使用的是 AjaxUpload.js ,封装好的一个库.调用时传入参数 ...
- 用Vue来实现图片上传多种方式
没有业务场景的功能都是耍流氓,那么我们先来模拟一个需要实现的业务场景.假设我们要做一个后台系统添加商品的页面,有一些商品名称.信息等字段,还有需要上传商品轮播图的需求. 我们就以Vue.Element ...
- AntDesign vue学习笔记(七)Form 读写与图片上传
AntDesign Form使用布局相比传统Jquery有点繁琐 (一)先读写一个简单的input为例 <a-form :form="form" layout="v ...
- H5 利用vue实现图片上传功能。
H5的上传图片如何实现呢? 以下是我用vue实现的图片上传功能,仅供参考. <!DOCTYPE html> <html> <head> <meta chars ...
- vue 图片上传功能
这次做了vue页面的图片上传功能,不带裁剪功能的! 首先是html代码,在input框上添加change事件,如下: <ul class="clearfix"> ...
随机推荐
- Mac OS 挂载 EFI 引导分区
正如Windows下的EFI分区一样在资源管理器中默认不显示EFI引导分区(即ESP分区),Mac OS也是如此,为了安全嘛,不让用户随意操作. 那么怎么挂载显示出来呢? 命令转自 https://b ...
- Java核心知识盘点(一)- 数据存储
MySQL 索引使用的注意事项 1.索引的目的:在于提高查询效率,插入和更新的操作,数据库的操作是慢的,但是查询操作会非常快,索引可以对表中一个或多个字段进行加索引动作. 2.索引的类型: 1.唯一索 ...
- webpack中如何使用vue
1.安装 vue包:npm i vue -S 2.由于在webpack中,推荐使用.vue这个组件模版文件来定义组件,不然会出现vue.js移动和一些高级语法的不支持,因此需要安装能解析这种文件的lo ...
- 微信小程序外包 就找北京动软 专业承接微信小程序定制
很多人问为什么要开发微信小程序,微信小程序的“入口”在哪儿? 1.只有访问过的小程序,才会出现所谓的「入口」. 所有访问过得小程序都可以从微信首屏下面的「发现」点过去.(必须是最新版微信) 这个所谓的 ...
- Aspose.Words的Merge Field
今天应客户要求,修改导出word模板.使用的是Aspose.Words插件.这个程序原是同事所写,且自己对Aspose不是很了解.在替换模板上花费了一些时间. 先来一张图:下图是原来的模板.现在要求删 ...
- 批处理脚本+adb命令
app的测试过程中,有一些重复性的繁琐工作,可以采用用批处理脚本+adb命令方式来代替 说明: (1)等待时间我用的ping命令替代的,比较简单直观 (2)我采取的是用坐标定位,后续会使用控件来定位 ...
- 纯css实现轮播(渐变式 less语法)
下载:https://pan.baidu.com/s/181GkM0EdM5NSqnUcecMS4Q 预览
- 关于vue中this.attr代替this.data.attr访问的原理
请看如下例子: var obj = { name:"zhuwei", age:18 } function Person(data){ this.data = data; } var ...
- Android屏幕适配框架-(今日头条终极适配方案)
在Android开发中,屏幕适配是一个非常头痛的问题,因而为了去进行屏幕适配,作为程序员,是呕心沥血,历经磨难,哈哈 我们之前做屏幕适配一般都会用到一下两种方式: 第一种就是宽高限定符适配,什么是宽高 ...
- Angular Js 与bootstrap, angular 与 vue.js
今天突然接到电话, 问我他们的区别 虽然平时看了,但是没记住,凉凉是肯定的 总结一下: bootstrap不算是javascript框架,它只是一个前端的ui框架,然后有一些附带的js插件而已.an ...