js 获取到左右小括号里面的内容
要获取 JavaScript 字符串中左右小括号内的内容,您可以使用正则表达式配合 match
方法来实现。以下是一个示例代码:
const str = '这是一个包含小括号内内容的字符串 (Hello World)。';
// 使用正则表达式匹配小括号内的内容
const regex = /\((.*?)\)/g; // 使用非贪婪模式匹配
const matches = str.match(regex);
// 提取小括号内的内容
const contents = matches.map(match => match.replace(/\(|\)/g, ''));
console.log(contents); // 输出:["Hello World"]
在上面的代码中,我们定义了一个正则表达式 /(\(.*?\))/g
,用于匹配字符串中的小括号内容。使用 str.match
方法将匹配结果存储在 matches
数组中。
然后,我们使用 .map
方法遍历 matches
数组,通过正则表达式 /(\(|\))/g
替换掉小括号。contents
数组存储了从小括号中提取出的内容。
请注意,在上面的示例中,我们使用了非贪婪模式(*?
)来匹配最短可能的内容。这意味着如果有多个小括号,每对小括号中的内容都会被匹配和提取。
什么是非贪婪模式:
非贪婪模式,也被称为懒惰模式或最小匹配模式,是正则表达式的一种模式匹配方式。
在正则表达式中,当使用量词(例如 *
或 +
)来匹配重复的模式时,默认情况下,它们是贪婪的,会尽可能地匹配最长的字符串。而非贪婪模式则相反,它会尽可能匹配最短的字符串。
非贪婪模式可以通过在量词后面添加 ?
来实现。例如,*?
表示匹配前面的模式零次或多次,但尽可能少次数地匹配。类似地,+?
表示匹配前面的模式一次或多次,但尽可能少次数地匹配。
以下是一个示例,展示了贪婪模式和非贪婪模式的区别:
const str = "aaaab";
const greedyRegex = /a+/;
const lazyRegex = /a+?/;
console.log(str.match(greedyRegex)); // 输出: ["aaaa"]
console.log(str.match(lazyRegex)); // 输出: ["a"]
在上面的示例中,字符串 str
中的模式 /a+/
使用贪婪模式进行匹配,输出结果是匹配到的最长字符串 "aaaa"
。而模式 /a+?/
使用非贪婪模式进行匹配,输出结果只匹配到了最短的字符串 "a"
。
非贪婪模式在某些情况下非常有用,尤其是在需要捕获特定部分的情况下。通过使用 ?
来指定非贪婪模式,可以更精确地控制正则表达式的匹配行为。