html,图片上传预览,input file获取文件等相关操作

input file常用方法:

var obj=document.getElementById("upimage");
var file=obj.files[0];//获取文件数据
var path=obj.value;//获取文件当前路径
var size=obj.files[0].size;//获取文件大小
var prefix=path.substring( path.lastIndexOf(‘\\‘)+1 );//获取文件名的前缀名(文件格式)
var suffix=path.substring(path.lastIndexOf(‘.‘)+1).toLocaleLowerCase();
//获取文件名的后缀名(文件格式)并且转换为小写

图片上传预览完整代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>上传图片</title>
<script type="text/javascript">
        //下面用于图片上传预览功能
        function setImagePreview() {
            var obj=document.getElementById("upimage");
            var imgObjPreview=document.getElementById("preview");
            var src=event.target || window.event.srcElement; //获取事件源,兼容chrome/IE
            //下面把路径截取为文件名
            var filename=src.value;//图片完整路径
            var prefix=filename.substring( filename.lastIndexOf(‘\\‘)+1 );//获取文件名的前缀名(文件格式)
            var suffix=filename.substring( filename.lastIndexOf(‘.‘)+1).toLocaleLowerCase(); //获取文件名的后缀名(文件格式)
            console.log(suffix);
            if(suffix !=‘jpg‘ && suffix !=‘png‘){
                alert("图片格式只能为jpg 或者 png");
                obj.outerHTML=obj.outerHTML;//清空选择按钮
                return false;
            }
            if(obj.files && obj.files[0])
            {
                if(obj.files[0].size>2048000){
                    alert("文件超过2M");
                    obj.outerHTML=obj.outerHTML;//清空选择按钮
                    return false;
                }
                //火狐下,直接设img属性
                imgObjPreview.style.display = ‘block‘;
                imgObjPreview.style.width = ‘150px‘;
                imgObjPreview.style.height = ‘180px‘;
                console.log(obj.files[0].size);
                    //imgObjPreview.src = obj.files[0].getAsDataURL();

                //火狐7以上版本不能用上面的getAsDataURL()方式获取,需要一下方式
                imgObjPreview.src = window.URL.createObjectURL(obj.files[0]);//写入文件流
            }
            else
            {
                obj.select();//IE下,使用滤镜
                var imgSrc = document.selection.createRange().text;//路径
                var localImagId = document.getElementById("imageDiv");
                var img=document.getElementById("preview");

                alert(localImagId.fileSize);
//必须设置初始大小
                localImagId.style.width = "150px";
                localImagId.style.height = "180px";
//图片异常的捕捉,防止用户修改后缀来伪造图片
                try{
                    localImagId.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
                    localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;//显示图片
                }
                catch(e)
                {
                    alert("您上传的图片格式不正确,请重新选择!");
                    return false;
                }
                imgObjPreview.style.display = ‘none‘;
                document.selection.empty();
            }
            return true;
        }

    </script>
</head>
<body>
<div id="imageDiv"><img id="preview" src="#"></div>
<form action="upload.do" method="post" enctype="multipart/form-data">
<input type="file" id="upimage" name="file" onchange="setImagePreview()"/> <input type="submit" value="Submit" /></form>
</body>
</html>  
时间: 2024-10-06 13:58:53

html,图片上传预览,input file获取文件等相关操作的相关文章

JS实现图片上传预览效果:方法一

<script type="text/javascript"> //处理file input加载的图片文件 $(document).ready(function(e) { //判断浏览器是否有FileReader接口 if(typeof FileReader =='undefined') { /*$("#images_show").css({'background':'none'}).html('亲,您的浏览器还不支持HTML5的FileReader接口

js:s上次预览,上传图片预览,图片上传预览

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

js前端实现多图图片上传预览

<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>测试页面</title> <script type="text/javascript"> //下面用于

Javascript之图片上传预览

使用Javascript之图片上传预览,我们无需上传到服务器中,兼容所有浏览器. 关键方法是使用微软库filter:progid:DXImageTransform.Microsoft.AlphaImageLoader来生成本地图片预览图的. <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <

多图片上传预览功能

//下面用于多图片上传预览功能 function setImagePreviews(avalue) { var docObj = document.getElementById("doc"); var dd = document.getElementById("dd"); dd.innerHTML = ""; var fileList = docObj.files; for (var i = 0; i < fileList.length;

移动端图片上传预览

前天要做wap版的图片上传预览,找了好半天才找到比较适合的插件,我在该插件的基础上修改了一些东西,比如:上传后的图片删除后不能再添加.不能限制上传图片的数量. input虽然有multiple(多选),但是android目前是不支持的. 该插件控制不了不能上传同一张图片,暂时没有思路解决这个问题(:′д`)ゞ 1 <!DOCTYPE html> 2 <html lang="zh-cn"> 3 4 <head> 5 <meta charset=&

图片上传-预览

<html><head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>javascript实现图片上传本地预览图片的代码-php自学网</title> <script type="text/javascript"> function checkFiles(str, ex

移动端 js 实现图片上传 预览

方法一: <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>测试页面</title> <script type="text/javascript"> /

来之不易的js图片上传预览代码

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getS