javascript截取两个符号之间的字符串(2):lastIndexOf匹配和正则表达式匹配

简介: javascript截取两个符号之间的字符串(2):lastIndexOf匹配和正则表达式匹配

项目需求

  • javascript中截取字符串中最后一个“/”和“?”之间的内容。

1.规范的字符串

https://test.com/p/course/column/p_64a7738ce4b0b0bc2bfcebaa?shareBind=true


function extractContent(url) {
  const lastSlashIndex = url.lastIndexOf('/');
  const lastQuestionMarkIndex = url.lastIndexOf('?');
  if (lastSlashIndex === -1 || lastQuestionMarkIndex === -1 || lastQuestionMarkIndex < lastSlashIndex) {
    return '';
  }
  const content = url.substring(lastSlashIndex + 1, lastQuestionMarkIndex);
  return content;
}
// 示例用法
const url = "https://test.com/p/course/column/p_64a7738ce4b0b0bc2bfcebaa?shareBind=true";
const extractedContent = extractContent(url);
console.log(extractedContent); // 输出: p_64a7738ce4b0b0bc2bfcebaa


在上述代码中,我们先使用lastIndexOf方法找到最后一个斜杠和问号的索引位置。然后,我们检查这两个索引位置是否有效,确保斜杠位于问号之前。如果索引位置无效,则返回空字符串。最后,我们使用substring方法截取位于斜杠之后、问号之前的内容,并返回结果。


请注意,上述代码仅考虑了截取最后一个斜杠和问号之间的内容。如果URL中没有斜杠或问号,或者它们的顺序不正确,提取的内容可能会有误。


2.不规范的字符串

如果提供的地址字符串不包含“?”时:

https://test.com/p/course/column/p_64a7738ce4b0b0bc2bfcebaa

function extractContent(url) {
  const lastSlashIndex = url.lastIndexOf('/');
  if (lastSlashIndex === -1) {
    return url;
  }
  const content = url.substring(lastSlashIndex + 1);
  return content;
}
// 示例用法
const url = "https://test.com/p/course/column/p_64a7738ce4b0b0bc2bfcebaa";
const extractedContent = extractContent(url);
console.log(extractedContent); // 输出: p_64a7738ce4b0b0bc2bfcebaa


3-1.万能封装

function extractContent(url) {
  var lastSlashIndex = url.lastIndexOf('/');
  var lastQuestionMarkIndex = url.lastIndexOf('?');
  var content='';
  //存在斜杠时
  if (lastSlashIndex != -1) {
    content = url.substring(lastSlashIndex + 1, lastQuestionMarkIndex);
  }
  //不存在问号时
   if (lastQuestionMarkIndex === -1) {
   content = url.substring(lastSlashIndex + 1);
  }
  return content;
}
// 示例用法
const url = "https://test.com/p/course/column/p_64a7738ce4b0b0bc2bfcebaa";
const extractedContent = extractContent(url);
console.log(extractedContent); // 输出: p_64a7738ce4b0b0bc2bfcebaa


3-2.ChatGPT的优化写法

可以使用 `lastIndexOf` 和 `substring` 方法来实现截取字符串中最后一个斜杠(/)和问号(?)之间的内容:
```javascript
function extractContent(url) {
  const lastSlashIndex = url.lastIndexOf('/');
  const lastQuestionMarkIndex = url.lastIndexOf('?');
  if (lastQuestionMarkIndex !== -1) {
    return url.substring(lastSlashIndex + 1, lastQuestionMarkIndex);
  }
  return url.substring(lastSlashIndex + 1);
}
// 示例用法
const url1 = "https://www.example.com/path/to/file?param=value";
const url2 = "https://www.example.com/path/to/file";
const extractedContent1 = extractContent(url1);
const extractedContent2 = extractContent(url2);
console.log(extractedContent1); // 输出: file
console.log(extractedContent2); // 输出: file


在上述代码中,我们首先使用 lastIndexOf 方法找到最后一个斜杠和问号的索引位置。然后,我们使用两个索引位置来判断是否存在问号。如果存在问号,则使用 substring 方法从最后一个斜杠的下一个位置开始截取到最后一个问号的位置之间的内容。如果不存在问号,则使用 substring 方法从最后一个斜杠的下一个位置开始截取到字符串的末尾的内容。


这种写法也能够正确地截取最后一个斜杠和问号之间的内容。在示例用法中,两个 URL 都会输出结果 “file”。


4.正则表达式的用法

function extractContent(url) {
  const regex = /\/([^/?]+)\??.*$/;
  const match = url.match(regex);
  if (match) {
    return match[1];
  }
  return '';
}
// 示例用法
const url1 = "https://www.example.com/path/to/file?param=value";
const url2 = "https://www.example.com/path/to/file";
const extractedContent1 = extractContent(url1);
const extractedContent2 = extractContent(url2);
console.log(extractedContent1); // 输出: file
console.log(extractedContent2); // 输出: file

在上述代码中,我们使用正则表达式来匹配最后一个斜杠和问号之间的内容。正则表达式 /\/([^/?]+)\??.*$/ 匹配的规则如下:


\/:匹配一个斜杠。

([^/?]+):匹配除了斜杠和问号之外的连续字符,并将其捕获为分组。

\??:匹配一个可选的问号。

.*$:匹配剩余的任意字符。

然后,我们使用字符串的 match 方法并传入正则表达式来查找匹配项。如果有匹配项,则返回第一个捕获分组内容 (match[1]),即最后一个斜杠和问号之间的内容。如果没有匹配项,则返回空字符串。在示例用法中,两个 URL 都会输出结果 “file”。


5.补充知识:lastIndexOf的用法

lastIndexOf 是 JavaScript 字符串的一个方法,用于返回指定字符或子字符串在原始字符串中最后一次出现的位置索引。

语法:

string.lastIndexOf(searchValue[, fromIndex])


参数说明:


searchValue:要搜索的字符或子字符串。

fromIndex(可选):从哪个位置开始向前搜索。默认为字符串的末尾(即 string.length - 1)。

返回值:


如果找到匹配的字符或子字符串,则返回最后一次出现的索引位置。

如果未找到匹配的字符或子字符串,则返回 -1。


示例用法:

const str = 'Hello, World!';
const lastIndex = str.lastIndexOf('o');
console.log(lastIndex); // 输出: 8
const lastIndex2 = str.lastIndexOf('o', 7);
console.log(lastIndex2); // 输出: 4
const lastIndex3 = str.lastIndexOf('JavaScript');
console.log(lastIndex3); // 输出: -1

在上面的示例中,我们使用 lastIndexOf 方法搜索字符串中最后一次出现的字符 'o' 的索引位置。第一个 lastIndex 示例返回 8,因为最后一个 'o' 在索引位置 8 处。第二个 lastIndex2 示例中,我们通过将 fromIndex 参数设置为 7 来指定了搜索的起始位置,结果返回 4,因为最后一个 'o' 在索引位置 4 处。最后一个 lastIndex3 示例中,我们搜索了一个不存在的子字符串 'JavaScript',因此返回 -1。根据需求使用 lastIndexOf 方法来查找字符串中最后一次出现的字符或子字符串的位置。



@漏刻有时

目录
打赏
0
0
0
0
184
分享
相关文章
JS几种拼接字符串的方法
JS几种拼接字符串的方法
69 1
如何使用这个正则表达式来验证一个字符串是否符合特定的格式要求?
如何使用这个正则表达式来验证一个字符串是否符合特定的格式要求?
JavaScript字符串的常用方法
在JavaScript中,字符串处理是一个非常常见的任务。JavaScript提供了丰富的字符串操作方法,使开发者能够高效地处理和操作字符串。本文将详细介绍JavaScript字符串的常用方法,并提供示例代码以便更好地理解和应用这些方法。
35 13
模板字符串和普通字符串在浏览器和 Node.js 中的性能表现是否一致?
综上所述,模板字符串和普通字符串在浏览器和 Node.js 中的性能表现既有相似之处,也有不同之处。在实际应用中,需要根据具体的场景和性能需求来选择使用哪种字符串处理方式,以达到最佳的性能和开发效率。
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
35 2
U4字符串以及正则表达式
【10月更文挑战第19天】在 Java 中,字符串是重要数据类型,支持多种操作如长度获取、字符访问、子串提取等。正则表达式提供强大的模式匹配和文本处理功能,通过 `Pattern` 和 `Matcher` 类实现。示例代码展示了如何使用正则表达式匹配单词字符。常用语法包括字符类、数量词、边界匹配和分组。
电话号码正则表达式 代码 javascript+html,JS正则表达式判断11位手机号码
电话号码正则表达式 代码 javascript+html,JS正则表达式判断11位手机号码
147 1
JavaScript 字符串(String) 对象
JavaScript 字符串(String) 对象
51 3
前端JS实现密码校验键盘横竖、26字母、相同字母、相同数字、密码包含用户名、数字 字母不能连续 不能相同三个、不能横向 竖向 连续三个 包含字符、不能有中文符号
该 JavaScript 代码实现了一个严格的密码校验功能,确保密码满足多种安全要求,包括长度、字符类型、不包含中文及特殊字符、不与用户名相似等。通过多个辅助函数,如 `validateFormat` 检查密码格式,`isHasChinaCharFun` 检测中文符号,`getCharAll` 生成键盘组合,以及 `checkPasswordFun` 综合验证密码的有效性和安全性。此工具对于提高用户账户的安全性非常有用。
108 0
JavaScript用indexOf()在字符串数组中查找子串时需要注意的一个地方
JavaScript用indexOf()在字符串数组中查找子串时需要注意的一个地方
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等