我如何解析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=
数字并不总是相同或单个数字。
答案 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 }