gpt4 book ai didi

javascript - 如何通过正则表达式获取 @import 语句中的 URL

转载 作者:行者123 更新时间:2023-11-29 20:48:17 26 4
gpt4 key购买 nike

我使用这个 Reguler Expression 来获取 CSS 文本的 @import 语句(如果有的话)。这很成功,例如:

RegExp:
(?:^|\s)?(?:@import)(?:\s)(?:url)?(?:(?:(?:\()(["'])?(?:[^"')]+)\1(?:\))|(["'])(?:.+)\2)(?:[A-Z\s])*)+(?:;)

Input:
@import url('https://meyerweb.com/eric/tools/css/reset/reset200802.css');@import url('http://opdetect.com/x/1-2-2.css');:root{--blue:#007bff;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#fd7e14;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#6c757d;--gray-dark:#343a40;--primary:#007bff;--secondary:#6c757d;--success:#28a745;--info:#17a2b8;--warning:#ffc107;--danger:#dc3545;--light:#f8f9fa;--dark:#343a40;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";--font-family-monospace:SFMono-Regular,Menlo,Monaco,Consolas,\"Liberation Mono\",\"Courier New\",monospace}

Result:
@import url('https://meyerweb.com/eric/tools/css/reset/reset200802.css');
@import url('http://opdetect.com/x/1-2-2.css');

但是,我想要这样的结果;

Expected Result:
https://meyerweb.com/eric/tools/css/reset/reset200802.css
http://opdetect.com/x/1-2-2.css

我该怎么做?

最佳答案

您可以使用这个基于您的正则表达式:

(?:^|\s)?(?:@import)(?:\s)(?:url)?(?:(?:(?:\()(["'])?(?:https?:)?([^"')]+)\1(?:\))|(["'])(?:.+)\2)(?:[A-Z\s])*)+(?:;)

我已将非捕获组更改为捕获组,并创建了一个包含“https?:”的新非捕获组。

您需要设置'global' 标志。

您想要的结果将在第 2 组中。

编辑,根据您更改后的期望结果('http:' 现在包含在匹配中):

(?:^|\s)?(?:@import)(?:\s)(?:url)?(?:(?:(?:\()(["'])?([^"')]+)\1(?:\))|(["'])(?:.+)\2)(?:[A-Z\s])*)+(?:;)

编辑(发现错误,修改了后面的引用):

(?:^|\s)?(?:@import)(?:\s)(?:url)?(?:(?:(?:\()(["'])?([^"')]+)\1(?:\))|(["'])(.+)\3)(?:[A-Z\s])*)+(?:;)

您的结果将在 Group 2 或 Group 4 中。

使用方法:

var input = 'your css';
var regex = / (?:^|\s)?(?:@import)(?:\s)(?:url)?(?:(?:(?:\()(["'])?([^"')]+)\1(?:\))|(["'])(.+)\3)(?:[A-Z\s])*)+(?:;)/g;
var matches = regex.exec(input);
for (var i = 0; i < matches.length; i++)
{
var output = matches[i][2] + matches[i][4]; // one will be blank
Console.WriteLine(output);
}

关于javascript - 如何通过正则表达式获取 @import 语句中的 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53333580/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com