使用 JavaScript 动态创建正方形网格

使用 javascript 动态创建正方形网格

本文旨在解决 JavaScript 代码无法在网页父容器中创建正方形块的问题。我们将深入探讨问题的根源,包括样式属性的误用和变量作用域的理解,并提供修复后的代码示例,助你掌握使用 JavaScript 动态生成网页元素的方法,并避免常见的错误。

样式属性的正确使用

初学者在使用 JavaScript 操作 CSS 样式时,容易混淆属性名称。在这个例子中,问题在于尝试使用 color 属性来改变正方形的背景颜色。color 属性专门用于设置文本颜色,而要改变背景颜色,应该使用 backgroundColor 属性。

以下是正确的代码示例:

newChild.style.backgroundColor = "#f389ca";newChild.addEventListener("mouseover", function(){    newChild.style.backgroundColor = "#8e2db8";});newChild.addEventListener("mouseout", function(){    newChild.style.backgroundColor = "#f389ca";});

变量作用域与 var 的陷阱

另一个关键问题在于 var 关键字的使用。在 JavaScript 中,var 声明的变量具有函数作用域或全局作用域,而 let 和 const 声明的变量具有块级作用域。在循环中使用 var 时,容易出现变量提升(hoisting)和闭包问题,导致事件监听器绑定到同一个变量上,而不是每个正方形各自的变量。

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

下面的代码展示了使用 let 修复后的示例,确保每个事件监听器都绑定到正确的正方形元素:

const parentDiv = document.querySelector(".parent-div");for (let i = 0; i < 10; i++) {    const childDiv = document.createElement("div");    childDiv.style.display = "flex";    childDiv.style.flex = "1";    for (let k = 0; k < 10; k++) {        const newChild = document.createElement("div");        newChild.style.flex = "1";        newChild.style.height = "48px";        newChild.style.width = "48px";        newChild.style.border = "2px black solid";        newChild.style.backgroundColor = "#f389ca"; // Corrected property        newChild.addEventListener("mouseover", function(){            newChild.style.backgroundColor = "#8e2db8"; // Corrected property        });        newChild.addEventListener("mouseout", function(){            newChild.style.backgroundColor = "#f389ca"; // Corrected property        });        childDiv.appendChild(newChild);    }    parentDiv.appendChild(childDiv);}

代码解释:

飞书多维表格 飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

飞书多维表格 26 查看详情 飞书多维表格 const parentDiv = document.querySelector(“.parent-div”);: 获取 HTML 中类名为 “parent-div” 的父容器。for (let i = 0; i < 10; i++) { … }: 外层循环创建 10 行。使用 let 声明循环变量 i。const childDiv = document.createElement(“div”);: 创建每一行的容器 div。childDiv.style.display = “flex”; childDiv.style.flex = “1”;: 设置行容器的 Flexbox 布局,使其子元素水平排列for (let k = 0; k < 10; k++) { … }: 内层循环在每一行中创建 10 个正方形。使用 let 声明循环变量 k。const newChild = document.createElement(“div”);: 创建正方形 div 元素。newChild.style.flex = “1”; newChild.style.height = “48px”; newChild.style.width = “48px”; newChild.style.border = “2px black solid”; newChild.style.backgroundColor = “#f389ca”;: 设置正方形的 Flexbox 属性、高度、宽度、边框和背景颜色。newChild.addEventListener(“mouseover”, function(){ … }); newChild.addEventListener(“mouseout”, function(){ … });: 为每个正方形添加鼠标悬停和移开事件监听器,改变背景颜色。childDiv.appendChild(newChild);: 将正方形添加到行容器中。parentDiv.appendChild(childDiv);: 将行容器添加到父容器中。

确保脚本在 DOM 加载完成后执行

如果 JavaScript 代码在 HTML 元素加载之前执行,document.querySelector(“.parent-div”) 可能无法找到父容器,导致代码无法正常工作。

解决方法有两种:

将 标签放在 标签之前,确保 HTML 元素已经加载完毕。

使用 DOMContentLoaded 事件监听器,在 DOM 加载完成后执行 JavaScript 代码:

document.addEventListener("DOMContentLoaded", function() {    // Your JavaScript code here    const parentDiv = document.querySelector(".parent-div");    // ... rest of your code});

总结

动态创建网页元素是 Web 开发中的常见任务。理解 CSS 属性的正确用法、变量作用域以及 DOM 加载时机至关重要。 通过本文的讲解和示例代码,你现在应该能够使用 JavaScript 动态创建正方形网格,并避免常见的错误。记住,使用 backgroundColor 设置背景颜色,使用 let 或 const 声明块级作用域的变量,并确保脚本在 DOM 加载完成后执行。

以上就是使用 JavaScript 动态创建正方形网格的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 22:28:33
下一篇 2025年11月4日 22:29:58

相关推荐

  • BTC近期价格预测分析_BTC短期会涨吗

    一键直达|2025主流加密资产交易所平台 Binance币安 Huobi火币 欧易OKX BTC近期价格预测分析——2025年短期走势展望 比特币(BTC)作为全球加密资产的风向标,其短期走势受到宏观经济、政策预期、市场情绪和技术面等多重因素影响。以下从多个角度分析BTC是否具备短期上涨动能,为投资…

    2025年12月8日
    000
  • 狗狗币为什么被称为“ meme 币”?有什么故事?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 狗狗币,这个在加密货币世界中独树一帜的存在,常常被冠以“ meme 币”的称号。与许多追求尖端技术或解决实际问题的加密货币不同,狗狗币的起源和发展与一种特定的互联网…

    2025年12月8日
    000
  • 狗狗币的创始人是谁?为什么后来退出了?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 狗狗币,一种以柴犬为标志的数字货币,其诞生源于互联网文化中的一个流行迷因(meme)。与许多追求技术革新或金融颠覆的加密货币不同,狗狗币在2013年底被创造出来时,…

    2025年12月8日
    000
  • 购买山寨币需要什么

    进入山寨币的交易领域,其操作方式与在中心化平台上购买主流加密资产存在显著差异。大部分山寨币,特别是早期项目,通常不会在大型、知名的交易平台上线。它们的流通主要依赖于去中心化交易协议(DEX)。这就… 进入山寨币的交易领域,其操作方式与在中心化平台上购买主流加密资产存在显著差异。大部分山寨…

    2025年12月8日
    000
  • 哪个交易所可以买山寨币 山寨币交易平台推荐

    哪个交易所可以买山寨币 山寨币交易平台推荐。除了比特币、以太坊等主流加密货币,还存在着成千上万种被称为“山寨币”或“另类币”的资产。这些项目通常具有特定的应用场景、社区文化或是技术创新点,吸引了大量寻求多… 哪个交易所可以买山寨币 山寨币交易平台推荐 在数字资产的世界里,除了比特币、以太…

    2025年12月8日
    000
  • 币圈七月可能出现的空投有哪些

    七月空投项目包括LayerZero生态、Zora Network和Linea主网。LayerZero的交互步骤:1.准备Arbitrum或Optimism上的ETH;2.访问Stargate Finance;3.连接钱宝并选择源链和目标链;4.选择资产进行跨链操作;问题处理方法包括追踪交易哈希和选择…

    2025年12月8日
    000
  • CMC山寨币季节指数有什么用

    CMC山寨币季节指数用于衡量主流山寨币相对于比特币的市场表现,帮助判断当前是“比特币季节”还是“山寨币季节”。该指数基于市值排名前50的山寨币(不含比特币、稳定币和资产支持型代币)在过去90天的表现,当75%以上的山寨币跑赢比特币时,指数进入“山寨币季节”(高于75),反之则为“比特币季节”(低于2…

    2025年12月8日
    000
  • 2025合规SAHARA交易所TOP10

    一键直达|2025主流加密资产交易所平台 Binance币安 Huobi火币 欧易OKX 2025年合规SAHARA交易所TOP10——全球最具监管资质的平台评选 随着全球对数字资产监管逐步明晰,合规性已成为衡量交易所可信度与可持续性的核心指标。对于SAHARA等新兴资产而言,选择合规交易所,不仅保…

    2025年12月8日
    000
  • 比特币有什么价值?比特币为什么值钱?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 比特币是一种数字加密货币。它在诞生初期可能不为人知,但随着时间的推移,其在全球范围内的认知度不断提高。人们开始关注它独特的属性以及它所代表的一种新型资产类别。理解比…

    2025年12月8日
    000
  • ERC-721和ERC-1155有什么区别?一文搞懂两者区别

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: ERC-721 标准和 ERC-1155 标准都是在以太坊区块链上用于创建代币的技术规范。尽管它们都与代币相关,但它们的设计理念和功能存在显著差异,使其适用于不同的…

    2025年12月8日
    000
  • 如何通过OKX邀请码加入合伙人计划

    okx合伙人计划为推广okx平台的用户提供了合作机会。通过该计划,合伙人可以邀请新用户加入okx,并从被邀请用户的交易中获得返佣。利用邀请码是加入这一计划的一种特定途径,通常意味着您可能已经被现有合伙人推荐,或者符合通过特定渠道申请的条件。 了解 OKX 合伙人计划 OKX 合伙人计划旨在邀请个体或…

    2025年12月8日
    000
  • 2025年交易量前十交易所安全性评估 前十交易所安全性排行榜

    数字资产交易平台在全球金融市场中扮演着至关重要的角色,它们是连接用户与快速发展的区块链世界的关键基础设施。随着行业规模的不断扩大,平台所承载的资产价值日益攀升,其安全性成为用户、监管机构乃至整个生态系统关注的焦点。一个平台的安全性不仅仅关乎用户资产的保护,更影响着市场的稳定与信心。对各大交易平台安全…

    2025年12月8日 好文分享
    000
  • 币安手续费怎么算-币安现货交易与合约手续费分别是多少

    币安交易手续费分为Maker和Taker两种类型,现货交易基础费率为0.1%,使用BNB支付可享25%折扣;合约交易费率更低,U本位合约基础费率为Maker 0.02%、Taker 0.05%,使用BNB可享10%折扣。用户可通过设置限价单成为Maker以降低费用;启用BNB支付需在账户中开启相应功…

    2025年12月8日
    000
  • 鲍威尔主席7月1日讲话对比特币有可能造成的影响分析

    鲍威尔7月1日讲话可能对比特币产生显著影响。若其言论偏向鹰派,强调高通胀和维持高利率,则会因流动性收紧预期而压制比特币价格;若透露经济衰退风险,则市场对其避险属性的解读将分化,部分投资者抛售,另一些则视其为对冲工具;讲话发布后,比特币价格通常因市场即时解读而剧烈波动,鸽派信号可能拉升价格,鹰派则导致…

    2025年12月8日
    000
  • 鸿蒙系统怎么安装欧亿(OKX交易所)

    鸿蒙系统安装欧亿(OKX)的方法如下:1. 打开浏览器访问欧亿官网并下载APK文件;2. 在设置中开启浏览器“允许安装未知应用”权限;3. 点击APK文件完成安装。若遇到下载失败、解析错误或闪退问题,可切换网络、清理缓存、重新下载、检查存储空间及系统版本兼容性,并通过官网更新应用版本以确保正常使用。…

    2025年12月8日
    000
  • 安卓手机对币安app安装一般有些什么样的问题(附解决方法)

    安卓用户安装币安App常见问题的解决方案如下:1.找不到下载渠道时,应访问币安官网(binance.com)下载APK安装包,并避免通过其他来源获取;2.无法安装或被系统拦截时,需进入手机设置-应用-权限管理-安装未知应用,为浏览器开启安装权限;3.安装时报错“解析包错误”等问题时,可能因安装包损坏…

    2025年12月8日
    000
  • 随着ADA浸入和avax的眼睛增益,BDAG空投会加热:什么是嗡嗡声?

    blockdag斥资1亿美元的空投活动引发热议,cardano承受下行压力,而avalanche则展现出反弹迹象。bdag是否是当前加密货币市场的首选投资标的? 加密市场总是风云变幻,眼下,所有人的焦点都集中在Blockdag的大手笔空投上。与此同时,ADA和AVAX似乎正酝酿着新一轮动作。让我们来…

    2025年12月8日
    000
  • 银币,官方语言,黄金年:印度的纪念致敬

    印度以其独特的官方语言致敬方式引发关注,2025年特别推出一枚价值50卢比的银币,以此纪念官方语言部门迎来“黄金年”。 印度以一枚精美的限量版50卢比银币庆祝其语言文化遗产!这款硬币专为2025年官方语言部门“黄金年”打造,融合了钱币美学与文化象征。 一枚讲述故事的硬币 该枚重达40克的硬币依据20…

    2025年12月8日
    000
  • Solana(Sol)价格:导航抵抗和支撑水平

    索拉纳的价格随市场波动而起伏。关键支撑位与阻力位的动态为投资者提供了重要参考。让我们一起来分析solana的价格走势! Solana(SOL)价格:识别支撑与阻力区域 Solana(SOL)近期经历了较大的价格波动。本文将概述其关键价格变动、阻力与支撑水平,以及生态系统中的新进展。 Solana价格…

    2025年12月8日
    000
  • 做空狗狗币爆仓了怎么办?如何减少损失?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 做空狗狗币遭遇爆仓是一个令人沮丧的经历。在这种情况下,关注的核心是如何处理当前的局面,并尽量控制可能产生的进一步影响。爆仓意味着您的保证金不足以维持仓位,交易平台已…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信