协慌网

登录 贡献 社区

如何将逗号分隔的字符串转换为数组?

我有一个逗号分隔的字符串,我想将其转换为数组,因此可以循环遍历它。

有内置的功能可以做到这一点吗?

例如,我有这个字符串

var str = "January,February,March,April,May,June,July,August,September,October,November,December";

现在,我想用逗号将其分割,然后将其存储在数组中。

答案

var array = string.split(',');

MDN 参考limit参数可能发生的异常行为很有帮助。 (提示: "a,b,c".split(",", 2)出现在["a", "b"] ,而不是["a", "b,c"] 。)

请注意是否要针对整数,例如 1,2,3,4,5。如果打算在拆分字符串后将数组的元素用作整数而不是字符串,请考虑将其转换为此类。

var str = "1,2,3,4,5,6";
var temp = new Array();
// This will return an array with strings "1", "2", etc.
temp = str.split(",");

添加这样的循环,

for (a in temp ) {
    temp[a] = parseInt(temp[a], 10); // Explicitly include base as per Álvaro's comment
}

将返回一个包含整数而不是字符串的数组。

嗯,分割是危险的恕我直言,因为字符串始终可以包含逗号。请注意以下几点:

var myArr = "a,b,c,d,e,f,g,','";
result = myArr.split(',');

那么您将如何解释呢?您希望结果是什么?具有以下内容的数组:

['a', 'b', 'c', 'd', 'e', 'f', 'g', '\'', '\''] or
['a', 'b', 'c', 'd', 'e', 'f', 'g', ',']

即使您逃脱了逗号,您仍然会遇到问题。

我很快把它们弄在一起:

(function($) {
    $.extend({
        splitAttrString: function(theStr) {
            var attrs = [];

            var RefString = function(s) {
                this.value = s;
            };
            RefString.prototype.toString = function() {
                return this.value;
            };
            RefString.prototype.charAt = String.prototype.charAt;
            var data = new RefString(theStr);

            var getBlock = function(endChr, restString) {
                var block = '';
                var currChr = '';
                while ((currChr != endChr) && (restString.value !== '')) {
                    if (/'|"/.test(currChr)) {
                        block = $.trim(block) + getBlock(currChr, restString);
                    }
                    else if (/\{/.test(currChr)) {
                        block = $.trim(block) + getBlock('}', restString);
                    }
                    else if (/\[/.test(currChr)) {
                        block = $.trim(block) + getBlock(']', restString);
                    }
                    else {
                        block += currChr;
                    }
                    currChr = restString.charAt(0);
                    restString.value = restString.value.slice(1);
                }
                return $.trim(block);
            };

            do {
                var attr = getBlock(',', data);
                attrs.push(attr);
            }
            while (data.value !== '')
                ;
            return attrs;
        }
    });
})(jQuery);