前端图片上传的问题

时间:2012-04-27 07:32:55

标签: javascript jquery

我需要实现图片上传,其中缩略图出现在按钮旁边..我已经使用函数“getAsDataURL”实现了它,...它不能在chrome和safari中工作....任何解决方案??

<script type="text/javascript">
    function setImage(file) {
        if(document.all)
            document.getElementById('prevImage').src = file.value;
        else
            document.getElementById('prevImage').src = file.files.item(0).getAsDataURL();
        if(document.getElementById('prevImage').src.length > 0) 
            document.getElementById('prevImage').style.display = 'block';
    }
</script>


<div class="uploading_block_inner">
                                <div class="uploaded_img_inner"><img id="prevImage" style="display:none;" width="91" height="91" /></div>
                                <div class="submit_button_upload">
                                    <div class="upload"><input type="file" id=""  name="myImage" onchange="setImage(this);" /></div>
                                </div>
                                <div class="upload_submit_inner"><input type="submit" name="" value="" /></div>                             
                            </div>

1 个答案:

答案 0 :(得分:0)

假设您使用的是jQuery,我会为您提供以下解决方案。

$(document).ready(function(){
    $('input[type=file]').on('change', setImage);
});

function setImage(file) 
{
  if(document.all)
  {
    document.getElementById('prevImage').src = file.value;
  }
  else
  {
    document.getElementById('prevImage').src = file.files.item(0).getAsDataURL(); 
  }

  if(document.getElementById('prevImage').src.length > 0)
  {
    document.getElementById('prevImage').style.display = 'block'; 
  }
}