基于VUE选择上传图片并页面显示(图片可删除)


Posted in Javascript onMay 25, 2017

基于VUE选择上传图片并在页面显示,图片可删除,具体内容如下

demo例子:

基于VUE选择上传图片并页面显示(图片可删除)

依赖文件:jqueryform

HTML文本内容:

<template>
 <div id="accident">
 <div class="wrapper">
 <i class="icon-pic"></i>相关照片
 <button type="button" @click="change_input()">上传照片</button>
 <form id="addTextForm" @change="setImg($event)">
 </form>
 </div>
 <div id="img-wrapper" @click="deleteImg($event)"></div>
 <P class="btn-wrapper">
 <mt-button type="primary" @click="submit()">提交</mt-button>
 </P>
 </div>
</template>

JS文本内容:

<script>
 /** 
 * 从 file 域获取 本地图片 url 
 */ 
 function getFileUrl(obj) { 
 let url; 
 url = window.URL.createObjectURL(obj.files.item(0)); 
 return url; 
 }

export default {
 name: 'accident',
 // 定义数据
 data () {
 return {
 imgNum:4, //上传的照片数量,可根据实际情况自定义 
 }
 },//定义事件
 methods:{
 //根据点击上传按钮触发input
 change_input(){
 let inputArr=$('#addTextForm input');
 let add_inputId=''; //需要被触发的input
 for(let i=0;i<inputArr.length;i++){
 // 根据input的value值判断是否已经选择文件
 if(!inputArr[i].value){ //如果没有选择,获得这个input的ID 
 add_inputId=inputArr[i].id;
 break;
 }
 }
 if(add_inputId){ //如果需要被触发的input ID存在,将对应的input触发
 return $("#"+add_inputId).click();
 }else{
 alert("最多选择"+this.imgNum+"张图片")
 }
 },
 //当input选择了图片的时候触发,将获得的src赋值到相对应的img
 setImg(e){
 let target=e.target;
 $('#img_'+target.id).attr('src',getFileUrl(e.srcElement));
 },
 //点击图片删除该图片并清除相对的input
 deleteImg(e){
 let target=e.target;
 let inputID=''; //需要清除value的input
 if(target.nodeName=='IMG'){
 target.src='';
 inputID=target.id.replace('img_',''); //获得需要清除value的input
 $('input#'+inputID).val("");
 }
 },
 //提交信息到后台
 submit(){
 $("#addTextForm").ajaxSubmit({
 url: this.$root.api+"/Index/staff_accident/add", 
 type: "post",
 data: {
 'total_price':this.price,
 'descript':this.descript,
 },
 success: (data) => {
 if(data.code==0){
 console.log(‘提交成功');
 }else{
 alert('提交失败');
 }
 }
 }); 
 }
 },
 //页面加载后执行
 mounted(){
 for(let i=0;i<this.imgNum;i++){
 //生成input框,默认为1
 let my_input = $('<input type="file" name="image" />'); //创建一个input
 my_input.attr('id',i); //为创建的input添加id
 $('#addTextForm').append(my_input); //将生成的input追加到指定的form
 //生成img,默认为1
 let my_img = $('<img src="">');
 my_img.attr('id', 'img_'+i);
 my_img.css({"max-width":"50%","max-height":"200px"}); 

 //添加样式,由于vue的执行机制,页面加载的时候img标签还没有生成,直接写在style样式会不生效
 $('#img-wrapper').append(my_img); 
 }
 },
}
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用Javascript和DOM Interfaces来处理HTML
Oct 09 Javascript
Google Suggest ;-) 基于js的动态下拉菜单
Oct 11 Javascript
JAVASCRIPT代码编写俄罗斯方块网页版
Nov 26 Javascript
jQuery中的siblings()是什么意思(推荐)
Dec 29 Javascript
详解angular中如何监控dom渲染完毕
Jan 03 Javascript
jquery横向纵向鼠标滚轮全屏切换
Feb 27 Javascript
js+canvas实现动态吃豆人效果
Mar 22 Javascript
JS实现匀加速与匀减速运动的方法示例
Sep 04 Javascript
浅谈es6语法 (Proxy和Reflect的对比)
Oct 24 Javascript
js判断文件类型大小并给出提示的实现方法
Jan 03 Javascript
JavaScript设计模式之代理模式简单实例教程
Jul 03 Javascript
VSCode写vue项目一键生成.vue模版,修改定义其他模板的方法
Apr 17 Javascript
jQuery滚动插件scrollable.js用法分析
May 25 #jQuery
Angular2学习教程之TemplateRef和ViewContainerRef详解
May 25 #Javascript
Bootstrap组件之下拉菜单,多级菜单及按钮布局方法实例
May 25 #Javascript
vue-router实现webApp切换页面动画效果代码
May 25 #Javascript
Angular 2.x学习教程之结构指令详解
May 25 #Javascript
bootstrap动态添加面包屑(breadcrumb)及其响应事件的方法
May 25 #Javascript
js获取一组日期中最近连续的天数
May 25 #Javascript
You might like
PHP has encountered an Access Violation 错误的解决方法
2010/01/17 PHP
php 使用file_get_contents读取大文件的方法
2014/11/13 PHP
Laravel中间件实现原理详解
2016/10/09 PHP
Centos 6.5系统下编译安装PHP 7.0.13的方法
2016/12/19 PHP
PHP命名空间用法实例分析
2019/09/04 PHP
jquery的相对父元素和相对文档定位示例代码
2013/08/02 Javascript
jQuery lazyLoad图片延迟加载插件的优化改造方法分享
2013/08/13 Javascript
IE6 hack for js 集锦
2014/09/23 Javascript
EasyUI实现二级页面的内容勾选的方法
2015/03/01 Javascript
jQuery实现网页抖动的菜单抖动效果
2015/08/07 Javascript
JavaScript 深层克隆对象详解及实例
2016/11/03 Javascript
js 实现省市区三级联动菜单效果
2017/02/20 Javascript
Vue2.0使用过程常见的一些问题总结学习
2017/04/10 Javascript
微信小程序实现瀑布流布局与无限加载的方法详解
2017/05/12 Javascript
Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖
2018/11/25 Javascript
vue刷新页面时去闪烁提升用户体验效果的实现方法
2018/12/10 Javascript
JS实现数组去重及数组内对象去重功能示例
2019/02/02 Javascript
详解小程序BackgroundAudioManager踩坑之旅
2019/12/08 Javascript
Vue路由的模块自动化与统一加载实现
2020/06/05 Javascript
[03:38]2014DOTA2西雅图国际邀请赛 VG战队巡礼
2014/07/07 DOTA
Python脚本实现DNSPod DNS动态解析域名
2015/02/14 Python
Python封装shell命令实例分析
2015/05/05 Python
利用python求相邻数的方法示例
2017/08/18 Python
tornado 多进程模式解析
2018/01/15 Python
python面向对象多线程爬虫爬取搜狐页面的实例代码
2018/05/31 Python
使用python将图片按标签分入不同文件夹的方法
2018/12/08 Python
PyQt5实现五子棋游戏(人机对弈)
2020/03/24 Python
python实现删除列表中某个元素的3种方法
2020/01/15 Python
意大利团购网站:Groupon意大利
2016/10/11 全球购物
爱奇艺VIP会员:大剧抢先看
2018/07/11 全球购物
学校安全检查制度
2014/01/27 职场文书
学生会干部自我鉴定2014
2014/09/18 职场文书
老人再婚离婚协议书范本
2014/10/27 职场文书
中学生打架《检讨书》范文
2019/08/12 职场文书
Python实战之实现简易的学生选课系统
2021/05/25 Python
MySQL的索引你了解吗
2022/03/13 MySQL