Javascript学习笔记13——关于响应事件
具体的事情记不清了,某一天下班后听到两个同事在说关于关于事件的问题。
这里简单说下:
<input type="button" runat="server" value="Click Me" id="ButtonTest" />很普通的一个按钮,我们要为其添加点击事件,有两种方法:
A.
<input type="button" runat="server" onclick="Alert()" value="Click Me" id="ButtonTest" />
<script type="text/javascript">
function Alert() {
alert("Click Me");
}
</script>
B.
<input type="button" runat="server" value="Click Me" id="ButtonTest" />
<script type="text/javascript">
document.getElementById("ButtonTest").onclick = function () {
alert("Click Me");
}
</script>
我们称A方法为静态绑定,B方法为动态绑定。我们来看A方法,他近乎可等于这样的效果:
<input type="button" runat="server" onclick="Alert()" value="Click Me" id="ButtonTest" />
<script type="text/javascript">
document.getElementById("ButtonTest").onclick = function () {
Alert();
}
</script>
也就是说,当我们静态绑定一个事件的时候,实际上是系统默认为我们做了一个匿名函数,然后把我们的方法体包于其中。由于这样,就涉及到了this的问题。
我们来看这样一段代码,这也是我在公司初学JS的时候,公司的JS小牛抛给我的问题。
<input type="button" runat="server" onclick="Alert1()" value="Test1" id="ButtonTest1" />
<input type="button" runat="server" onclick="Alert2(this)" value="Test2" id="ButtonTest2" />
<script type="text/javascript">
function Alert1() {
alert(this.value);
}
function Alert2(obj) {
alert(obj.value);
}
</script>
当试验这样一段代码时,便会发现第一个按钮会弹出”undefined”,第二个按钮弹出”Test2”。原因就是如我上面所说,在按钮一中,方法等于声明了一个匿名函数,然后讲Alert1()闭包于其中,也就是说,Alert1()是无法找到其调用者的,所以这时,他会去找window对象的value属性,结果发现未定义,我们可以这样证明:
<input type="button" runat="server" onclick="Alert1()" value="Test1" id="ButtonTest1" />
<input type="button" runat="server" onclick="Alert2(this)" value="Test2" id="ButtonTest2" />
<script type="text/javascript">
value = "window";
function Alert1() {
alert(this.value);
}
function Alert2(obj) {
alert(obj.value);
}
</script>
运行上面的代码,就可以很好地理解问题了!
分类:
Javascript相关
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!