Jquery - 从分隔字符串创建数组并评估其值

5

我有一个问题,无法解决。

我有一个字符串“B01、B20、B03、”

我想用“,”作为分隔符创建一个jQuery数组,然后删除最后一个元素(即空白),然后对于数组的每个值都发出警报。

类似这样的东西...

 var theString = "B01, B20, B03, ";

    var theArray = (theString, ',');

    theArray = remove_last_element;  (??)

    $('theArray').each(function() {

      alert(theArray[?].value); 

    });

有任何提示吗?
谢谢!
7个回答

23
var theString = "B01, B20, B03, ";

$.each(theString.split(",").slice(0,-1), function(index, item) {
    alert(item); 
});

如果您有任何问题,请告诉我。


你为什么要把数组放进 jQuery 对象中? - Guffa
@Guffa 我根据他的问题措辞假设他想要一个 jQuery 对象。 - Jon Hinson
太棒了,我最终选择了这种方式,因为它非常紧凑和美观!非常感谢您的帮助!@Guffa,我是一个完全的新手,我还在学习 :) - matteo

12

“jQuery数组”这一说法不存在,应该使用Javascript数组。

如果一个字符串包含逗号分隔的值,你不能简单地将其转换为数组。你需要使用某些方法来解析字符串,而在这种情况下,可以使用split方法来实现:

var theString = "B01, B20, B03, ";
var theArray = theString.split(", ");

这将生成一个包含四个元素的数组,因为有一个尾随分隔符,所以您可以检查并删除它:

if (theArray.length > 0 && theArray[theArray.length - 1].length == 0) {
  theArray.pop();
}

您可以使用纯JavaScript或jQuery方法循环数组。纯JavaScript代码如下:

for (var i = 0; i < theArray.length; i++) {
  alert(theArray[i]);
}

使用jQuery方法的示例如下:

$.each(theArray, function(index, item) {
  alert(item);
});

你也可以跳过删除项目的步骤,在循环中直接检查空项目:

var theString = "B01, B20, B03, ";
var theArray = theString.split(", ");
for (var i = 0; i < theArray.length; i++) {
  if (theArray[i].length > 0) {
    alert(theArray[i]);
  }
}

2
你不需要 jQuery。使用 String.prototype.split 来分割字符串,然后用 for 循环遍历它。
var theString = "B01, B20, B03, ",
    bits = theString.split(', ').slice(0, -1); // split the string and remove the last one

for (var i = 0; i < bits.length; i++) {
    alert(bits[i]);
}

我是一个完全的新手 :) 我认为我需要使用jQuery,因为所有其他脚本都在使用它。无论如何,非常感谢您抽出时间来帮助我。 - matteo

1
var theString = "B01, B20, B03, ",
    theArray = theString.split(', ');

theArray.pop();
$(theArray).each(function() {
  alert(this); 
});

非常感谢您抽出时间来帮助我。 - matteo

0
下面我只使用了jQuery中的“trim”函数来检查值是否为空。否则,我使用了split和splice函数(纯粹的JavaScript)。
var theString = "B01, B20, B03, ";
var theArray = theString.split(',');
for(i=0; i<theArray.length; i++) {
  // check if any array element is empty, if so, take it out of the array
  if ($.trim(theArray[i]) == "")
    theArray.splice(i, 1); // remove element since it's blank
}

// now you can iterate over the "real" values of the array
$.each(theArray, function(i, value) {
  alert(value);
});

非常感谢您抽出时间来帮助我。 - matteo

0
var str = "B01, B20, B03, ";

$.each(str.split(','), function(i, val) {
  val = $.trim(val);
  alert(val);
});

0
cleanString = function(str) {
    return $.grep(str.split(','), function(elem) {
        return ($.trim(elem) !== '')
    });
}

此函数将返回一个数组,其中包含所有逗号分隔的元素,并删除所有空格。请查看$.grep

用法

cleanString("B01, B20, B03, ");

警告数组应该很简单。只需要迭代返回的数组即可。

  var arr = cleanString("B01, B20, B03, ");
  $.each(arr, function(index, value) { 
      alert(value); 
  });

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接