使用正则表达式提取数据

时间:2012-11-24 19:52:55

标签: javascript regex

给定以下字符串,如何在数据选择后的引号(即THIS-DATA)之间提取字符串。无论是使用单引号还是双引号,或者在等号之前或之后是否有任何空格,我都希望它能够工作。谢谢

<td><img alt="abc" src="lib/templates/administrator/images/star.png" data-selected="THIS_DATA" title="None" class="vtip"></td>

3 个答案:

答案 0 :(得分:1)

你能用jQuery吗?不确定为什么需要使用正则表达式。

var $el = $(".vtip");
var data = $el.attr('data-selected');

或原生javascript:

var el = document.querySelector(".vtip");
var data = el.getAttribute('data-selected');

或带有数据集的原生javascript:

var el = document.querySelector(".vtip");
var data = el.dataset.selected;

使用数据集的更多信息: https://developer.mozilla.org/en-US/docs/DOM/element.dataset

答案 1 :(得分:1)

简单正则表达式,假设THIS_DATA不包含引号:

var reg = /data-selected\s*=\s*["']([^"']*)["']/;

使用:

function extractData(yourString) {
    var match = str.match(yourString);
    return match ? match[1] : "";
}

修改

甚至更简单:

var data = str.replace(/.*data-selected\s*=\s*["']([^"']*)["'].*/, "$1");

答案 2 :(得分:0)

您可以将字符串解析为dom

var xmlStr = '<td><img alt="abc" src="lib/templates/administrator/images/star.png" data-selected="THIS_DATA" title="None" class="vtip"></td>';
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlStr, "text/xml");

var path = 'img/@data-selected';

var nodes = xmlDoc.evaluate(path, xmlDoc, null, XPathResult.ANY_TYPE, null);


var result = nodes.iterateNext();
var data-selected  = result.textContent;