0

0

修复矩阵计算器中函数执行一次后失效的问题

花韻仙語

花韻仙語

发布时间:2026-01-29 12:25:01

|

653人浏览过

|

来源于php中文网

原创

修复矩阵计算器中函数执行一次后失效的问题 - php中文网

本文详解为何矩阵加减法函数在首次调用后失效,并指出根本原因是变量名与函数名冲突导致函数被意外覆盖,提供清晰的修复方案与最佳实践。

在您提供的矩阵计算器代码中,add() 和 sub() 函数在第一次点击按钮后能正常运行,但后续点击却报错(如 add is not a function 或直接无响应)。问题并非出在 this 关键字使用不当,而是一个更基础却极易被忽视的 JavaScript 命名冲突问题。

核心原因在于以下两行代码:

add = parseInt(this[x]) + parseInt(this[y]); // ❌ 覆盖了全局函数 add
sub = parseInt(this[x]) - parseInt(this[y]); // ❌ 覆盖了全局函数 sub

当 JavaScript 执行到 add = ... 时,由于未使用 let、const 或 var 声明,引擎会在全局作用域window)中隐式创建一个同名变量 add,其值为一个数字。这直接覆盖了原本定义的 function add() —— 此后 add 不再是函数,而是一个数值,因此再次点击 + 按钮时,onclick="add()" 就会尝试调用一个数字,导致运行时错误或静默失败。

同样,sub 函数也在 sub() 内部被同名赋值覆盖,造成相同后果。

PicWish
PicWish

推荐!专业的AI抠图修图,支持格式转化

下载

✅ 正确做法是:为计算结果使用语义清晰且不与函数名冲突的局部变量名。推荐使用 let 显式声明块级变量:

function add() {
    o.textContent = ''; // 清空输出区(注意:textContent 比 innerHTML 更安全)
    const t = r * c; // 重新计算当前行列数下的总元素数,避免依赖旧 t
    for (let i = 1; i <= t; i++) {
        const aVal = parseInt(document.getElementById("a" + i).value) || 0;
        const bVal = parseInt(document.getElementById("b" + i).value) || 0;
        const result = aVal + bVal; // ✅ 使用独立变量名 result
        o.innerHTML += ``;
    }
}

function sub() {
    o.textContent = '';
    const t = r * c;
    for (let i = 1; i <= t; i++) {
        const aVal = parseInt(document.getElementById("a" + i).value) || 0;
        const bVal = parseInt(document.getElementById("b" + i).value) || 0;
        const result = aVal - bVal; // ✅ 同样使用 result
        o.innerHTML += ``;
    }
}

? 其他关键优化建议:

  • 避免 innerHTML += 频繁拼接:每次拼接都会触发 DOM 重排,性能差且易引入 XSS 风险(若输入含恶意 HTML)。推荐先构建字符串或使用 DocumentFragment。
  • 添加输入校验与默认值:parseInt(...) 可能返回 NaN,应使用 || 0 提供兜底。
  • 使用 readonly 属性:输出框应禁止用户编辑,提升体验。
  • 动态生成 input 时注意 ID 唯一性:当前 reg() 函数在行列变化时重复添加 input,但未清理旧元素,可能导致 ID 冲突(如多个 a1)。应在 reg() 开头清空容器:p1.innerHTML = ''。
  • 启用严格模式:在

? 总结:函数名是宝贵的标识符资源,切勿用作临时变量名。坚持「函数名描述行为,变量名描述数据」的原则,并始终使用 let/const 显式声明变量,即可彻底规避此类“执行一次就失效”的陷阱。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

287

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

258

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

124

2025.08.07

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

78

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

96

2025.09.18

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

15

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号