首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JavaScript RegEx On Styles

JavaScript RegEx On Styles
EN

Stack Overflow用户
提问于 2013-02-09 02:07:20
回答 2查看 108关注 0票数 2

我正在尝试使用regex从元素样式中删除所有的"color“样式,但我失败得很痛苦。

样式示例

代码语言:javascript
复制
cursor: pointer;background-color: yellow;color: lightgray;

样式应该变成什么样子的示例

代码语言:javascript
复制
cursor: pointer;background-color: yellow;

这是我正在使用的正则表达式color:[^;]+;

它捕获背景颜色并删除背景之后的部分。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-02-09 02:10:22

这个正则表达式适用于我:

代码语言:javascript
复制
[\s;]color:[^;]+(?=;)|^color:[^;]+;

您将看到它处理第一个参数时的处理方式有所不同。

代码语言:javascript
复制
var style = "cursor: pointer;background-color: yellow;color: lightgray;";
var replaced = style.replace(/[\s;]color:[^;]+(?=;)|^color:[^;]+;/g, '')

请注意,即使在这里使用正则表达式并不是那么糟糕,使用一个简单的splitting+filtering也可以更自信地完成此操作:

代码语言:javascript
复制
var replaced = style.split(';').filter(function(v){
   return v.split(':')[0].trim()!='color'
}).join(';');
票数 2
EN

Stack Overflow用户

发布于 2013-02-21 07:42:52

困难的是,解决方案只有一个小问题来处理背景图像与base64输入。我只是想添加正则表达式来拆分样式

代码语言:javascript
复制
arr = s.match(/background-image\s*:\s*url\s*\(\s*data:image[^)]+\)?|[a-zA-Z-]+:[^;]+/gi);

这将为您提供一个包含所有元素的数组。到目前为止,它是有效的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14778703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档