【发布时间】:2010-10-13 16:29:39
【问题描述】:
我需要获取具有多个分隔符的拆分数组的最后一个元素。分隔符是逗号和空格。如果没有分隔符,它应该返回原始字符串。
如果字符串是“你今天过得怎么样?”它应该返回“今天?”
如果输入是“hello”,则输出应该是“hello”。
如何在 JavaScript 中做到这一点?
【问题讨论】:
标签: javascript split
我需要获取具有多个分隔符的拆分数组的最后一个元素。分隔符是逗号和空格。如果没有分隔符,它应该返回原始字符串。
如果字符串是“你今天过得怎么样?”它应该返回“今天?”
如果输入是“hello”,则输出应该是“hello”。
如何在 JavaScript 中做到这一点?
【问题讨论】:
标签: javascript split
const str = "hello,how,are,you,today?"
const pieces = str.split(/[\s,]+/)
const last = pieces[pieces.length - 1]
console.log({last})
此时,pieces 是一个数组,pieces.length 包含数组的大小,因此要获取数组的最后一个元素,请检查 pieces[pieces.length-1]。如果没有逗号或空格,它将简单地输出给定的字符串。
alert(pieces[pieces.length-1]); // alerts "today?"
【讨论】:
pieces.pop() 来获取数组的最后一项。
var last = str.split(/[\s,]+/).pop()
每件事都有一条线。 :)
var output = input.split(/[, ]+/).pop();
【讨论】:
split 调用创建的,无论如何它都不会保留。从数组中弹出项目不会更改原始字符串。
slice 方法:var output = input.split(/[, ]+/).slice(-2);。
{1,} 相同,即[, ]+ 匹配集合中的一个或多个字符(逗号和空格)。当您想要字符串中的所有单词时,它很有用,但是当您只想要最后一个单词时,它不会产生任何功能差异,它只会减少开销,因为数组中的字符串会更少。
如果你不想构造一个数组...
var str = "how,are you doing, today?";
var res = str.replace(/(.*)([, ])([^, ]*$)/,"$3");
英文细分为:
/(anything)(any separator once)(anything that isn't a separator 0 or more times)/
替换只是说用最后一个分隔符之后的东西替换整个字符串。
因此,您可以看到如何普遍应用它。注意原始字符串没有被修改。
【讨论】:
var item = "one,two,three";
var lastItem = item.split(",").pop();
console.log(lastItem); // three
【讨论】:
.split(',').pop() 适用于逗号分隔字符串上的最后一个元素。只是说因为我被 Guffa 的真棒答案误导了,我只是忽略了它,因为不需要正则表达式并认为诀窍就在那里! :P
var title = 'fdfdsg dsgdfh dgdh dsgdh tyu hjuk yjuk uyk hjg fhjg hjj tytutdfsf sdgsdg dsfsdgvf dfgfdhdn dfgilkj,n, jhk jsu wheiu sjldsf dfdsf hfdkdjf dfhdfkd hsfd ,dsfk dfjdf ,yier djsgyi kds';
var shortText = $.trim(title).substring(1000, 150).split(" ").slice(0, -1).join(" ") + "...More >>";
【讨论】:
可以直接访问数组索引:
var csv = 'zero,one,two,three';
csv.split(',')[0]; //result: zero
csv.split(',')[3]; //result: three
【讨论】:
使用split 和slice 的有史以来最好的和我最喜欢的
const str = "hello, how are you today?"
const last = str.split(' ').slice(-1)[0]
console.log({last})
另一个使用split 然后pop 最后一个。
const str = "hello, how are you today?"
const last = str.split(' ').pop()
console.log({last})
【讨论】:
.pop() 仍然是一个很好的便利。没有突变,因为访问器方法返回一个新数组。
您还可以考虑反转数组并获取第一个元素。这样你就不必知道长度,但它没有带来真正的好处,缺点是反向操作可能需要更长的时间来处理大数组:
array1.split(",").reverse()[0]
虽然很简单,但也修改了有问题的原始数组。这可能是也可能不是问题。
参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse
也许你可能想用这个:
array1.split(",").pop()
【讨论】:
.pop() 方法是迄今为止我见过的最好的答案。这就是它被创建的原因!
有多种方法可以获取最后一个元素
let input='one,two,three,four';
let output1 = input.split(',').pop();
console.log('output1 =',output1);
let split = input.split(',');
let output2 = split[split.length-1];
console.log('output2=',output2);
let output3 = input.split(',').reverse()[0];
console.log('output3=',output3);
let output4 = input.split(',').slice(-1)[0];
console.log('output4=',output4);
【讨论】:
这种方式很容易理解,也很简短。
const output = input.split(',').pop().split(' ').pop();
【讨论】: