Javascript Slice 方法及其示例

javascript slice 方法及其示例

什么是 javascript 数组切片?

array.prototype.slice 是一个 js array 方法,用于从现有数组中提取连续的子数组或“切片”。

javascript 切片可以接受两个参数:切片的开始和结束指示符——两者都是可选的。也可以在没有任何参数的情况下调用它。因此,它具有以下调用签名:

// slice();slice(start);slice(start, end);

如果我想对数组进行切片以获取其中的一部分,实际上有一个用于 javascript 的内置函数 slice 。开箱即用,它将克隆原始数组。

[1,2,3].slice() // [1,2,3]

结果指向新的内存地址,而不是原始数组。如果您想将结果与其他函数链接起来,这非常有用。真正的用法是当您向切片提供一些输入时。

开始索引

切片最多可以接受两个输入参数。第一个称为起始索引,这将告诉它应该从哪里开始切片。

[1,2,3].slice(0) // returns [1,2,3]; original array unmodified[1,2,3].slice(1) // returns [2,3]; original array unmodified[1,2,3].slice(2) // returns [3]; original array unmodified[1,2,3].slice(3) // returns []; original array unmodified

默认情况下,它将切片直到数组末尾。起始索引的有趣之处在于,不仅可以使用零或正数,还可以使用负数。

[1,2,3].slice(-1) // [3][1,2,3].slice(-2) // [2,3][1,2,3].slice(-3) // [1,2,3]

当为负数时,表示从 n 末尾开始计数的索引。例如,-1 指数组的最后一个元素,-2 指倒数第二个元素,等等。请注意,没有 -0 ,因为最后一个元素之外没有任何元素。根据具体情况,这可能非常明显或令人困惑。

结束索引

切片可以采用第二个参数,称为结束索引。

[1,2,3].slice(0,3) // [1,2,3][1,2,3].slice(0,2) // [1,2][1,2,3].slice(0,1) // [1]

结束索引,也称为范围索引,指向元素索引+1。这是什么意思?为了解释这一点,如果我们能联系到 for 语句就会相对容易一些:

for (let i = 0; i < n; i++) {}

变量 i 从 0 开始,即起始索引;并以结束索引 n 结束。结束索引不是数组的最后一个元素,因为那将是 n – 1 。但当谈到结束索引时,n 代表“结束”,包括最后一个元素。如果这是您第一次使用结束索引,只需记住 for 语句是如何编写的,或者只需记住获取最后一个元素索引,然后加一即可。另一种思考方式是结束索引是开放式的,[start, end)。

立即学习“Java免费学习笔记(深入)”;

与开始索引一样,结束索引也可以为负数。

1,2,3].slice(0,-1) // [1,2][1,2,3].slice(0,-2) // [1]

这里要多加注意。 -1 指的是最后一个元素,因此如果用作第二个参数,则意味着最后一个元素将被排除,正如我们所解释的,开放式。

很酷,但是如果我想包含最后一个元素怎么办?

[1,2,3].slice(0) // [1,2,3]

是的,只需使用单个参数输入即可。

如何使用 javascript 切片:真实示例

切片数组的一个典型示例涉及从源数组生成连续部分。例如,前三个项目、后三个项目以及从某个索引到另一个索引的一些项目。

如下例所示:

const elements = [  "please",  "send",  "cats",  "monkeys",  "and",  "zebras",  "in",  "large",  "cages",  "make",  "sure",  "padlocked",];const firstthree = elements.slice(0, 3); // ["please", "send", "cats"]const lastthree = elements.slice(-3, elements.length); // ["make", "sure", "padlocked"]const fromthirdtofifth = elements.slice(2, 5); // ["cats", "monkeys", "and"]

如果我们不向 javascript slice 传递任何参数,我们将获得包含所有项目的源数组的浅表副本:

const allcopied = elements.slice();// (12) ["please", "send", "cats", "monkeys", "and", "zebras", "in", "large", "cages", "make", "sure", "padlocked"]

它实际上是[…元素]。

没有第二个参数的 javascript 数组切片方法

从零写个小框架 从零写个小框架

本课以一个极简的PHP开发框架为案例,向您展示了一个PHP框架应该具有的基本功能,以及具体的实现方法,让您快速对PHP开发框架的底层实现有一个清楚的认识,为以后学习其实的开发框架打下坚实的基础。

从零写个小框架 1151 查看详情 从零写个小框架

如果我们不传递第二个参数,提取的 javascript 数组切片将扩展到最后一个元素:

const fromthird = elements.slice(2);// (10) ["cats", "monkeys", "and", "zebras", "in", "large", "cages", "make", "sure", "padlocked"]const lastthree = elements.slice(-3, elements.length);// (3) ["make", "sure", "padlocked"]const lastthreewithnosecarg = elements.slice(-3);// (3) ["make", "sure", "padlocked"]

具有负偏移量的 javascript array.prototype.slice

还请注意,我们可以传入负数作为参数。参数的负值表示从最后一项向后计数的偏移位置。我们可以对两个参数执行此操作:

const latesttwobeforelast = elements.slice(-3, -1);// (2) ["make", "sure"]

如果我们传入的 start 值大于 end 值,我们会得到一个空数组:

const somewherewedontknow = elements.slice(5, 2); // []

这表明我们必须始终从较小的正索引开始切片。

array.prototype.slice:起始位置大于数组长度

同样,如果我们传入的 start 值大于数组的长度,我们会得到一个空数组:

const somewhereinouterspace = elements.slice(15, 2); // []

将 js 切片与稀疏数组结合使用

如果我们的目标切片有稀疏项目,它们也会被复制:

const elements = [  "please",  "send",  ,  "cats",  ,  "monkeys",  "and",  "zebras",  "in",  "large",  "cages",  "make",  "sure",  "padlocked",];const sparseitems = elements.slice(0, 6);// (6) [ 'please', 'send', , 'cats', , 'monkeys' ]

array.prototype.slice:从参数列表创建数组

在本节中,我们对切片有点疯狂。我们使用 array.prototype.slice 开发了两种有趣的方法,从传递给函数的参数列表构造数组。

第一个:

const createarray = (...args) => array.prototype.slice.call(args);const array = createarray(1, 2, 3, 4);// (4) [1, 2, 3, 4]

这很容易。

执行此操作的下一个级别的方法是采用最混乱的方式:

const boundslice = function.prototype.call.bind(array.prototype.slice);const createarray = (...args) => boundslice(args);const array = createarray(1, 2, 3, 4);// (4) [1, 2, 3, 4]

切片 javascript 字符串

const mnemonic =  "please send cats monkeys and zebras in large cages make sure padlocked";const firstthreechars = mnemonic.slice(0, 3); // "ple"const lastthreechars = mnemonic.slice(-3, mnemonic.length); // "ked"const fromthirdtofifthchars = mnemonic.slice(2, 5); // "eas"

同样,两个参数都表示从零开始的索引号或偏移值。这里,第一个参数——firstthree赋值中的0——代表源数组中的起始索引或偏移量。第二个参数 (3) 表示提取应停止之前的索引或偏移量。

javascript 字符串切片的细微差别

使用不带参数的 javascript 字符串切片

与数组切片类似,如果我们不向 string slice() 传递任何参数,则会复制整个字符串:

const mnemonic =  "please send cats monkeys and zebras in large cages make sure padlocked";const memorizedmnemonic = mnemonic.slice();// "please send cats monkeys and zebras in large cages make sure padlocked"

具有负偏移量的 javascript 字符串切片

与array.prototype.slice类似,start和end的负值表示距数组末尾的偏移位置:

const mnemonic =  "Please Send Cats Monkeys And Zebras In Large Cages Make Sure Padlocked";const lastThreeChars = mnemonic.slice(-3); // "ked"const latestTwoCharsBeforeLast = mnemonic.slice(-3, -1);  // "ke"

概括

在这篇文章中,我们阐述了 javascript 中的 slice() 方法。我们看到 javascript 以两种方式实现 slice():一种用于使用 array.prototype.slice 的数组,另一种用于使用 string.prototype.slice 的字符串。我们通过示例发现,这两种方法都会生成源对象的副本,并用于从中提取目标连续切片。

我们介绍了几个示例,说明函数组合和使用 function.prototype.call 和 function.prototype.bind 进行上下文绑定如何允许我们使用 array.prototype.slice 定义自定义函数,以帮助我们从参数列表生成数组.

我们还看到 string.prototype.slice 是 array.prototype.slice 的相同实现,它消除了将字符串转换为字符数组的开销。

以上就是Javascript Slice 方法及其示例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/898499.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 19:02:10
下一篇 2025年11月28日 19:02:32

相关推荐

  • 使用 Go 语言解析转义的 JSON 字符串

    本文旨在解决 Go 语言中解析转义 JSON 字符串的问题。当从 SockJS 等渠道接收到转义的 JSON 字符串时,直接使用 `json.Unmarshal` 会失败。本文将介绍如何使用 `strconv.Unquote` 函数来正确解析这类字符串,并提供详细的代码示例和解释,帮助开发者理解和应…

    2025年12月16日
    000
  • 使用Go Rest处理POST请求中的表单数据

    本文档旨在指导Go语言初学者在使用`gorest`框架处理POST请求时,如何正确解析和使用HTML表单提交的数据。我们将解释为何直接使用HTML表单提交数据会导致解析错误,并提供使用JavaScript发送JSON格式数据的解决方案,以及如何配置Go Rest服务以接收和处理JSON数据。 在使用…

    2025年12月16日
    000
  • 使用Go Build Constraints实现跨平台代码管理

    go语言通过构建约束(build constraints)机制,优雅地解决了平台特定代码的兼容性问题。开发者可以利用文件注释或文件名约定,为不同操作系统或架构编写独立的实现,从而在编译时自动选择正确的代码,无需传统预处理器,确保跨平台应用的顺畅构建与运行。 在开发跨平台应用程序时,经常会遇到某些功能…

    2025年12月16日
    000
  • Go语言接口深度解析:从io.ReadCloser看接口嵌入与使用

    本文深入探讨go语言中接口的核心概念,特别是其隐式实现机制和接口嵌入的强大特性。通过分析`io.readcloser`这一常见接口,我们将阐明接口如何通过组合其他接口来构建更复杂的行为,并纠正关于“接口包含另一个接口”的常见误解,最终指导读者正确地使用如http响应体(`response.body`…

    2025年12月16日
    000
  • Go语言能否用于操作系统内核开发?

    本文探讨了使用Go语言开发操作系统内核的可行性。虽然理论上任何图灵完备的语言都可以用于此目的,但实际应用中存在诸多挑战。本文将分析Go语言的优势与局限,并提供相关案例与参考,帮助开发者评估Go语言在操作系统内核开发中的适用性。 操作系统内核开发是一个极具挑战性的任务,通常需要对硬件进行底层控制,并对…

    2025年12月16日
    000
  • Go语言HTTP服务中JSON响应的正确处理方法

    本文探讨了Go语言HTTP服务在发送JSON响应时的一个常见陷阱。当使用fmt.Fprint将字节切片写入http.ResponseWriter时,可能会导致数据被格式化为字节数组的字符串表示,而非原始JSON数据。文章详细解释了这一问题的原因,并提供了使用w.Write方法发送原始JSON字节的正…

    2025年12月16日
    000
  • Go HTTP服务器:POST表单数据解析与常见陷阱规避指南

    本文旨在解决go语言http服务器在处理post请求时,无法正确获取表单值的问题。我们将详细讲解`req.parseform()`和`req.form.get()`的正确用法,并深入分析客户端与服务器端键名不匹配等常见陷阱,通过示例代码确保开发者能够高效、准确地处理http post表单数据。 Go…

    2025年12月16日
    000
  • Go语言行为驱动测试:探索GoConvey的魅力

    goconvey为go语言开发者提供了一个rspec风格的行为驱动测试(bdd)框架,解决了go生态中缺乏表达性强、类自然语言测试工具的问题。它不仅提供了清晰、易读的测试语法,还附带一个自动更新的浏览器ui,极大地提升了测试开发的效率和反馈速度,成为go 1+版本下进行现代化测试的理想选择。 GoC…

    2025年12月16日
    000
  • Go中解析JSON时保留64位整数值

    在Go语言中处理包含64位整数的JSON数据时,标准`json.Unmarshal`到`interface{}`可能导致精度丢失。本文将介绍两种有效策略来解决此问题:一是利用`json.Decoder`的`UseNumber()`方法将数字解析为`json.Number`字符串再手动转换;二是定义具…

    2025年12月16日
    000
  • Go语言JSON编码:值类型与指针类型结构体性能深度解析

    在go语言中,使用`encoding/json`包对结构体进行json编码时,包含指针类型字段的结构体通常会比包含值类型字段的结构体表现出更低的性能。这种性能差异主要源于json编码器在处理指针时,需要通过反射机制进行额外的解引用操作,从而引入了固定的性能开销,该开销往往会抵消指针在避免数据复制上的…

    2025年12月16日
    000
  • Go JSON 编码:结构体使用指针比使用拷贝更慢?

    本文探讨了 Go 语言中使用 encoding/json 包进行 JSON 编码时,结构体成员使用指针类型与使用拷贝类型在性能上的差异。通过基准测试,我们发现使用指针类型的结构体进行 JSON 编码通常比使用拷贝类型的结构体更慢。文章分析了这种现象的原因,并解释了指针的反射和解引用操作带来的额外开销…

    2025年12月16日
    000
  • Go JSON 编码:结构体使用指针为何比使用拷贝更慢?

    本文探讨了在 Go 语言中使用 `encoding/json` 包进行 JSON 编码时,结构体成员使用指针类型反而比使用值类型更慢的现象。通过基准测试代码,我们分析了这种性能差异的原因,并解释了指针解引用带来的额外开销。结论表明,对于简单的结构体,使用值类型可以获得更好的性能。 在 Go 语言中使…

    2025年12月16日
    000
  • Golang构建简单博客文章管理工具

    答案是用Golang构建博客管理工具需定义Post结构体实现CRUD,使用内存存储并可通过flag或net/http提供命令行或HTTP接口。 用Golang构建一个简单的博客文章管理工具并不复杂,适合初学者练手或快速搭建原型。核心目标是实现文章的增、删、改、查(CRUD)功能,并通过命令行或HTT…

    2025年12月16日
    000
  • Go语言中访问深度嵌套JSON数据的正确姿势

    本文旨在介绍在Go语言中如何有效地解析和访问深度嵌套的JSON数据。通过使用`encoding/json`标准库以及第三方库`go-simplejson`,我们将展示如何从复杂的JSON结构中提取特定键的值,并探讨如何使用结构体来表示这些数据,以提高代码的可读性和可维护性。 在Go语言中处理JSON…

    2025年12月16日
    000
  • Golang如何应用迭代器模式简化集合操作

    Go语言通过闭包和泛型实现迭代器模式,提供统一方式遍历数据结构。1. 使用闭包封装遍历逻辑,如IntSliceIterator返回func() (int, bool);2. Go 1.18+支持泛型后,SliceIterator[T any]可复用于任意类型切片;3. 可构建FilterIterat…

    2025年12月16日
    000
  • 如何在Golang中实现表单验证

    使用结构体标签与反射可实现基础表单验证,如定义含validate标签的User结构体并解析执行规则;推荐使用go-playground/validator库进行高效验证,支持required、email等内置规则及自定义逻辑;在Gin框架中结合binding标签与ShouldBind方法可自动校验请…

    2025年12月16日
    000
  • Web服务器异常处理与日志记录示例

    答案:Web服务器应通过统一异常处理中间件捕获各类错误,使用结构化错误对象(如AppError)携带状态码和消息,结合专业日志库(如winston)记录详细信息,并区分环境返回客户端友好提示,确保系统稳定与可维护性。 当Web服务器遇到异常时,良好的错误处理和日志记录机制能帮助开发者快速定位问题、提…

    2025年12月16日
    000
  • 使用Go Rest框架处理POST请求中的表单数据

    本文旨在帮助初学者了解如何在使用Go Rest框架构建REST API时,正确处理来自HTML表单的POST请求。我们将深入探讨Content-Type的问题,并提供使用JavaScript发送JSON数据的解决方案,避免常见的反序列化错误。 在使用 Go Rest 框架构建 REST API 时,…

    2025年12月16日
    000
  • 如何使用Golang反射实现依赖注入

    答案是使用反射实现Go语言依赖注入:通过定义inject标签标记依赖字段,利用反射扫描结构体字段类型,结合容器注册和查找实例,自动完成依赖赋值。 在 Go 语言中,依赖注入(Dependency Injection, DI)通常通过手动构造对象并传递依赖来实现。由于 Go 不直接支持注解或泛型(在旧…

    2025年12月16日
    000
  • 如何使用Golang开发REST API接口

    使用Gin框架可快速构建REST API,通过net/http处理HTTP请求,结合GORM操作数据库,合理分层(main、handlers、services、models)提升可维护性,遵循REST原则实现CRUD,配合中间件与统一错误处理,逐步扩展JWT鉴权与Swagger文档功能。 用Gola…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信