深入理解JS中的substr和substring

深入理解JS中的substr和substring

在JavaScript字符串操作中,substr()substring()是两个常用的函数,都用来截取字符串。但在具体应用场景和实现方式有所不同,因此需要深入理解其差异。

substr()

substr()函数接受两个参数,第一个参数是截取的起始位置,第二个参数是截取的长度。如果省略第二个参数,则默认截取至字符串的尾部。该函数也可以接受负数参数,表示从字符串尾部开始计数。

示例1:

let str = 'Hello, world!';
let subStr = str.substr(7, 5);
console.log(subStr); // 输出 "world"

在上面的例子中,substr(7, 5)表示从第7个位置(从0开始计数)开始,截取长度为5的字符串。因此输出结果为"world"。

示例2:

let str='Hello world!';
let subStr=str.substr(-6,2);
console.log(subStr);//输出:'ld'

在上面的例子中,substr() 的第一个参数为负数,表示从字符串尾部开始截取,起始位置为倒数第6位(l字母),2表示截取的长度,即从上一个起始位置开始截取两位,输出结果为"ld"。

substring()

substr()类似,substring()也用来截取字符串,但它接受两个参数,第一个参数是截取的起始位置,第二个参数是截取的终止位置(不包含终止位置本身)。如果省略第二个参数,则默认截取至字符串的尾部。substring()不支持负数参数。

示例1:

let str = 'Hello, world!';
let subStr = str.substring(7, 12);
console.log(subStr); // 输出 "world"

在上面的例子中,substring(7, 12)表示从第7个位置(从0开始计数)开始截取,到第12个位置(不包含第12个位置),因此输出结果为"world"。

示例2:

let str='Hello world!';
let subStr=str.substring(6);
console.log(subStr);//输出:'world!'

在上面的例子中,substring() 的第一个参数表示从截取的起始位置,即位置6开始截取,由于省略了第二个参数,因此截取到了字符串尾部,输出结果为"world!"。

总结

  • substr()根据起始位置和长度截取字符串,支持负数参数,即从字符串尾部开始计数。
  • substring()根据起始位置和终止位置截取字符串,不支持负数参数。
  • 两者的区别在于第二个参数的含义,substr()表示截取的长度,substring()表示截取的终止位置。
  • 除非有特别需求,建议使用substring()函数。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:深入理解JS中的substr和substring - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • Asp与JS的数组和字符串下标介绍

    Asp和JS都是常用的Web编程语言,数组和字符串是它们中非常重要的数据结构。下面来详细讲解一下Asp与JS的数组和字符串下标,以及使用示例。 数组下标 JS数组下标 JS数组下标从0开始,每个元素占据一个整数下标。可以使用以下语法创建JS数组:var arr = [val1, val2, …, valn];。其中,val1到valn为数组元素。 访问J…

    JavaScript 2023年5月27日
    00
  • JS组件系列之Gojs组件 前端图形化插件之利器

    JS组件系列之Gojs组件 前端图形化插件之利器 GoJS是一个用于创建交互式图形和流程图的JavaScript库。借助GoJS,我们可以轻松地创建各种类型的图表,包括流程图,树形图,关系图等等。本文将详细讲解如何使用GoJS,并提供两个示例说明。 安装GoJS 我们可以通过引入GoJS的CDN来使用该库: <script src="http…

    JavaScript 2023年5月27日
    00
  • 详解JavaScript+Canvas绘制环形进度条

    接下来我将详细讲解“详解JavaScript+Canvas绘制环形进度条”的完整攻略。 环形进度条简介 环形进度条是指一个环形背景,根据输入的进度值,填充相应的进度颜色。它可以展示操作的进度、网站的加载进度等等。 环形进度条实现方法 JavaScript+Canvas是一种流行的实现环形进度条的方式。 首先,我们需要在HTML中创建一个Canvas元素: &…

    JavaScript 2023年6月11日
    00
  • 关于__defineGetter__ 和__defineSetter__的说明

    关于 __defineGetter__ 和 __defineSetter__ 的说明 __defineGetter__ 和 __defineSetter__ 是 JavaScript 中的两个方法,它们可以用于动态定义属性的 getter 和 setter 方法。在 ES5 中已经被废弃,建议使用 Object.defineProperty 来替代它们。 _…

    JavaScript 2023年6月10日
    00
  • js刷新页面方法大全

    下面是详细讲解 “JS 刷新页面方法大全” 的攻略: 一、使用 location.reload() 方法 location.reload() 方法可以重新加载当前文档(即刷新页面)。在不传递任何参数的情况下,它将以最新的内容重新加载当前URL。 // 简洁版 location.reload(); // 带有强制刷新参数的完整版 location.reload…

    JavaScript 2023年6月11日
    00
  • JavaScript window.setTimeout() 的详细用法

    JavaScript window.setTimeout() 的详细用法 在 JavaScript 中,window.setTimeout() 方法可以定时执行一个指定的代码块。它接收两个参数,分别是需要执行的代码块和执行时间(单位为毫秒)。 语法 window.setTimeout(code, delay); 其中,code 为需要执行的代码块;delay…

    JavaScript 2023年6月11日
    00
  • js动态设置div的值下例子

    下面让我来详细讲解“js动态设置div的值”的完整攻略。 基本概念 在开始具体的实现代码之前,我们先来了解一下这个问题的基本概念。 动态设置div的值:指的是通过JavaScript脚本代码实现在网页中的某个元素(如div)中动态设置内容,而不是直接在HTML代码中写死。 实现过程 实现动态设置div的值可以分为以下两个步骤: 1. 获取div元素 在Jav…

    JavaScript 2023年6月11日
    00
  • JavaScript 对象管家 Proxy

    JavaScript 对象管家 Proxy 的完整攻略 Proxy 概述 Proxy 是 ES6 所引入的一个内置对象,它用于通过一个代理来控制对另一个对象(目标对象)的访问。被代理的对象可以是任意一个对象。通过定义一系列的 trap 方法,可以在代理对象访问目标对象时截获操作并进行相应处理。 Proxy 的基本使用 在代码中使用 Proxy 时,首先需要创…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部