替换RegExp - 负面模式 [英] Replace RegExp - negative pattern

查看:73
本文介绍了替换RegExp - 负面模式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有'contenteditable'的div。我想在这个div中过滤char,当 [^± - źa-z0-9 \ s] AND NOT(& amp; sbsp)时,我必须更改颜色字符,与模式不匹配。
例如,当我得到 $(this).html():$ b $bdfgtąść45%$# tg& nbsp ; ss & k ; - 我想更改为红色粗体字符。

I have div with 'contenteditable'. I would like filter char in this div, and when is [^ą-źa-z0-9\s] AND NOT ( ), I must change color char, don't match the pattern. For example, when I get $(this).html(): dfgtąść45%$#tg ss&k; - I would like change to red color bold char.

JS:

var t = $(this).html().replace(/<\/?[^>]+>/gi, '').replace(/\s$/, '&nbsp;');
t = t.replace(/(&nbsp;)[^ą-źa-z0-9\s]/ig,function(match){return '<span style="color: red;">' + match + "</span>";});
$(this).html(t);


推荐答案

这是一种方式

t = t.replace( /(&nbsp;)|(?:(?!&nbsp;)[^ą-źa-z0-9\s])+/ig,
    function ( match, nbsp ) {
        return nbsp ? nbsp : '<span style="color: red;">' + match + "</span>";
});

请注意,不建议以这种方式操纵html:例如,元素属性中的任何字符匹配否定的字符类将被错误地包含在 span 标记中。

Note though that manipulating html in this way is not recommended: for example, any characters within element attributes which match the negated character class would be mistakenly enclosed in span tags.

这篇关于替换RegExp - 负面模式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆