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免费学习笔记(深入)”;

<input type='text' id="brand<?php echo $x;?>" class="brand-list" name='brand' value="<?php echo $item['brand']?>" onkeyup="editSave<?php echo $x;?>(), success()">

修改为:

<input type='text' class="brand-list item-brand" name='brand' value="<?php echo $item['brand']?>">

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")用于查找最近的zuojiankuohaophpcntr>父元素,然后提取行的ID,并调用editSave函数。

3. 统一JavaScript函数定义

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

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载

例如,将:

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

function editSave<?php echo $x;?>(){
  var id = <?php echo $item['id']?>;
  var brand = $("#brand<?php echo $x;?>").val();
  var itemKind = $("#item-kind<?php echo $x;?>").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代码,并添加必要的类和数据属性。

<?php
if(isset($_COOKIE['shoppinglist'])){
  $list = $_COOKIE['shoppinglist'];
  $stmt = $pdo->prepare("SELECT * FROM `$list`");
  $stmt->execute();
  $x = 0;
  foreach($stmt as $item)
  { $x++;?>
    <tr id="line<?php echo $x;?>" style="opacity: 1.0;" data-item-id="<?php echo $item['id']; ?>">
    <td><button class="btn-hide-row activ" data-line="<?php echo $x;?>"><img class="list-icon visibility" src="images/icon-invisible.png" /></button></td>
     <form action='calculate.php' method='post'>
     <td class="pcs-unit-list"><?php echo $item['pieces']." ".$item['unit']?></td>
     <td name='item' class="shop-list-item" id="item"><?php echo $item['item']?></td>
     <td class="brand-list"><input type='text' class="brand-list item-brand" name='brand' value="<?php echo $item['brand']?>"></td>
     <td class="kind-list"><select class="shoppinglist-kind item-kind" name='item-kind'>
       <option value=""></option>
       <option value="Gemüse" <?php if($item['kind'] == "Gemüse") echo "selected"?>>Gemüse</option>
       <option value="Obst" <?php if($item['kind'] == "Obst") echo "selected"?>>Obst</option>
       <option value="Fleisch" <?php if($item['kind'] == "Fleisch") echo "selected"?>>Fleisch</option>
       <option value="Fisch" <?php if($item['kind'] == "Fisch") echo "selected"?>>Fisch</option>
       <option value="Getreideprod." <?php if($item['kind'] == "Getreideprod.") echo "selected"?>>Getreideprod.</option>
       <option value="Milchprod." <?php if($item['kind'] == "Milchprod.") echo "selected"?>>Milchprod.</option>
       <option value="Gewürze" <?php if($item['kind'] == "Gewürze") echo "selected"?>>Gewürze</option>
       <option value="Knabbern" <?php if($item['kind'] == "Knabbern") echo "selected"?>>Knabbern</option>
       <option value="Getränke" <?php if($item['kind'] == "Getränke") echo "selected"?>>Getränke</option>
       <option value="Kräuter" <?php if($item['kind'] == "Kräuter") echo "selected"?>>Kräuter</option>
       <option value='Hygiene' <?php if($item['kind'] == "Hygiene") echo "selected"?>>Hygiene</option>
       <option value='Putzen' <?php if($item['kind'] == "Putzen") echo "selected"?>>Putzen</option>
       <option value='Haustier' <?php if($item['kind'] == "Haustier") echo "selected"?>>Haustiere</option>
       <option value='Sonstiges' <?php if($item['kind'] == "Sonstiges") echo "selected"?>>Sonstiges</option>
      </select></td>
      <td class="list-button"><button class='btn-list' name='delete' value="<?php echo $item['id']?>"><img src='images/trashbox.png'></button></td></form></tr>
                        <?php
                        }
                    }else {
                                                /******************************************************************************** shopping list end****/
                        ?><tr><td></td><td></td><td>Keine Items vorhanden</td><td></td><td></td><td></td><td></td></tr><?php
                    }
                ?>

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,例如<tr data-item-id="<?php echo $item['id']; ?>">,然后在JavaScript中使用element.dataset.itemId来访问。
  • 根据实际情况调整选择器和事件类型。

总结:

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

500

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

167

2023.10.07

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4382

2024.08.14

什么是低代码
什么是低代码

低代码是一种软件开发方法,使用预构建的组件可快速构建应用程序,无需大量编程。想了解更多低代码的相关内容,可以阅读本专题下面的文章。

300

2024.05.21

chatgpt官网入口地址合集
chatgpt官网入口地址合集

本专题整合了chatgpt官网入口地址、使用教程等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

minimax入口地址汇总
minimax入口地址汇总

本专题整合了minimax相关入口合集,阅读专题下面的文章了解更多详细地址。

4

2026.03.16

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

7

2026.03.16

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

114

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

141

2026.03.12

热门下载

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

精品课程

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

共137课时 | 13.7万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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