js报错 Uncaught DOMException: Failed to execute ‘getImageData‘ on ‘CanvasRenderingContext2D‘: The can

在使用IDEA进行前端开发时遇到getImageData跨域错误,尝试了设置时间戳、修改image的crossOrigin属性及调整浏览器设置等方法未果。最终通过在VsCode中安装LiveServer插件成功解决,该插件提供了本地服务器环境,避免了直接从文件系统加载导致的跨域问题,操作简单便捷。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在用IDEA时,调用getImageData()报跨域的错误,原因是图片存储在本地时,是默认没有域名的,用getImageData方法时,浏览器会判定为跨域而报错。

搜索了很多方法尝试解决,包括:

  1. 设置时间戳
var img = new Image();
var url = 'https://media.prod.mdn.mozit.cloud/attachments/2013/06/22/5397/7a3ec0cae64a95ad454ac3bc2c71c004/rhino.jpg';
img.src = url + '?' + new Date().getTime();
img.setAttribute('crossOrigin', '');

https://blog.youkuaiyun.com/leftfist/article/details/106947101

  1. 设置crossOrigin属性并修改浏览器设置
    var canvas = document.createElement('canvas');
    var context = canvas.getContext('2d');
    var img = new Image();
    img.crossOrigin = '';    //这里!!!
    img.onload = function () {
        context.drawImage(this, 0, 0);
        context.getImageData(0, 0, this.width, this.height);
    };
    img.src = 'https://vip.itzlm.cn/images/canvas.jpg';

https://www.cnblogs.com/happy-8090/p/11244056.html

  1. 更改浏览器设置: --allow-file-access-from-files 或 --disable-web-security

https://blog.youkuaiyun.com/w5167839/article/details/45485645

2、3操作也并行试过了,不知道是不是操作问题,始终不得行。。

最终的解决方案是,使用VsCode,下载一个叫Live Server的插件:

Live Server
然后在右下角启用它:

在这里插入图片描述
打开html文件的时候,在VsCode中右键点击 Open With Live Server

在这里插入图片描述
就可以啦!

非常非常简单!

在这里插入图片描述

https://blog.youkuaiyun.com/weixin_41056807/article/details/109533221

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值