当我的 Flatiron School 课程第一阶段即将结束时,我已经学习了 JavaScript 编程的基础知识。但在这篇博文中,我将讨论我迄今为止最喜欢的主题的经验:事件和事件监听器。
JavaScript 可以侦听您正在使用的浏览器中可能发生的特定事件。 JS 可以听的东西有很多。一些示例包括按键、鼠标单击和表单提交,仅举几个最常用的示例。它们也是实现异步交互的好方法,即页面能够响应用户输入而不中断进程或重新加载页面。这对于网络应用程序的功能至关重要,因为网络应用程序需要类似的功能。我最喜欢事件的一点是,它们可以为您正在处理的 Web 项目添加大量交互性。
事件监听器是等待指定元素上发生特定事件的 JavaScript 函数。一旦事件触发,事件监听器就会执行特定的代码块(通常称为回调函数)。将事件侦听器附加到元素的最常见方法是使用 addEventListener 方法。
我将使用我目前在阶段末项目中使用的个人示例。对于我的项目,我创建了一个简单的 Web 应用程序,它从 API 获取信息并将其显示在带有交互元素的网页上。
我决定使用免费的 Amiibo API 创建一个 Web 应用程序,可以过滤多年来创建的所有 Yoshi Amiibo。我喜欢使用这个 API 的想法,因为 Yoshi 是我最喜欢的任天堂角色!
这是我如何制作此下拉菜单的示例,该菜单允许用户使用事件侦听器过滤不同的 Yoshi Amiibos!
这是我的特定函数的代码
const amiiboContainer = document.getElementById('amiibo-container'); const amiiboDropdown = document.getElementById('amiiboDropdown'); const amiibos = data.amiibo; // Create an array of names for the dropdown search const amiiboNames = amiibos.map(amiibo => amiibo.name); // Populate the dropdown with Amiibo names amiiboNames.forEach(name => { const option = document.createElement('option'); option.value = name; option.textContent = name; amiiboDropdown.appendChild(option); }); // Display all Amiibos initially displayAmiibos(amiibos); // Add an event listener to filter Amiibos when the dropdown value changes amiiboDropdown.addEventListener('change', (e) => { const selectedName = e.target.value; const filteredAmiibos = amiibos.filter(amiibo => amiibo.name === selectedName ); displayAmiibos(filteredAmiibos); }); })
让我带您了解一下这段代码中发生了什么。
我做的第一件事是为 Yoshi Amiibo 名字创建一个数组。
const amiiboNames = amiibos.map(amiibo => amiibo.name);
该行有一个映射函数,可迭代存储在 amiibos 数组中的项目。对于每个 amiibo 对象,它将采用 name 属性并返回一个包含所有 Amiibo 名称的新数组。
下一步是用 Amiibo 名称填充下拉菜单。
amiiboNames.forEach(name => { const option = document.createElement('option'); option.value = name; option.textContent = name; amiiboDropdown.appendChild(option); });
此块创建一个 HTML
对于每个名称,它:
- 创建一个新的选项元素。
- 将选项的 value 属性设置为 Amiibo 名称。
- 将选项的可见文本(textContent)设置为 Amiibo 名称。
- 将我们的新选项元素附加到下拉菜单 (amiiboDropdown)。
之后,我决定在使用过滤器下拉列表之前首先显示所有 Yoshi Amiibo。
const amiiboContainer = document.getElementById('amiibo-container'); const amiiboDropdown = document.getElementById('amiiboDropdown'); const amiibos = data.amiibo; // Create an array of names for the dropdown search const amiiboNames = amiibos.map(amiibo => amiibo.name); // Populate the dropdown with Amiibo names amiiboNames.forEach(name => { const option = document.createElement('option'); option.value = name; option.textContent = name; amiiboDropdown.appendChild(option); }); // Display all Amiibos initially displayAmiibos(amiibos); // Add an event listener to filter Amiibos when the dropdown value changes amiiboDropdown.addEventListener('change', (e) => { const selectedName = e.target.value; const filteredAmiibos = amiibos.filter(amiibo => amiibo.name === selectedName ); displayAmiibos(filteredAmiibos); }); })
我创建了这个函数,以便在页面加载时显示页面上的所有 Amiibo。其作用是将整个 amiibos 数组传递到我上面刚刚创建的函数中。
最后,我必须为下拉列表更改设置事件侦听器。
const amiiboNames = amiibos.map(amiibo => amiibo.name);
这是代码中最重要的部分之一,是该函数的事件监听器。这使得页面可以根据下拉菜单中选择的内容过滤页面上显示的 Amiibo。
其工作方式是 addEventListener() 函数侦听 amiiboDropdown 元素(或
其工作顺序是:
- selectedName 变量将存储使用 e.target.value 选择的任何选项的值
- 然后它将过滤 amiibos 数组,以确保它只包含与 selectedName 匹配的 Yoshi Amiibo。
- 过滤后,filteredAmiibos 数组会传递给 displayAmiibos(),然后该函数将使用过滤后的 Yoshi Amiibos 列表更新 UI。
总结
JavaScript 中的事件和事件监听器是开发具有交互性的 Web 应用程序时需要了解的一些最重要的事情。他们之所以伟大,仅因为这一点;它赋予应用程序功能和用途,同时为用户提供无缝体验的机会。
以上是JavaScript 中的事件和事件监听器的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript核心数据类型在浏览器和Node.js中一致,但处理方式和额外类型有所不同。1)全局对象在浏览器中为window,在Node.js中为global。2)Node.js独有Buffer对象,用于处理二进制数据。3)性能和时间处理在两者间也有差异,需根据环境调整代码。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

禅工作室 13.0.1
功能强大的PHP集成开发环境

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具