JavaScript - 表单提交前预览图片
其实这东西网上到处都是,但并不完整。
正好我也遇到了这个问题,不仅仅是预览,还需要得到图片的属性。
于是东凑西凑整理出一个完整的版本,并根据个人的理解加上了一点点说明。
首先做一些准备工作,HTML方面主要是img和input标签的id:
<form>
<input type='file' id="imgFile" />
<div id="previewDiv">
<img id="previewImg" src="#" alt="your image" />
</div>
</form>
另外,要为imgFile的change事件设置function:
$(function(){
$('#imgFile').change(function(e){doPreview(this);})
});
先从IE开始,IE上还是比较容易的。
对于file控件的value会老老实实地获取,
而且创建Image对象时只需要指定src属性值就能成功。
剩下的就是从Image对象中获得属性了。
代码如下:
function doPreview(){
document.getElementById('imgFile').src = input.value;
var img = new Image();
img.src = input.value;
alert('width:'img.width+'; height:'+img.height);
}
当然,我们也可以不用img元素:
function doPreview(){
var previewDiv = document.getElementById("previewDiv");
previewDiv.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = input.value;
var img = new Image();
img.src = input.value;
previewDiv.style.width = img.width;
previewDiv.style.height = img.height;
alert('width:'+img.width+'; height:'+img.height);
}
如果要使用上面的filter,还需要加上:
<style type="text/css">
#previewDiv {
filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);
}
</style>
但这种方式在chrome下是行不通的,因为input.value会输出这样的结果:
也就是做了些安全处理,似乎修改浏览器设置就可以,但我们不希望每个人都修改设置。
而FileReader对象恰好可以解决这个问题,
我的情况需要用到FileReader的readAsDataURL。
readAsDataURL将blob读作一个URL,load事件触发后将结果保存在this.result。
试着输出一下返回结果,大概是如下结果,长度几万到几十万不等:
其实这个返回结果可以直接用作img.src的值。
剩下的就没有什么难度了。
完整代码如下:
$(function(){
$('#imgFile').change(function(e){doPreview(this);})
});
function doPreview(input) {
if (input.files && input.files[0]) {
var reader = new FileReader();
var file = input.files[0];
reader.readAsDataURL(file);
reader.onload = function (e) {
var img = new Image();
img.src = this.result;
img.onload = function(){
var w = this.width,
h = this.height,
t = file.type,
n = file.name,
s = ~~(file.size/1024) +'KB';
$('#previewDiv').append('<img src="' + this.src +'"> '+w+'x'+h+' '+s+' '+t+' '+n+'<br>');
}
};
}else{
var previewDiv = document.getElementById("previewDiv");
previewDiv.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = input.value;
//previewDiv.innerHTML = '<img src="'+input.value+'" />'
//document.getElementById('previewImg').src = input.value;
var img = new Image();
img.src = input.value;
previewDiv.style.width = img.width;
previewDiv.style.height = img.height;
alert('width:'+img.width+'; height:'+img.height);
}
}
JavaScript - 表单提交前预览图片的更多相关文章
- hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images
hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images, 本例子主要是使用HTML5 的File API,建立一個可存取到该file的url, 一个空的img标签,ID为img0,把 ...
- springmvc下js控制表单提交(表单提交前检验,提交后获取json返回值)
这个问题我搞了四天,终于搞懂.因为对js很不熟悉.郁闷的是后台代码出错总可以设置断点调试,前端js代码出错只能通过浏览器提供一些运行数据来分析,很不习惯. 首先说下逻辑:这是一个注册功能,我希望,注册 ...
- JavaScript表单提交四种方式
总结JavaScript表单提交四种方式 <!DOCTYPE html> <html> <head> <title>JavaScript表单提交四种方式 ...
- form的onsubmit事件--表单提交前的验证最佳实现方式
今天遇到了一个问题,页面中include了很多的公共页面(都是没有form的),并且里面好多的地方都是自行提交的(页面中加入一个type=“submit”域,然后js中写入sumbit.click来执 ...
- javascprit form表单提交前验证以及ajax返回json
1.今天要做一个手机验证码验证的功能.需求是前端页面点击发送 短信验证码,后台接收后通过ajax返回到前端,之后前端在提交时候进行验证.思路很简单,不过做的过程还是学到不少的东西. 1.ajax请求后 ...
- a标签指定的url,在表单提交前进行js验证的实现
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Html form 表单提交前验证
可以使用form表单的onsubmit方法,在提交表单之前,对表单或者网页中的数据进行检验. onsubmit指定的方法返回true,则提交数据:返回false不提交数据. 直接看下面的代码: 1 & ...
- js 在表单提交前进行操作
最近在写页面的时候,需要手动写一些在表单进行提交前的验证操作,正好看到了2种阻止表单提交的方法,可以进行一些逻辑处理 方法一:使用return false 原生js写法: <form id=&q ...
- easyui 表单提交前的 confirm 处理
最近学习用 easyui,异步提交表单是遇到一个小问题 $('#fModiDetail').form('submit',{ url:'...', onSubmit:function(){ if($(t ...
随机推荐
- random 随机生成字符串
# import random# for x in range(10):# i = 0# l = []# while i < 10:# ret = chr(random.randint(33, ...
- day13学python 协程+事件驱动
协程+事件驱动 协程 (微线程)--用处多,重点 当调度切换时 靠寄存器上下文和栈保存 要使用时再调用(即可不会因io传输数据卡壳 从而耗时无法继续进行)实现并行 优缺点: 优点: 1 无需同线程上下 ...
- Sublime Text3 最新版3207 安装及破解
注:原文地址 https://www.abbeyok.com/archives/337 Sublime Text 3最近更新了新版本,最新版本:3207,之前的license无效了,新版破解方法如下: ...
- Codeforces Round #549 (Div. 2)C. Queen
C. Queen time limit per test 1 second memory limit per test 256 megabytes input standard input outpu ...
- Windows 64位操作系统下安装和配置MySQL
一安装方式 MySQL安装文件分为两种,一种是MSI格式的,一种是ZIP格式的.下面来看看这两种方式: MSI格式的可以直接点击安装,按照它给出的安装提示进行安装,Windows操作系统下一般MySQ ...
- [CoffeeScript]在WebStorm里运行CoffeeScript
CoffeeScript 是一门编译到 JavaScript 的小巧语言. 在 Java 般笨拙的外表下, JavaScript 其实有着一颗华丽的心脏. CoffeeScript 尝试用简洁的方式展 ...
- Codeforces - 331B2 权值线段树 区间合并
题意:题目太玄了我无法用语言精简.. 题目要求的操作1是基于值的,所以用普通线段树基本无法维护(反正我不知道) 换做权值型后十分好做,因为连接处必然是更后面的,这时比较一下位置就好 PS.感觉周赛越来 ...
- DOM操作 045
一 什么是DOM DOM : 文档对象模型 它为文档提供了结构化表示 并定义了如何通过脚本来访问文档结构 . 目的就是为了能让js操作HTML元素而制定的一个规范 . DOM树(一切都是节点): 元素 ...
- 那些H5用到的技术(4)——弹幕
前言思路实现模式无限循环模式时间线模式停止显示弹幕 前言 以前玩卷轴射击游戏的时候,大量的BOSS子弹让我们无路可逃的时候,让我见识到了真正弹幕的威力,可自从A站B站火了之后,大量评论留言参与到了视频 ...
- nodejs 并发控制
1.用 eventproxy 实现控制并发: var EventProxy = require('eventproxy'); const most = 5;//并发数5 var urllist = [ ...