0

0

优化PHP循环中嵌入的JavaScript代码:避免重复

DDD

DDD

发布时间:2025-08-31 22:21:01

|

359人浏览过

|

来源于php中文网

原创

优化php循环中嵌入的javascript代码:避免重复

本文旨在解决在PHP循环中嵌入大量重复JavaScript代码的问题。通过使用事件委托、类选择器和事件目标等技术,可以将JavaScript函数定义一次,并在循环生成的每个元素上复用,从而提高代码的可维护性和性能。本文将提供详细的步骤和示例代码,帮助你优化现有的代码结构,使其更加简洁高效。

优化循环内嵌JavaScript代码

在PHP循环中直接嵌入JavaScript代码,特别是当循环次数较多时,会导致大量的代码重复,降低代码的可读性和维护性。以下介绍一种更优雅的方法来解决这个问题,核心思想是将事件监听器绑定到父元素,并利用事件委托机制来处理子元素的事件。

1. 使用类选择器替代ID选择器

在循环中生成HTML元素时,避免使用唯一的ID,而是使用类选择器。这样可以方便地选中所有需要绑定事件的元素。

例如,将:

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

修改为:

2. 利用事件委托绑定事件监听器

将事件监听器绑定到表格或其父元素上,而不是每个单独的元素。当子元素触发事件时,事件会冒泡到父元素,父元素根据事件目标(event.target)来判断是哪个子元素触发的事件,并执行相应的操作。

document.getElementById("mySEARCH").addEventListener("keyup", function(event) {
  if (event.target && event.target.classList.contains("item-brand")) {
    // 获取当前行的ID
    const row = event.target.closest("tr");
    const itemId = row.id.replace("line", "");

    // 获取当前输入框的值
    const brand = event.target.value;

    // 执行保存操作
    editSave(itemId, brand);
  }
});

在这个例子中,我们监听了mySEARCH表格的keyup事件。当event.target(即触发事件的元素)包含item-brand类时,我们才执行相应的操作。event.target.closest("tr")用于查找最近的

父元素,然后提取行的ID,并调用editSave函数。

3. 统一JavaScript函数定义

将JavaScript函数定义在循环外部,并修改函数以接受参数,从而实现对不同元素的处理。

Lumen5
Lumen5

一个在线视频创建平台,AI将博客文章转换成视频

下载

例如,将:

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

function editSave(){
  var id = ;
  var brand = $("#brand").val();
  var itemKind = $("#item-kind").val();
  $.post("calculate.php", { save: id, brand: brand, itemkind: itemKind },
  function(data) {
    $('#edit-confirm').html(data);
  });
}

修改为:

function editSave(itemId, brand, itemKind) {
  var id = itemId;
  var brand = brand;
  var itemKind = itemKind;
  $.post("calculate.php", { save: id, brand: brand, itemkind: itemKind },
  function(data) {
    $('#edit-confirm').html(data);
  });
}

4. 修改PHP代码

修改PHP代码,移除循环中嵌入的JavaScript代码,并添加必要的类和数据属性。

prepare("SELECT * FROM `$list`");
  $stmt->execute();
  $x = 0;
  foreach($stmt as $item)
  { $x++;?>
    
    
     
Keine Items vorhanden

5. 完整的JavaScript代码示例

document.addEventListener("DOMContentLoaded", function() {
  const table = document.getElementById("mySEARCH");

  // 事件委托:品牌修改
  table.addEventListener("keyup", function(event) {
    if (event.target && event.target.classList.contains("item-brand")) {
      const row = event.target.closest("tr");
      const itemId = row.dataset.itemId; // 使用 data-item-id
      const brand = event.target.value;
      const itemKind = row.querySelector(".item-kind").value; // 获取 itemKind

      editSave(itemId, brand, itemKind);
    }
  });

  // 事件委托:种类修改
  table.addEventListener("change", function(event) {
    if (event.target && event.target.classList.contains("item-kind")) {
      const row = event.target.closest("tr");
      const itemId = row.dataset.itemId; // 使用 data-item-id
      const brand = row.querySelector(".item-brand").value; // 获取 brand
      const itemKind = event.target.value;

      editSave(itemId, brand, itemKind);
    }
  });

  // 事件委托:隐藏/显示行
  table.addEventListener("click", function(event) {
    if (event.target && event.target.classList.contains("activ")) {
      const row = event.target.closest("tr");
      const itemId = row.dataset.itemId;
      const line = row;
      const brand = row.querySelector(".item-brand");
      const itemKind = row.querySelector(".item-kind");
      const btnLocked = row.querySelector(".btn-list");
      const btnImage = row.querySelector(".visibility");

      if (line.style.opacity === "1") {
        line.style.opacity = "0.1";
        brand.setAttribute("readonly", "");
        itemKind.setAttribute("disabled", "");
        btnLocked.setAttribute("disabled", "");
        btnImage.setAttribute("src", "images/icon-visible.png");
      } else {
        line.style.opacity = "1";
        brand.removeAttribute("readonly");
        itemKind.removeAttribute("disabled");
        btnLocked.removeAttribute("disabled");
        btnImage.setAttribute("src", "images/icon-invisible.png");
      }
    }
  });

  function editSave(itemId, brand, itemKind) {
    $.post("calculate.php", { save: itemId, brand: brand, itemkind: itemKind }, function(data) {
      $('#edit-confirm').html(data);
    });
  }
});

注意事项:

  • 确保在DOM加载完成后绑定事件监听器,可以使用document.addEventListener("DOMContentLoaded", function() { ... });。
  • 使用data-*属性来存储每个元素的ID,例如,然后在JavaScript中使用element.dataset.itemId来访问。
  • 根据实际情况调整选择器和事件类型。
  • 总结:

    通过使用事件委托、类选择器和统一的JavaScript函数,可以有效地减少PHP循环中嵌入的重复JavaScript代码,提高代码的可维护性和性能。这种方法使得代码结构更加清晰,易于理解和修改。

    优化PHP循环中嵌入的JavaScript代码:避免重复优化PHP循环中嵌入的JavaScript代码:避免重复

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2690

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1663

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1525

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

953

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1509

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

0

2026.01.20

热门下载

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

精品课程

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

共137课时 | 8.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 8.5万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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