- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
作为一个狂热的浏览器(但从未发布过),我首先要说的是,提前感谢您的任何见解。
我正在为我的雇主代码部门制作一个页面,该部门需要使用动态下拉菜单,因为每页的下拉菜单数量会有所不同。
上下文:
最初我们使用的是标准的 Bootstrap 下拉菜单,但我们的客户处理的一些 Web 提供商没有在 Bootstrap 中加载。我最初的想法是侧面加载它,但是,我们正在开发必须适用于我们所有客户及其所有 Web 提供商的模板。长话短说,bootstrap CSS 文件会覆盖各种未考虑 bootstrap 的网站,存在稳定性问题。
关于问题:
这是我的 CodePen供您查看。
dropdown = () => {
const dropdown = document.getElementsByClassName("dropdown");
for (let i = 0; i < dropdown.length; i++) {
const activeDropdown = dropdown[i].id,
down = "#downChev-" + activeDropdown,
up = "#upChev-" + activeDropdown,
downIcon = document.querySelector(down),
upIcon = document.querySelector(up),
dropdownNumID = "#" + activeDropdown,
dropdownID = "#dropdown-" + activeDropdown;
if (event.target.matches(dropdownNumID)) {
if (upIcon.classList.contains("show-icon")) {
upIcon.classList.remove("show-icon");
downIcon.classList.add("show-icon");
} else if (downIcon.classList.contains("show-icon")) {
downIcon.classList.remove("show-icon");
upIcon.classList.add("show-icon");
}
document.querySelector(dropdownID).classList.toggle("dropdown-show")
}
}
}
目前,我已经构建了一个动态下拉系统,该系统利用每个下拉列表的特定 ID。问题在于,在通过下拉菜单创建支持变量的第一个循环中,它不会创建 activeDropdown 变量,而是在记录时返回一个空白变量。
我已经在多种情况下进行了故障排除,并得出以下结论:
我不确定我的执行逻辑是否错误,或者我是否将整个事情复杂化了。这里唯一真正的目标是创建一个动态结构,允许我的前端开发团队随意添加或删除模型 div,随着列表的增长对 ID 进行简单修改。
我们无权访问的其他脚本也可能在实时站点上造成问题。不过,我想你们会发现我的代码有问题的,哈哈。
最佳答案
很难知道发生了什么,因为您的生产环境可能与代码笔有很大不同,但我认为可能会发生一些事情。
1) 可能是 JavaScript 在整个页面加载之前运行。确保与 CodePen 等效的 JavaScript 代码最后加载到页面上。 (即将 <script></script>
标记放在文档的最后)。
2) 某些变量可能会发生冲突,因为您是在全局范围内将 JavaScript 直接加载到文档正文中。我有一些一般的文体建议可以帮助您解决问题:
通过查看您的 CodePen,您正在使用两种不同的方法来对点击事件使用react:您已经设置了一个事件监听器,并在 window.onclick
上进行了回调。 ,以及 2) 一个名为 dropdown
的函数您附加到 onclick
HTML 中的属性。
我建议远离内联 onclick
属性,而是将事件监听器添加到下拉列表的容器中。这样您的标记就不会与下拉 JS 耦合,并且您正在收听该容器内的点击,而不是整个应用程序。您可以使用相同的事件监听器来打开下拉菜单和关闭下拉菜单。 See this stackoverflow post for more information about this .
此外,我建议在您的代码周围添加一个包装函数,以防止您污染全局范围。该函数可以在页面加载时立即调用,并将在容器上添加事件监听器。 You can read more about IIFE's here.
这里是CodePen证明这两个建议。虽然我不知道这是否能帮助您解决问题,但希望您至少能学到一些新东西!
关于javascript - 本地主机上的循环变量设置,而不是实时站点上的循环变量设置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57099468/
最近我用 php 建立了一个网站,但他们的旧网站都是 HTML 格式的。所以现在我不知道使用 .htaccess 将所有这些旧链接重定向到新站点(可能将所有带有 HTML 的链接重定向到主域)的最佳方
我创建了一个新的 WordPress 网站,它是我旧网站的更名版本。它有一个新的域和一个新的设计。除此之外,其他一切都是相同的,包括内容和链接结构。现在我想完全重定向旧链接。与旧帖子一样,标签和类别
我想使用 WatiN测试我正在开发的网站的功能。理想情况下,我会在测试开始运行之前以编程方式部署网站 (asp.net MVC3),然后在每次测试之前刷新数据。这可能吗? 最佳答案 在此处阅读有关使用
我们的网站使用我们自己定制的 session 状态管理,与 ASP.NET session 状态分开。但是由于少数特殊页面使用 SQL Server Reporting Services,我们还需要启
不久前我看到一个网站,其中有 JavaScript/HTML/CSS 栏目,下面有实际代码的样子。有点像 jsFiddle,但它有用户示例和演示。有谁知道这个网站的名字吗?我到处都找不到它!谢谢! 最
我们的核心数据库出现问题,该数据库已由前一天的备份数据库恢复。 此后,网站工作正常,但我们在发布任何更改时遇到问题。一旦点击发布按钮,“发布正在初始化..”消息就会持续很长时间。截至“发布开始/结束”
我们的核心数据库出现问题,该数据库已由前一天的备份数据库恢复。 此后,网站工作正常,但我们在发布任何更改时遇到问题。一旦点击发布按钮,“发布正在初始化..”消息就会持续很长时间。截至“发布开始/结束”
Maven 不仅仅是一款项目构建和依赖管理工具,它还能够聚合项目信息,促进项目团队间地交流。POM 中可以包含各种项目信息,例如:项目描述、SCM 地址、许可证信息,开发者信息等。用户可以使用 Mav
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭上个月。 Improve this ques
您知道哪些网站正在使用 Silverlight?此信息将帮助我们决定何时采用 Silverlight 平台。 这些网站应该是面向公众的并且被认为是高流量的。 (每月至少 300,000 次点击)。 我
我尝试通过 VS2017 中的发布上下文菜单将我的 .net 核心站点部署到 Azure,偶尔(大约三分之一的部署),我收到以下错误。 Web deployment task failed. (Web
我为 20 个不同的国家/地区创建了一个包含 20 个站点(每个站点一个不同的域)的 Django 项目。这些站点共享所有内容:代码库、数据库、网址、模板等。 他们唯一不共享的是我在每个站点设置文件中
如何将商店页面添加到我使用 jekyll 和基础构建的网站? 任何自动化平台/方法都可以做到这一点。 谢谢。 最佳答案 您可以使用 snipcart .有一个blog post和一个 demo sit
我部署了一个服务结构集群,域为 foo.northcentralus.cloudapp.azure.com 它具有单一节点类型和单一公共(public) IP 地址/负载均衡器。 假设我部署了以下
我不是一个大的typ3 专家,也无法访问我正在使用的typ3 实例中的typoscript 选项(这是一个非常大的站点,我没有这样做的授权)。所以我希望这个问题适合 stackoverflow(如果没
我们正在对我们的 Drupal 站点进行性能调整。 我们正在使用 Siege 来衡量性能(作为 drupal 访问者)。 环境: Nginx + FastCGI + Memcache Siege 运行
我搜索了 SO、SU 和 SP.SE寻求解决方案,但找不到我需要的东西。我正在寻找一个解决方案,它可能是一个脚本或一些其他非编码方法/工具。 我正在尝试编写一个脚本(供其他人使用)或某种其他形式的自动
我有一个 Django 站点,它使用本地化中间件与 gettext 和 trans/blocktrans 模板标签相结合,根据用户代理字符串中的首选语言向访问者显示不同的页面(这似乎是在 Django
我是 Drupal 新手。是否可以设置所有内容并在服务器上部署 Drupal?我的意思是像放入内容、设置模块等...,然后将它们全部放到生产服务器上? 最佳答案 当然。 复制所有文件 编辑数据库凭证(
我想将以下行添加到我的 head.html仅在运行时 jekyll serve本地: 如果可能的话,我正在考虑使用一些简单的液体检查。 最佳答案 当你做 jekyll serve本地默认 {{
我是一名优秀的程序员,十分优秀!