使用 HTML, CSS 和 JavaScript 显示下拉列表中选中的项目

使用 html, css 和 javascript 显示下拉列表中选中的项目

使用 HTML, CSS 和 JavaScript 显示下拉列表中选中的项目

本文详细介绍了如何使用 HTML, CSS 和 JavaScript 创建一个动态下拉列表,该列表从 JSON 数组中获取数据,并允许用户搜索和选择项目。文章重点讲解了如何捕获用户选择的项目,并将其显示在页面上,同时提供代码示例和注意事项,帮助开发者快速实现该功能。

HTML 结构

首先,我们需要定义 HTML 结构来创建下拉列表。以下代码展示了一个基本的下拉列表结构,包含一个按钮用于触发下拉列表的显示,一个输入框用于搜索,以及一个用于显示列表项的 div 元素。

CSS 样式

立即学习“Java免费学习笔记(深入)”;

接下来,我们需要使用 CSS 来美化下拉列表的外观。以下代码展示了一些基本的 CSS 样式,用于定义下拉列表的布局、颜色和字体等。

#myInput {  box-sizing: border-box;  background-image: url('searchicon.png'); /* 可选:添加搜索图标 */  background-position: 14px 12px;  background-repeat: no-repeat;  font-size: 16px;  padding: 14px 20px 12px 45px;  border: none;  border-bottom: 1px solid #ddd;}#myInput:focus {  outline: 3px solid #ddd;}.dropdown {  position: relative;  display: inline-block;}.dropdown-content {  display: none;  position: absolute;  background-color: #f6f6f6;  min-width: 230px;  border: 1px solid #ddd;  z-index: 1;}.dropdown-content a {  color: black;  padding: 12px 16px;  text-decoration: none;  display: block;  cursor: pointer; /* 添加鼠标悬停样式 */}.dropdown-content a:hover {  background-color: #f1f1f1;}.show {  display: block;}.dropdown-content > .dropdown-option{  cursor: pointer;}.dropdown-content > .selectedOption{  background-color: darkgray !important;}

JavaScript 逻辑

现在,我们需要使用 JavaScript 来实现下拉列表的动态功能。以下代码展示了如何从 JSON 数组中获取数据,动态生成列表项,并实现搜索和选择功能。

function myFunction() {  var country = [    { "ID": "001", "Country_Name": "India" },    { "ID": "002", "Country_Name": "Australia" },    { "ID": "003", "Country_Name": "Austria" },    { "ID": "004", "Country_Name": "China" },    { "ID": "005", "Country_Name": "Bangladesh" }  ];  var dropdown = document.getElementById("myDropdown");  dropdown.classList.toggle("show");  dropdown.innerHTML = ''; // Clear existing content  // Add search input  let input = document.createElement('input');  input.type = 'text';  input.placeholder = 'Search...';  input.id = 'myInput';  input.onkeyup = filterFunction;  dropdown.appendChild(input);  // Populate dropdown with country options  for (var i = 0; i  {    o.classList.remove('selectedOption');  });  // Add selectedOption class to the selected option  clickedOption.classList.add('selectedOption');  // Log selected country details  console.log(`${countryID} - ${countryName}`);  console.log(getSelectedOption());  // You can further update the UI to display the selected country  // For example, update a  element with id 'selectedCountry'  // document.getElementById('selectedCountry').innerText = countryName;}function getSelectedOption() {  return document.querySelector('#myDropdown > .dropdown-option.selectedOption');}function filterFunction() {  var input, filter, a, i;  input = document.getElementById("myInput");  filter = input.value.toUpperCase();  div = document.getElementById("myDropdown");  a = div.getElementsByTagName("a");  for (i = 0; i  -1) {      a[i].style.display = "";    } else {      a[i].style.display = "none";    }  }}

代码解释:

myFunction(): 这个函数负责显示和隐藏下拉列表。它首先从 JSON 数组中获取国家数据,然后动态生成列表项,并将其添加到 myDropdown 元素中。此外,它还动态创建搜索框。countryOnClick(event): 这个函数处理列表项的点击事件。当用户点击一个列表项时,该函数会获取选中的国家 ID 和名称,并将其显示在控制台中。你可以根据实际需求修改该函数,例如将选中的国家显示在页面上的某个元素中。该函数还负责更新选中项的样式。getSelectedOption(): 返回当前选中的元素。filterFunction(): 这个函数负责实现搜索功能。当用户在搜索框中输入内容时,该函数会根据输入的内容过滤列表项,只显示包含输入内容的列表项。

注意事项:

确保 JSON 数组中的数据格式正确,并且包含 ID 和 Country_Name 字段。可以根据实际需求修改 CSS 样式,以美化下拉列表的外观。可以根据实际需求修改 JavaScript 代码,以实现更复杂的功能,例如多选、自动完成等。为了更好的用户体验,可以添加加载状态,在数据加载完成之前显示加载动画。在countryOnClick函数中,可以根据实际需求更新UI,例如将选中的国家显示在页面上。

总结:

本文详细介绍了如何使用 HTML, CSS 和 JavaScript 创建一个动态下拉列表,并实现搜索和选择功能。通过本文的学习,你可以快速创建一个功能完善的下拉列表,并将其应用到你的项目中。 记住,代码只是一个起点,根据你的具体需求进行修改和扩展才是关键。

以上就是使用 HTML, CSS 和 JavaScript 显示下拉列表中选中的项目的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1579140.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 20:22:35
下一篇 2025年12月22日 20:22:47

相关推荐

  • 使用 CSS 创建倾斜角的形状

    本文介绍了如何使用 CSS 的 `clip-path` 属性创建一个带有倾斜角的矩形形状。通过调整 `clip-path` 属性中的坐标值,可以灵活地控制倾斜角度和形状。本文提供了详细的代码示例和解释,帮助你轻松实现各种倾斜角形状的设计。 使用 CSS 的 clip-path 创建倾斜角形状 在网页…

    好文分享 2025年12月23日
    000
  • JavaScript:高效检测页面所有复选框状态的教程

    本教程深入探讨了在javascript中检测页面所有复选框(checkboxes)状态的两种高效方法。我们将学习如何利用 `array.some()` 快速判断是否存在未选中的复选框,以及如何使用 `array.filter()` 精确统计已选中和未选中的复选框数量,并提供详细的代码示例和最佳实践指…

    2025年12月23日
    000
  • 深入理解CSS选择器:向上遍历的局限与:has()的崛起

    css选择器遵循从上到下的级联与遍历规则,传统上无法实现类似数学中的括号来影响操作顺序,也无法向上遍历dom树。这意味着无法直接基于子元素的状态来选择其父元素或父元素的兄弟元素。然而,新兴的`:has()`伪类正在改变这一现状,它允许开发者根据子元素的存在或状态来选择父元素或祖先元素,从而间接实现更…

    2025年12月23日
    000
  • HTML5怎么制作天气应用_HTML5天气组件开发实战

    使用HTML5、CSS3和JavaScript结合OpenWeatherMap API可快速开发响应式天气应用。2. 页面结构包含输入框、按钮和结果显示区域。3. 通过fetch调用API获取实时天气数据,支持中文和摄氏度单位。4. 数据渲染包括城市名、温度、图标、湿度和风速,并用CSS美化界面。5…

    2025年12月23日
    000
  • 响应式设计中媒体查询与伪元素样式冲突的解决方案

    在响应式网页设计中,开发者常常需要为不同屏幕尺寸(如桌面、平板和手机)提供定制化的用户体验。媒体查询(media queries)是实现这一目标的关键技术。然而,当采用多个外部样式表并利用`max-width`媒体查询来加载这些样式时,可能会遇到一个常见且令人困惑的问题:某些元素的样式,特别是伪元素…

    2025年12月23日
    000
  • html5怎么安装后台登录_HTML5管理界面搭建与认证实现

    答案:使用HTML5构建前端界面,结合Node.js等后端技术实现登录认证。通过HTML5搭建登录页面,利用JavaScript发送请求至后端接口;后端采用Express框架处理用户验证,使用session管理登录状态,并返回响应;前端根据结果跳转到管理页。需注意密码加密、HTTPS传输、防XSS/…

    2025年12月23日
    000
  • HTML5网页如何实现背景模糊 HTML5网页毛玻璃效果的制作技巧

    实现背景模糊效果主要依赖CSS3的backdrop-filter属性,而非HTML5功能。通过设置backdrop-filter: blur(10px)可使元素背后内容呈现毛玻璃效果,常用于模态框、导航栏等场景。配合rgba半透明背景和边框,能增强层次感。需注意添加-webkit-backdrop-…

    2025年12月23日
    000
  • 使用JavaScript和单选按钮实现网页内容动态显示与隐藏

    本教程将详细讲解如何利用javascript和html单选按钮实现网页内容的动态显示与隐藏。通过监听单选按钮的点击事件,我们可以精确控制不同区域的可见性,从而在无需提交表单的情况下,为用户提供流畅的交互体验。 在网页开发中,我们经常需要根据用户的选择动态地展示或隐藏不同的内容区域,以提供更具交互性的…

    2025年12月23日
    000
  • 优化网页导航链接:避免相对路径导致重复重定向

    本文旨在解决网页导航栏中因相对路径设置不当导致的重复重定向问题。通过深入探讨相对路径与绝对路径的区别,并提供具体的html代码示例,指导开发者如何正确配置导航链接,确保用户在网站任何页面都能准确无误地跳转到目标页面,提升用户体验和网站的导航稳定性。 网页导航链接的常见问题解析 在构建多页面网站时,许…

    2025年12月23日
    000
  • HTML列表有哪几种类型_HTML无序有序列表ULOL应用

    无序列表(ul)用于并列项目,以圆点等符号标记,适用于导航菜单、功能罗列;有序列表(ol)带数字前缀,用于步骤、排名等有顺序的内容;两者通过CSS可自定义样式,如修改符号类型或起始编号,合理使用提升网页结构清晰度与可读性。 HTML列表主要有三种类型:无序列表、有序列表和定义列表。它们用于组织内容,…

    2025年12月23日
    000
  • 利用部分HTML注释在noscript中实现内容条件显示与隐藏

    当JavaScript被禁用时,开发者常面临如何隐藏或显示特定内容的挑战,尤其是在支持文本浏览器的场景。本文将深入探讨一种利用` `标签结合部分HTML注释的可靠技术,该方法通过巧妙利用HTML解析器的行为差异,确保内容在JavaScript启用时显示,禁用时隐藏,并依据HTML5规范详细解析其工作…

    2025年12月23日
    000
  • HTML表格基本结构组成部分有哪些_HTML表格核心结构元素分析

    HTML表格基本结构由、、、、、和组成,用于定义表格容器、表头、主体、页脚、行及单元格,提升语义性与可访问性。 HTML表格的基本结构由多个核心元素组成,这些元素共同协作,用来组织和展示数据。理解这些组成部分有助于构建语义清晰、结构合理的表格。 1. :表格的容器 每个HTML表格都以标签开始,它是…

    2025年12月23日
    000
  • 使用 MultiClamp 实现文本块的折叠与展开功能

    本文详细介绍了如何利用 `multiclamp` 库在网页中实现文本内容的折叠与展开功能。通过初始化 `multiclamp` 实例对文本进行多行截断,并结合其 `reload` 方法,实现点击“阅读更多”按钮或文本块本身时,动态地将折叠文本完全展开,从而提升用户体验和页面布局的灵活性。 引言 在现…

    2025年12月23日
    000
  • html5怎么发布_HTML5应用打包与各平台发布流程

    HTML5应用需通过Cordova或Capacitor打包为原生应用,或以PWA形式发布。1. 使用Cordova/Capacitor将HTML项目封装,配置平台信息并生成原生工程;2. Android平台通过Google Play Console上传AAB文件发布;3. iOS平台需在Mac环境下…

    2025年12月23日
    000
  • HTML Canvas图像绘制教程:解决图片加载与绘制常见问题

    本教程旨在解决在html canvas上绘制上传图片时常见的语法和异步加载问题。文章将详细解释`canvasrenderingcontext2d.drawimage()`方法的正确用法,强调图像加载的异步性,并提供一个完整的、健壮的代码示例,确保图片在加载完成后能正确且平滑地显示在canvas上,帮…

    2025年12月23日
    000
  • 利用CSS Flexbox实现元素垂直与水平居中对齐

    本文详细阐述了如何运用css flexbox布局,高效地实现子元素在父容器中的垂直与水平双向居中对齐。通过具体示例,我们将深入解析`display: flex`、`flex-direction`、`justify-content`和`align-items`等核心flexbox属性,助您轻松掌握现代…

    2025年12月23日
    000
  • 使用 Django 创建 Wiki 页面时保存新条目问题的解决

    本文旨在解决在使用 Django 构建 Wiki 页面时,遇到的无法保存新条目的问题。主要围绕 `views.py` 中处理 POST 请求的逻辑展开,并提供示例代码,阐述如何正确处理表单数据,以及如何利用 Django 的表单功能进行数据验证和保存,同时提供一些优化建议,帮助开发者构建更健壮的 W…

    2025年12月23日
    000
  • HTML网页字符编码怎么设置_HTMLmeta标签charset属性讲解

    正确设置HTML字符编码可解决网页乱码问题,需在head中添加meta标签指定charset,如UTF-8支持多语言,应确保文件实际编码与meta声明一致,推荐统一使用UTF-8并用编辑器验证编码格式。 如果您在浏览网页时遇到乱码问题,可能是由于浏览器未能正确识别网页的字符编码。HTML中的meta…

    2025年12月23日
    000
  • HTML5代码如何实现剪切板操作 HTML5代码中Clipboard API的用法

    HTML5 Clipboard API需用户手势触发,通过navigator.permissions查询权限;2. 使用writeText()和readText()实现复制粘贴;3. 必须在HTTPS环境下运行,注意错误处理与兼容性。 HTML5中的Clipboard API允许网页读写系统剪贴板,…

    2025年12月23日
    000
  • Angular响应式表单中复选框的绑定与状态管理

    本文深入探讨了在Angular响应式表单中有效管理复选框状态的方法。通过 `FormGroup` 和 `FormControl`,结合外部数据(如JSON中的”enabled”/”disabled”字符串),演示了如何将复选框绑定到布尔值,并实现数据的…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信