基于VUE选择上传图片并在页面显示,图片可删除,具体内容如下
demo例子:
依赖文件: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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍ajax上传图片到PHP并压缩图片显示的方法,包括了ajax上传图片到PHP并压缩图片显示的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了ajax上传图片到PHP并压缩图片显示的具体代码,供大家参考,具体内容如下 需求就是,上传图片并压缩图片页面效果如下图: HTML代码 CSS代码和引入的bootstrap JS代码 PHP代码 图片压缩类请下载源码 以上就是本
问题内容: 在我的HTML表单中,我输入了类型为file的文件,例如: 然后,通过单击该输入按钮来选择多个文件。现在,我想在提交表单之前显示所选图像的预览。如何在HTML 5中做到这一点? 问题答案: HTML5带有FileAPI规范,它使您可以创建应用程序,使用户可以在本地与文件交互;这意味着您可以加载文件并在浏览器中呈现它们,而无需实际上传文件。FileAPI的一部分是FileReader接口
我的代码在下面..在中 在onActivityResult(int requestCode,int resultCode,Intent data)中
问题内容: 我正在将蜻蜓与jruby和apache tomcat一起使用来上传图像。我正在尝试显示使用profile_picture.thumb(‘30x30#’)。url动态修饰的图像 当我在轨道上使用ruby运行应用程序时,图像会正确显示。但是当我使用apache tomcat运行它时,图像不显示。 我认为,当我们在中部署war文件时,约定profile_picture.thumb(‘30x3
通过本案例,我们实现blobImage上传的图片在grid表格中的显示。 grid的cellRender方法渲染单元格显示图片,例: Model.prototype.personGridCellRender = function(event){ if(event.colName == "sPhoto"){ var url = biz.Request.setBizPar
通过这个示例我们实现通过attachmentImage上传的图片在grid表格中显示,分成两个步骤: 1.引入DocUtils: DocUtils = require('$UI/system/components/justep/docCommon/docUtil'); 2.通过grid的cellRender方法来显示图片 例: Model.prototype.imageGridCellRender