如何理解普通函数和箭头函数中的“this”?

2023-12-14

我想加载远程图像以获取其高度和宽度,但得到不同的结果。

下面的代码给了我正确的图像高度和宽度

img.onload= function() {
                    console.log('image;', this.width, this.height);
                    ctx.drawImage(img, 0, 0, width, height);
                };
img.src = url;

但我得到了undefined如果我使用箭头函数,则高度和宽度的值如下:

img.onload=() => {
                    console.log('image;', this.width, this.height);
                    ctx.drawImage(img, 0, 0, width, height);
                };
img.src = url;

谁能告诉我为什么我不能在箭头函数中得到它?如何获取箭头函数的大小?


箭头函数没有自己的this绑定,因此它使用它所封闭的那个。

要获得它,请定义一个event范围。并使用event.currentTarget.width.

img.onload = event => {
  console.log('image;', event.currentTarget.width, event.currentTarget.height);
  ctx.drawImage(img, 0, 0, width, height);
};
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何理解普通函数和箭头函数中的“this”? 的相关文章

随机推荐

  • 正则表达式匹配整行

    我是脚本编写新手 一直在阅读有关如何使用正则表达式的内容 我想获取与模式匹配的完整行 我的输出是 64 bytes from 33 33 33 33 icmp seq 9 ttl 254 time 1 011 ms 33 33 33 33
  • 使用 PHP DOMDocument 时 nextSibling 不起作用

    我尝试使用以下元素获取nextSibling并且以下代码不起作用 我有一个错误如下 PHP 警告 为 php dom php 第 35 行中的 foreach 提供的参数无效 这肯定是由 foreach 循环中的 null 值引起的 但如果
  • 某些提交中缺少 git-svn-id

    我有一个旧的 SVN 存储库 我使用它签出了git svn为了解决这个问题并推送到 Heroku 我做得相当标准git push heroku master git svn rebase git svn dcommit跳舞 一切都很好 然而
  • 数据操作 - 当值为字母数字时排序索引

    我想知道应该如何解决这种数据操作困境 在索引级别的值是字母数字的数据框中对多索引的索引进行排序的最佳方法是什么 这些值为 u 0 u 1 u 10 u 11 u 2 u 2Y u 3 u 3Y u 4 u 4Y u 5 u 5Y u 6 u
  • std::array 的推导指南

    我浏览了 C 模板独特指南 一书 并尝试了解其中的推导指南std array作品 关于标准的定义 声明如下 template
  • ServiceStack - 域和子域的身份验证

    我想将 ServiceStack 身份验证提供程序托管在域 domain com 的根目录上 并对整个域 sub1 domain com sub2 domain com 进行身份验证 是否可以替换默认实现ICookies用我自己的 这样我就
  • WCF请求/响应包大小

    我想知道是否有可配置的设置来限制 WCF 的最大请求 响应数据包大小 我正在使用 VSTS 2008 WCF 3 5 我将自托管 WCF 服务作为 Windows 服务 提前致谢 乔治 是的binding具有获取 设置最大接收数据字节的属性
  • 计算类方法中类类型的对象数量

    如何计算该类的方法中该类类型的对象数量 就此而言 如何在类之外执行此操作而不将对象添加到列表中 我早该想到的 谢谢 我将暂时搁置它 看看是否有更好的方法 因为我同意 我只是把我的头围绕着面向对象 如果您不介意让我多解释一下 也许总体上有更好
  • 为什么我无法在 JavaScript 中解析 JSON?

    JSON 包含一个对象 results 0 MAX id 1 并且这段代码不起作用 var text results 0 var obj JSON parse text console log obj MAX id results 0 已经
  • 使用 --strictNullChecks 时如何防止打字稿中的“Required”从类型中删除“未定义”

    Typescript 允许您删除 可选性 与 映射类型修饰符 可以轻松地与Required
  • 在 FastAPI 中请求端点时出现“解析正文时出错”错误

    我已经在 FastAPI 中实现了一个端点 并且正在从 Postman 测试它 但是每当我发送请求时 我都会收到此错误 解析正文时出错 在搜索错误时 我在需要安装 python multipart 的地方找到了一个解决方案 这个包已经安装了
  • 使用 MarshalByRefObject 跨应用程序域传递数据

    我在两个 NET 应用程序域之间传递一些数据时遇到了一些麻烦 我希望这里有人可以帮助我 基本上我拥有的是一个主要应用程序 Main 加载程序集A and B进入它的主域 然后当我运行插件时 C Main调用创建域方法B它创建一个新域并加载C
  • “[类名]”未命名 C++ 中的类型

    我正在使用列表列表编写图表 为此 我有两个类 每个类都有一个指向同一类的另一个对象的指针和一个指向第二个类的对象的指针 这是代码 文件V h ifndef VERTICEPUNT H define VERTICEPUNT H include
  • 使用 mailR 包通过 R 通过 Outlook 发送经过身份验证的邮件

    如何通过 Outlook 从 R 发送邮件 我被告知要使用sendmailR包 但我不知道如何指定某些控制设置 例如端口 用户名和密码 我也被重定向到这个帖子 但这并没有帮助 我切换到mailR包裹 我可以从其他服务器发送邮件 例如smtp
  • 无法通过脚本更改游戏对象颜色?

    我有一个 UI 画布 其中的图像与画布大小相同 这Image has an rgba of 0 0 0 0 使其不可见 因为a是 0 我想让图像从脚本中淡入黑色 这是我正在使用的代码 public class NavigationC Mon
  • 计算机重新启动后恢复批处理脚本

    我有一堆运行 Windows 2000 Pro 和 IE 5 0 的旧机器 我想将它们升级到带有 Silverlight 的 IE 6 我从微软的网站下载了 IE6 和 Silverlight 安装程序 幸运的是它们都有命令行选项 允许它们
  • 你能在 C# 中编写一段 C++ 代码吗?

    我听说你可以在 C 代码中直接切换到 C 这是怎么做到的 还是我听错了 注意 我的意思不是 C CLI 你可能会想unsafe blocks您可以在其中编写看起来很像 C 的代码 因为您可以使用指针
  • 如何在 JavaScript 中快速播放声音文件的多个副本

    我正在用 html js 构建一个旋转得相当快的命运之轮 每当一种新的颜色飞过标记时 色轮就会发出咔哒声 在最高速度下 这听起来几乎就像一挺机关枪 因此在旧文件基本上完成之前就开始播放新文件 文件本身始终相同 click wav 它在 Ch
  • 如何在Javascript中使用字符串作为变量名? [复制]

    这个问题在这里已经有答案了 可能的重复 有没有办法使用包含变量名称的字符串来访问 JavaScript 变量 JavaScript 通过名称字符串动态获取局部变量 一个简单的代码来说明我的问题 var chat 1 one var chat
  • 如何理解普通函数和箭头函数中的“this”?

    我想加载远程图像以获取其高度和宽度 但得到不同的结果 下面的代码给了我正确的图像高度和宽度 img onload function console log image this width this height ctx drawImage