21

我试图让一个正则表达式接受 < 和 > 作为我的外部分隔符来获取它们之间的所有内容。

所以像这样的内容

< tfdsfa  >

应该抓住。

我是否必须转义 < 和 > 字符或什么?

我的脚本生成的正则表达式:

/<[^(>)]*>/g

文件中的代码:

data.method.highlight = function() {
    var x = data.syntax,
        text = data.$.span.html();
    for (var i=0, len = x.length; i < len; i++) {
        var rx;
        if (x[i].range) {
            rx = new RegExp(x[i].tag[0] + "[^(" + x[i].tag[1] + ")]*" + x[i].tag[1], "g");
            console.log(rx);
        }
        else {
            var temprx = x[i].tag[0];
            for (var z = 1; z < x[i].tag.length; z++) {
                temprx += "|" + x[i].tag[z];
            }
            rx = new RegExp(temprx, "g");
        }
        text = text.replace(rx,function (match) {
            console.log("looping - range");
            return '<span class="' + x[i].class.default + '">' + match + '</span>';
        });
        data.$.span.html(text);
    }
};
4

2 回答 2

24

正则表达式中既不是元字符<也不是元字符。>

这对我有用:

'<foo> and <bar>'.match(/<[^>]*>/g); // ["<foo>", "<bar>"]
于 2012-04-10T19:22:18.340 回答
-1

当您尝试将结果插入 HTML 并且浏览器认为它不是有效的 HTML 标记时,您可能会遇到问题,例如<blablabla>.

于 2016-08-23T11:38:51.657 回答