小编Rob*_*Rob的帖子

for循环中的闭包

循环中的闭包导致我出现问题.我想我必须创建另一个函数来返回一个函数来解决问题,但我无法使用我的jQuery代码.

以下是简化形式的基本问题:

function foo(val) {
  alert(val);
}

for (var i = 0; i < 3; i++) {
  $('#button'+i).click(function(){
    foo(i);
  });
}
Run Code Online (Sandbox Code Playgroud)

自然地点击三个按钮中的任何一个都会发出警告说3.我想要的功能是点击按钮1将发出警告说1,按钮2会说2等.

我该怎么做呢?

javascript jquery closures loops

12
推荐指数
3
解决办法
2388
查看次数

预准备语句中的递归

我一直在使用PDO并准备我的所有陈述主要是出于安全原因.不过,我有我的代码的一部分确实有不同的参数执行相同的语句多次,而且我认为这将是在准备好的发言大放异彩.但他们实际上打破了代码......

代码的基本逻辑是这样的.

function someFunction($something) {
  global $pdo;

  $array = array();

  static $handle = null;
  if (!$handle) {
    $handle = $pdo->prepare("A STATEMENT WITH :a_param");
  }

  $handle->bindValue(":a_param", $something);
  if ($handle->execute()) {
    while ($row = $handle->fetch()) {
      $array[] = someFunction($row['blah']);
    }
  }

  return $array;
}
Run Code Online (Sandbox Code Playgroud)

它看起来很好,但它错过了很多行.最终我意识到语句句柄正在被更改(使用不同的参数执行),这意味着在while循环中对fetch的调用只会工作一次,然后函数再次调用自身,并且结果集会被更改.

所以我想知道以递归方式使用PDO预处理语句的最佳方法是什么.

一种方法可能是使用fetchAll(),但它在手册中说有很大的开销.这一点的全部意义在于提高效率.

我能做的另一件事是不重用静态句柄,而是每次都创建一个新句柄.我相信,由于查询字符串是相同的,因此MySQL驱动程序内部无论如何都将使用预处理语句,因此在每次递归调用上创建新句柄的开销很小.就我个人而言,我认为这就失败了.

或者有什么方法可以重写这个吗?

php mysql recursion pdo prepared-statement

8
推荐指数
1
解决办法
921
查看次数

标签 统计

closures ×1

javascript ×1

jquery ×1

loops ×1

mysql ×1

pdo ×1

php ×1

prepared-statement ×1

recursion ×1