HTML - 选择文件名后显示图像

Edw*_*ted 143 html file-upload

可能重复:
在上传图像之前预览图像

我有一个允许我的表格

<input type="file" name="filename" accept="image/gif, image/jpeg, image/png">
Run Code Online (Sandbox Code Playgroud)

浏览并选择一个文件.

我想要做的是在选择图像后立即显示该图像.这是在表单上的"提交"按钮被按下之前,因此图像几乎肯定存在于客户端.可以这样做吗?

ygs*_*oni 277

干得好:

HTML

<!DOCTYPE html>
<html>
<head>
<link class="jsbin" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1/themes/base/jquery-ui.css" rel="stylesheet" type="text/css" />
<script class="jsbin" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script class="jsbin" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.0/jquery-ui.min.js"></script>
<meta charset=utf-8 />
<title>JS Bin</title>
<!--[if IE]>
  <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<style>
  article, aside, figure, footer, header, hgroup, 
  menu, nav, section { display: block; }
</style>
</head>
<body>
  <input type='file' onchange="readURL(this);" />
    <img id="blah" src="#" alt="your image" />
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

脚本:

function readURL(input) {
        if (input.files && input.files[0]) {
            var reader = new FileReader();

            reader.onload = function (e) {
                $('#blah')
                    .attr('src', e.target.result)
                    .width(150)
                    .height(200);
            };

            reader.readAsDataURL(input.files[0]);
        }
    }
Run Code Online (Sandbox Code Playgroud)

现场演示

  • 我想你应该给Ivan Baev提供学分:http://stackoverflow.com/a/4459419/2550529 (12认同)
  • 这不适用于 IE!IE 没有 FileReader 类! (2认同)
  • 如果用户点击(取消)并且没有选择文件,则会向控制台抛出错误。在执行 `reader.readAsDataURL(input.files[0]);` 行之前,请检查 (f) 的值 (2认同)

Xav*_*ier 28

您可以使用以下代码实现此目的:

$("input").change(function(e) {

    for (var i = 0; i < e.originalEvent.srcElement.files.length; i++) {

        var file = e.originalEvent.srcElement.files[i];

        var img = document.createElement("img");
        var reader = new FileReader();
        reader.onloadend = function() {
             img.src = reader.result;
        }
        reader.readAsDataURL(file);
        $("input").after(img);
    }
});
Run Code Online (Sandbox Code Playgroud)

演示:http: //jsfiddle.net/ugPDx/


Kel*_*vin 6

这可以使用 HTML5 来完成,但仅适用于支持它的浏览器。这是一个例子

请记住,对于不支持此功能的浏览器,您需要另一种方法。我使用这个插件取得了很大的成功,它使您摆脱了很多工作。