- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当点击事件发生时,事件信息在e
中可用,对吧?我只是想尝试理解两件事,抱歉我的无知。
第一个问题是:“id”实际上是什么?它是 React 通过 onClick 获取的特殊变量吗?如果是这样,为什么不是 this.id?
还有,为什么需要 this.deleteRow.bind(this, id)
再次绑定(bind)“this”?如果 this.deleteRow 有效,我没想到会出现第二个“this”。那么为什么需要再次绑定(bind)'this'呢?
<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button>
<button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>
最佳答案
<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button>
此版本的事件监听器清楚地表明 deleteRow
方法(我们未显示其实现)采用两个参数。 id
可能是应删除的行的一些标识符,而 e
必须是实际的事件对象(因为这始终是浏览器向事件回调提供的参数) )。
所以这是最明确的形式。但请注意,如果由于某种原因您的代码在不支持箭头函数的环境中运行(并且您没有先转译它),那么这显然是行不通的。并且可能需要箭头函数,因为如果没有它,deleteRow
方法中的 this
将不会是您期望的那样,特别是像 this.setState
不起作用。
除非您已采取其他步骤来确保 deleteRow
内的 this
正确,例如在第二个示例中:
<button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>
bind函数对象的方法返回另一个相关的函数,并且有 2 个方便的属性。第一个,也是与上述讨论的上下文中最相关的,是函数内的 this 引用始终引用的对象。在任何情况下,您都将 this
引用“绑定(bind)”为始终如您所说。 (好吧,除非你尝试使用 new
来调用绑定(bind)函数作为构造函数,我认为这不是你真正想要做的事情。)所以这避免了“this
问题”,否则您可能会遇到这样的问题,而不需要任何特定于 ES6 的功能(.bind
自 ES5 以来就已存在)。
bind
的另一个有用功能与它如何绑定(bind) this
完全无关,即 .bind
的所有其他参数作为参数传递给函数,如果有剩余,它们将作为新创建的“绑定(bind)函数”的参数。这称为“部分应用” - 您通过向函数传递一些它想要的参数来“部分应用”该函数,然后在调用新创建的函数时传递其他参数。
因此,在这种情况下,deleteRow
将具有如下签名:
deleteRow(id, event) {...}
函数 myThis.deleteRow.bind(myThis, myId)
会将 deleteRow
内出现的所有 this
绑定(bind)到 myThis
创建一个新函数,该函数采用单个参数 event
,并将其作为第二个参数提供给 deleteRow
,第一个参数固定为 我的ID
。因此,当它作为事件处理程序调用并传递事件对象时,它的行为方式与上面的箭头函数版本完全相同 - 具有正确的 this
、特定的 id
desired 作为第一个参数,event 作为第二个参数。
我认为毫无疑问箭头函数版本应该是首选,因为更加明确。即使您不能这样做,您仍然可以通过以下方式避免部分应用:
this.deleteRow = this.deleteRow.bind.this
,以及关于javascript - 寻找有关 React 事件上的 bind(this, id) 的说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55380660/
我正在查看预先重写的 jQuery 代码。我无法理解以下代码。 $('body > *:not(#print-modal):not(script)').clone(); 最佳答案 此选择器匹配以下任何
所以我开始学习MySQL,我对表有点困惑,所以我想澄清一下。数据库中可以有多个表吗?例如: Database1 -Table1 -Username -Password -Table2 -Name
我在 PostgreSQL 中编写了一个函数,其代码如下: for (i = 0; i str[0][i]); values[i] = datumCopy(dat_value,
oid: 行的对象标识符(对象 ID)。这个字段只有在创建表的时候使用了 WITH OIDS ,或者是设置了default_with_oids 配置参数时出现。 这个字段的类型是 oid (和字段同
我在搜索最大连接设备数时发现了 a post大致说: 当使用 P2P_STAR 时,最大设备数量为 10,因为此 topoly 使用 Wi-Fi 热点。也就是说,如果您没有路由器。 这让我问了两个问题
我不明白为什么会这样: Printf.sprintf "%08s" "s" = Printf.sprintf "%8s" "s" - : bool = true 换句话说,我希望: Printf.sp
我正在遵循 Grails in Action 中的示例。我有一个问题,如何理解 addTo*()功能有效。 我有一个简单的域:具有以下关系的用户、帖子、标签: 用户1对M发帖 用户一对一标签 发布 M
请问为什么行 "b[0]= new Child2();"在运行时而不是在编译时失败。请不要检查语法,我只是在这里做了 class Base {} class Child1 : Base {} clas
所以我想进一步加深我对套接字的理解,但是我想首先从最低级别开始(在C语言中,而不是在汇编中大声笑) 但是,我处理的大多数站点都使用SOCK_STREAM或SOCK_DGRAM。但是我已经阅读了Beej
好吧,我对 javascript 语法了解甚少,而且我对 null 的行为感到非常困惑。关于空值有很多讨论,但我似乎无法找出问题所在!请帮我。这是脚本。 var jsonData = '';
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭5 年前。 Improve thi
问题: SeriesSum 类旨在计算以下系列的总和: 类名:SeriesSum 数据成员/实例变量: x:存储整数 n:存储术语数量 sum:用于存储系列总和的双变量 成员函数: SeriesSum
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
今天我在 logcat 中注意到以下内容: D/OpenGLRenderer:0xa2c70600 (CardView) 上的 endAllStagingAnimators,句柄为 0xa2c9d35
如何创建值有序对的列表,例如list1 [(x, y), (x1, y1) ...].?? 学习如何创建此列表后,我需要知道如何将 x 值提供给列表中的用户输入并搜索 x 的下一个值并显示有序对 (x
我在存储过程中有以下逻辑。 这里完成了什么? 如果color为null,替换为'' IF ISNULL(@color, '') <> '' BEGIN END 最佳答案 它等同于: IF (@colo
我知道.Net中的接口(interface)定义了接口(interface)和继承它的类之间的契约。刚刚完成了一个大量使用数据访问层接口(interface)的项目,这让我开始思考。 . .有什么大不
如何防止基类方法被子类覆盖 最佳答案 您不需要做任何特别的事情:默认情况下方法是不可覆盖的。相反,如果您希望该方法可重写,则必须将 virtual 关键字添加到其声明中。 但是请注意,即使方法不可重写
我已阅读以下有关工厂模式的文章 here 请仅引用Class Registration - avoiding reflection这一部分。 这个版本在没有反射的情况下实现了工厂和具体产品之间的减少耦
我正在学习 Java 类(class),但无法完全理解下一课的内容。 目的:本课的目的是通过创建一个模拟 for-each 循环如何工作的替代方案来解释 for-each 循环的工作方式。 在上一课中
我是一名优秀的程序员,十分优秀!