我正在做一个有javascript提供的一些交互的页面。举个例子:发送AJAX请求以获取文章内容的链接,然后在div中显示该数据。显然,在这个例子中,我需要每个链接存储一个额外的信息:文章的id。我处理它的方法是把这些信息放在href链接中:

<a class="article" href="#5">

然后使用jQuery找到a.article元素并附加适当的事件处理程序。(不要太纠结于可用性或语义,这只是一个例子)

不管怎样,这个方法是有效的,但是有点臭,而且根本不能扩展(如果click函数有多个参数会发生什么?如果其中一些参数是可选的呢?)

显而易见的答案是在元素上使用属性。我是说,这就是它们的作用,对吧?(种)。

<a articleid="5" href="link/for/non-js-users.html">

在我最近的问题中,我问这个方法是否有效,结果证明,如果不定义我自己的DTD(我没有),那么不,它是无效或不可靠的。一种常见的响应是将数据放入class属性中(尽管这可能是因为我选择的示例不佳),但对我来说,这种方法更有味道。是的,它在技术上是有效的,但它不是一个很好的解决方案。

我过去使用的另一种方法是实际生成一些JS,并将其插入到页面中的<script>标记中,创建一个与对象关联的结构。

var myData = {
    link0 : {
        articleId : 5,
        target : '#showMessage'
        // etc...
    },
    link1 : {
        articleId : 13
    }
};

<a href="..." id="link0">

但这是一个真正痛苦的屁股维护,通常只是非常混乱。

那么,要回答这个问题,如何为HTML标记存储任意信息?


当前回答

如果你已经在使用jQuery,那么你应该利用“data”方法,这是使用jQuery在dom元素上存储任意数据的推荐方法。

储存:储存某物:

$('#myElId').data('nameYourData', { foo: 'bar' });

检索数据:

var myData = $('#myElId').data('nameYourData');

这就是jQuery的全部内容,但是请查看jQuery文档以获得更多信息/示例。

其他回答

作为jQuery用户,我会使用元数据插件。HTML看起来很干净,可以进行验证,并且可以嵌入任何可以使用JSON符号描述的内容。

我的回答可能不适用于你的情况。我需要在HTML中存储一个2D表,并且我需要用最少的按键操作。下面是我的HTML数据:

<span hidden id="my-data">
    IMG,,LINK,,CAPTION
    mypic.jpg,,khangssite.com,,Khang Le
    funnypic.jpg,,samssite.com,,Smith, Sam
    sadpic.png,,joyssite.com,,Joy Jones
    sue.jpg,,suessite.com,,Sue Sneed
    dog.jpg,,dogssite.com,,Brown Dog
    cat.jpg,,catssite.com,,Black Cat
</span>

解释

It's hidden using hidden attribute. No CSS needed. This is processed by Javascript. I use two split statements, first on newline, then on double-comma delimiter. That puts the whole thing into a 2D array. I wanted to minimize typing. I didn't want to redundantly retype the fieldnames on every row (json/jso style), so i just put the fieldnames on the first row. That a visual key for the programmer, and also used by Javascript to know the fieldnames. I eliminated all braces, brackets, equals, parens, etc. End-of-line is record delimiter. I use double-commas as delimiters. I figured no one would normally use double-commas for anything, and they're easy to type. Beware, programmer must enter a space for any empty cells, to prevent unintended double-commas. The programmer can easily use a different delimiter if they prefer, as long as they update the Javascript. You can use single-commas if you're sure there will be no embedded commas within a cell. It's a span to ensure it takes up no room on the page.

下面是Javascript代码:

// pull 2D text-data into array
let sRawData = document.querySelector("#my-data").innerHTML.trim();

// get headers from first row of data and load to array. Trim and split.
const headersEnd = sRawData.indexOf("\n");
const headers = sRawData.slice(0, headersEnd).trim().split(",,");

// load remaining rows to array. Trim and split.
const aRows = sRawData.slice(headersEnd).trim().split("\n");

// trim and split columns
const data = aRows.map((element) => {
    return element.trim().split(",,");
});

解释:

JS使用大量的修饰来消除任何额外的空白。

为什么不利用已有的有意义的数据,而不是添加任意的数据呢?

例如,使用<a href="/articles/5/page-title" class="article-link">,然后你可以通过编程方式获得页面上的所有文章链接(通过classname)和文章ID(匹配regex /articles\/(\d+)/ against this.href)。

你使用的是哪个版本的HTML ?

在HTML 5中,使用data-作为前缀的自定义属性是完全有效的。

<div data-internalid="1337"></div>

在XHTML中,这实际上是无效的。如果您使用的是XHTML 1.1模式,浏览器可能会报错,但在1.0模式下,大多数浏览器会默默地忽略它。

如果我是你,我会遵循基于脚本的方法。您可以让它在服务器端自动生成,这样维护起来就不那么麻烦了。

在html中,我们可以存储自定义属性,在属性名之前加上“data-”前缀

<p data-animal='dog'>这个动物是一只狗。 检查文档

我们可以使用这个属性使用jQuery动态设置和获取属性,例如: 如果我们有一个p标签

<p id='animal'>这个动物是一只狗

然后为上面的标签创建一个名为'breed'的属性,我们可以这样写:

$(" #动物”)。attr(“data-breed”、“哈巴狗”);

为了随时检索数据,我们可以这样写:

var breedtype = $('#animal').data('breed');