基于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 IE 浏览器判定代码
Mar 21 Javascript
jQuery EasyUI API 中文文档 - Dialog对话框
Nov 15 Javascript
Javascript中call和apply函数的比较和使用实例
Feb 03 Javascript
javascript实现点击商品列表checkbox实时统计金额的方法
May 15 Javascript
AngularJS ng-style中使用filter
Sep 21 Javascript
Node.js的特点详解
Feb 03 Javascript
纯JS单页面赛车游戏制作代码分享
Mar 03 Javascript
VUE + UEditor 单图片跨域上传功能的实现方法
Feb 08 Javascript
vue单页应用在页面刷新时保留状态数据的方法
Sep 21 Javascript
video.js 一个页面同时播放多个视频的实例代码
Nov 27 Javascript
三步实现ionic3点击退出app程序
Sep 17 Javascript
JavaScript碰撞检测原理及其实现代码
Mar 12 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
推荐Discuz!5的PHP代码高亮显示与实现可运行代码
2007/03/15 PHP
PHP5.3安装Zend Guard Loader图文教程
2014/09/29 PHP
PHP将字符串首字母大小写转换的实例
2017/01/21 PHP
CakePHP框架Model函数定义方法示例
2017/08/04 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
php精度计算的问题解析
2019/06/21 PHP
jQuery.fn和jQuery.prototype区别介绍
2013/10/05 Javascript
Array栈方法和队列方法的特点说明
2014/01/24 Javascript
JavaScript使用pop方法移除数组最后一个元素用法实例
2015/04/06 Javascript
jQuery实现滚动切换的tab选项卡效果代码
2015/08/26 Javascript
微信小程序 弹窗自定义实例代码
2017/03/08 Javascript
jQuery实现手机号正则验证输入及自动填充空格功能
2018/01/02 jQuery
详解js类型判断
2018/05/22 Javascript
JavaScript中filter的用法实例分析
2019/02/27 Javascript
JS实现的检验身份证格式并输出出生日期,年龄,性别,出生地示例
2019/05/17 Javascript
vue自定义组件(通过Vue.use()来使用)即install的用法说明
2020/08/11 Javascript
vue-admin-template配置快捷导航的代码(标签导航栏)
2020/09/04 Javascript
初步理解Python进程的信号通讯
2015/04/09 Python
Python利用ElementTree模块处理XML的方法详解
2017/08/31 Python
Python Pywavelet 小波阈值实例
2019/01/09 Python
Python计算时间间隔(精确到微妙)的代码实例
2019/02/26 Python
python:按行读入,排序然后输出的方法
2019/07/20 Python
python程序 线程队列queue使用方法解析
2019/09/23 Python
简单了解python列表和元组的区别
2020/05/14 Python
用python爬虫批量下载pdf的实现
2020/12/01 Python
python 基于PYMYSQL使用MYSQL数据库
2020/12/24 Python
基于HTML5 audio元素播放声音jQuery小插件
2011/05/11 HTML / CSS
HTML5全屏(Fullscreen)API详细介绍
2015/04/24 HTML / CSS
KENZO官网:高田贤三在法国创立的品牌
2019/05/16 全球购物
一些.net面试题
2014/10/06 面试题
商场拾金不昧表扬信
2014/01/13 职场文书
装修五一活动策划案
2014/01/23 职场文书
最新奶茶店创业计划书范文
2014/02/08 职场文书
党的群众路线教育实践活动个人对照检查材料范文
2014/09/25 职场文书
离婚协议书包括哪些内容
2014/10/16 职场文书
pytorch fine-tune 预训练的模型操作
2021/06/03 Python