用javascript解析id?

时间:2012-07-27 00:28:04

标签: javascript jquery regex variables

我如何解析id,将此id="type=2owner=6page=1"转换为此内容:

var type = "2"; // or what ever is after type= but before owner=
var owner = "6"; // or what ever is after owner= but before page=
var page = "1"; // or what ever is after page=

数字并不总是相同或单个数字。

3 个答案:

答案 0 :(得分:4)

可以完成你想要做的事情,但你几乎肯定会使用数据属性。

不要将数据打包到id属性中,而是使用单独的data-属性:

<div id="my-div" data-type="2" data-owner="6" data-page="1" />

jQuery为您提供了一种非常简单的语法来访问元素的数据属性:

$('#my-div').data('type');  // "2"
$('#my-div').data('owner'); // "6"
$('#my-div').data('page');  // "1"

或者,更改/添加新数据属性:

$('#my-div').data("name", "bob"); // <div .... data-name="bob" />

如果您无法向标记添加数据属性(例如,如果您只使用HTML而不生成它),则可以使用正则表达式将id属性分开:< / p>

var id = "type=2owner=6page=1";

id.match(/type=(\d+)/);  // ["type=1", "1"]
id.match(/owner=(\d+)/); // ["owner=6", "6"]
id.match(/page=(\d+)/);  // ["page=2", "2"]

上述任何一个都会返回一个两元素数组,其中第二个元素是有问题的数字。

答案 1 :(得分:1)

var id = document.getElementById(...).getAttribute("id").split(/=/g);
var type = id[1];
var owner = id[3];
var page = id[5];

答案 2 :(得分:1)

您可以尝试更具伸缩性的内容。这将创建一个包含所有关键字或术语及其值的漂亮对象,并且可以通过更多术语轻松扩展。

var id = 'type=2owner=6page=1'
var terms = ['type', 'owner', 'page']
var results = {}

for (var i = 0, n = terms.length, m, re; i < n; i++) {
  m = terms[i]
  re = new RegExp(m + '=(\\d+)', 'i')
  results[m] = re.exec(id)[1]
}

console.log(results) // { type: 2, owner: 6, page: 1 }