qq_34814994 2019-10-22 22:36 采纳率: 50%
浏览 1231

fileObj = document.getElementById("file").files[0]; 我想直接把地址给这个变量

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>压缩图片demo</title>
</head>
<body>
    <img id="img" src="">
    <input id="file" type="file" onchange="compress()">
</body>
<script>

// 对图片进行压缩
function compress() { 
    if(typeof FileReader=='undifined')            //判断浏览器是否支持filereader
        {
        result.innerHTML="<p>抱歉,你的浏览器不支持 FileReader</p>";
        return false;
        }
    var file=document.getElementById("file").files[0];
    if(!/image\/\w+/.test(file.type))            //判断获取的是否为图片文件
       {
        alert("请确保文件为图像文件");
        return false;
       }
    fileObj = document.getElementById('file').files[0] //上传文件的对象
    reader = new FileReader()
    reader.readAsDataURL(fileObj)
    reader.onload = function(e) {
        image = new Image() //新建一个img标签(还没嵌入DOM节点)
        image.src = e.target.result
        image.onload = function() {
            canvas = document.createElement('canvas'), 
            context = canvas.getContext('2d'),
            imageWidth = image.width / 10,    //压缩后图片的大小
            imageHeight = image.height / 10,
            data = ''

            canvas.width = imageWidth
            canvas.height = imageHeight

            context.drawImage(image, 0, 0, imageWidth, imageHeight)
            data = canvas.toDataURL('image/jpeg')

            //压缩完成 
            document.getElementById('img').src = data
        }
    }
}
</script>
</html>
    上面是压缩图片的案例,我 不想用按钮,想直接把“1.jpg”赋值给fileObj,请问该怎么办??
  • 写回答

2条回答 默认 最新

  • 毕小宝 博客专家认证 2019-10-23 09:12
    关注

    onchange 事件能触发吗?如果不能的化试试 onblur 事件呢?

    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!