有人知道这两种方法的区别吗?

String.prototype.slice
String.prototype.substring

当前回答

唯一的答案是好的,但需要一些解读。尤其是有了“停止”这个新术语。

My Go——根据差异组织,除了上面Daniel的第一个答案外,它还很有用:

1)负指数。子字符串需要正索引,并将负索引设置为0。Slice的负下标表示从字符串末尾开始的位置。

"1234".substring(-2, -1) == "1234".substring(0,0) == ""
"1234".slice(-2, -1) == "1234".slice(2, 3) == "3"

2)索引交换。子字符串将重新排序索引,使第一个索引小于或等于第二个索引。

"1234".substring(3,2) == "1234".substring(2,3) == "3"
"1234".slice(3,2) == ""

--------------------------

一般评论——我发现第二个索引是片或子字符串的最后一个字符之后的位置很奇怪。我希望"1234".slice(2,2)返回"3"。这使得安迪的困惑是合理的——我认为是“1234”。切片(2,-1)以返回“34”。是的,这意味着我是Javascript新手。这也意味着这种行为:

"1234".slice(-2, -2) == "", "1234".slice(-2, -1) == "3", "1234".slice(-2, -0) == "" <-- you have to use length or omit the argument to get the 4.
"1234".slice(3, -2) == "", "1234".slice(3, -1) == "", "1234".slice(3, -0) == "" <-- same issue, but seems weirder.

我的2摄氏度。

其他回答

slice方法和substring方法的唯一区别是参数

两者都有两个参数,例如start/from和end/to。

你不能传递一个负值作为子字符串方法的第一个参数,但slice方法从结束遍历它。

切片方法参数细节:

参数

start_index 从切片开始的位置索引。如果value为负,则表示从最后开始。例如,最后一个字符是-1。 end_index 切片结束后的索引。如果没有提供切片将从start_index到字符串的末尾。如果是负值,指数将从字符串的末端测量。

子字符串方法参数详细信息:

参数

从 它应该是一个非负整数,以指定子字符串应该从哪里开始。 来 一个可选的非负整数,用于提供应在哪个子字符串之前结束的索引。

Slice()的工作方式类似于substring(),只是有一些不同的行为。

Syntax: string.slice(start, stop);
Syntax: string.substring(start, stop);

他们的共同点是:

如果start = stop:返回一个空字符串 如果省略了stop:提取字符到字符串的末尾 如果任何一个参数大于字符串的长度,则使用字符串的长度。

substring()的区别:

如果start > stop,那么substring将交换这两个参数。 如果其中一个参数为负或为NaN,则将其视为0。

slice()的区别:

如果start > stop, slice()将返回空字符串。(" ") 如果start为负数:从字符串的末尾开始设置char,就像Firefox中的substr()一样。在Firefox和IE中都可以观察到这种行为。 如果stop为负值:将stop设置为:字符串。length - Math.abs(stop)(原始值),除了在0处有界(因此,Math.abs(stop))。马克斯(0,字符串。长度+停止)),如ECMA规范所述。

来源:编程与开发的基本艺术:Javascript: substr() vs .s. substring()

唯一的答案是好的,但需要一些解读。尤其是有了“停止”这个新术语。

My Go——根据差异组织,除了上面Daniel的第一个答案外,它还很有用:

1)负指数。子字符串需要正索引,并将负索引设置为0。Slice的负下标表示从字符串末尾开始的位置。

"1234".substring(-2, -1) == "1234".substring(0,0) == ""
"1234".slice(-2, -1) == "1234".slice(2, 3) == "3"

2)索引交换。子字符串将重新排序索引,使第一个索引小于或等于第二个索引。

"1234".substring(3,2) == "1234".substring(2,3) == "3"
"1234".slice(3,2) == ""

--------------------------

一般评论——我发现第二个索引是片或子字符串的最后一个字符之后的位置很奇怪。我希望"1234".slice(2,2)返回"3"。这使得安迪的困惑是合理的——我认为是“1234”。切片(2,-1)以返回“34”。是的,这意味着我是Javascript新手。这也意味着这种行为:

"1234".slice(-2, -2) == "", "1234".slice(-2, -1) == "3", "1234".slice(-2, -0) == "" <-- you have to use length or omit the argument to get the 4.
"1234".slice(3, -2) == "", "1234".slice(3, -1) == "", "1234".slice(3, -0) == "" <-- same issue, but seems weirder.

我的2摄氏度。

对于slice(start, stop),如果stop为负,stop将被设置为:

string.length – Math.abs(stop)

而不是:

string.length – 1 – Math.abs(stop)

substring和slice -之间的区别是它们如何处理负的和忽略的行参数:

substring(开始、结束)

负参数被解释为零。太大的值将被截断为字符串的长度:

alert("testme".substring(-2)); // "testme", -2 becomes 0

此外,如果start > end,参数将互换,即在开始和结束之间返回绘图线:

alert("testme".substring(4, -1)); // "test"
// -1 Becomes 0 -> got substring (4, 0)
// 4> 0, so that the arguments are swapped -> substring (0, 4) = "test"

负数值从线的末端开始测量:

alert("testme".slice(-2)); // "me", from the end position 2
alert("testme".slice(1, -1)); // "estm", from the first position to the one at the end.

它比奇怪的逻辑子字符串方便得多。

除IE8-外,所有浏览器均支持substr的第一个参数为负值。

如果选择这三种方法之一,在大多数情况下使用-它将是切片:负参数,它的维护和操作最明显。