javascript - 将选中的图像渲染到指定的图像容器

标签 javascript jquery

下面是我的代码片段,我想做的是将选定的图像(从输入文件)渲染到指定的图像容器(“#test_image”),但不幸的是,它看起来像错过了,遗憾的是没有工作.有什么想法吗?

var prev_image;
$(document).ready(function(){
  $("input[type='file']").change(function(){
    //get the val of the previous image for the reset use later
    prev_image = $("#test_image").attr("src");
    //render the selected image on the image box (test_image)
    $("#test_image").attr("src", $(this).val());
   })
});
#test_image{
 width: 100px;
  height: 100px;
-webkit-border-radius: 50%;-moz-border-radius: 50%;border-radius: 50%;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<img id="test_image" src=""/>
<input type="file" />

最佳答案

HTML5 自带 File API spec ,它允许您创建让用户与本地文件交互的应用程序;这意味着您可以加载文件并在浏览器中呈现它们,而无需实际上传文件。文件 API 的一部分是 FileReader允许 Web 应用程序异步读取文件内容的接口(interface)。

var prev_image;
$(document).ready(function(){
  $("input[type='file']").change(function(){
    // handle input changes
    prev_image = $("#test_image").attr("src");
    // grab the first image in the FileList object and pass it to the function
    renderImage(this.files[0])
  });
});

// render the image in our view
function renderImage(file) {
  // generate a new FileReader object
  var reader = new FileReader();
  // inject an image with the src url
  reader.onload = function(event) {
    the_url = event.target.result
    $('#test_image').attr('src',the_url);
  }
  // when the file is read it triggers the onload event above.
  reader.readAsDataURL(file);
}
#test_image{
  width: 100px;
  height: 100px;
  -webkit-border-radius: 50%;-moz-border-radius: 50%;border-radius: 50%;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<img id="test_image" src=""/>
<input type="file" />

关于javascript - 将选中的图像渲染到指定的图像容器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32709661/

相关文章:

javascript - HTML anchor 标记无法在 Android 平台中下载文件

javascript - 如何在javascript中委托(delegate)它?

jquery - 验证表格

javascript - 使用内联编辑和自定义编辑器下拉控件的 Kendo Grid

javascript - after() 插入元素,然后取回

javascript - 从前一个 oncomplete 回调中打开新的 IndexedDb 事务是否安全?

javascript - "Intercepting"用户在文本框中输入并删除

未调用 Javascript 子选择器

javascript - 捕获从 iframe 抛出的alert()?

javascript - 使用 jquery 从 window 对象中删除事件监听器