javascript - 在 jQuery 中枚举 JS 数组

标签 javascript jquery prototype

好的 jQuery 专家:所以 .. 我来自 Prototype 背景。

我一直在执行以下代码(或一些类似的变体):

MyObject.prototype.someFunction = function()
{
  var myArray = ["a","b","c"];
  myArray.each(function(arrayEntry)
    {
      this.printPart(arrayEntry);
    }, this);
}

MyObject.prototype.printPart = function(part)
{
  console.log(part);
}

我正在查看 jQuery 文档——我不知道该怎么做。

这可能吗?

我特别感兴趣:

  • 遍历 javascript 数组(对象也不错)。
  • 维护范围。请注意每个函数的最后一个“this”参数。

最佳答案

你正在寻找 $.each(array, function(i, element) { ... })

这也处理对象,在这种情况下,您在参数中得到 (key, value)

edit — 遗憾的是,没有什么比得上 Prototype 的 inject 了,我真的很想念它。但是 jQuery 中有 map,这有点像 Prototype 中的 collect

再次编辑 — 正如@Nick 在他的评论中指出的那样,Prototype 和 jQuery 不同意处理“this”的最佳方式。通常,jQuery 调用“处理程序”函数,其中“this”指向明显的相关对象。就此而言,原型(prototype)制作更加自由。

关于javascript - 在 jQuery 中枚举 JS 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3122101/

相关文章:

javascript - 如何选择大于某个值的所有类

javascript - Polymer 修复搞乱了 Javascript

javascript - 为什么子类型必须在子类型函数之外为其原型(prototype)分配一个父对象?

使用 defineProperty 的 JavaScript 原型(prototype)继承

javascript - 处理异步回调和渲染 DOM 的更好方法

javascript - 在node.js中使用for循环?

jQuery 平滑滚动

javascript - Backbone.*.extend 是否为定义的类设置原型(prototype)值?

javascript - 单击 popup.html(chrome 扩展)后执行脚本

javascript - Jquery 等高