我正在做一个有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标记存储任意信息?


当前回答

所以应该有四种选择:

将数据放在id属性中。 将数据放在任意属性中 将数据放在class属性中 将数据放在另一个标记中

http://www.shanison.com/?p=321

其他回答

这是个好建议。感谢@Prestaul

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

非常正确,但是如果您想在普通的HTML中存储任意数据呢?还有另一种选择……

<input type="hidden" name="whatever" value="foobar"/>

将数据放在隐藏输入元素的name和value属性中。如果服务器正在生成HTML(即PHP脚本或其他东西),而您的JavaScript代码稍后将使用此信息,那么这可能是有用的。

不可否认,它不是最干净的,但它是一种选择。它与所有设备都兼容 浏览器,是有效的XHTML。你不应该使用自定义属性,也不应该使用带有“data-”前缀的属性,因为它可能不适用于所有浏览器。此外,您的文档将无法通过W3C验证。

另一种方法是将key:value对存储为一个简单的类,使用以下语法:

<div id="my_div" class="foo:'bar'">...</div>

这是有效的,可以很容易地用jQuery选择器或自定义函数检索。

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

这就是我怎么做你ajax页面…这是一个非常简单的方法…

    function ajax_urls() {
       var objApps= ['ads','user'];
        $("a.ajx").each(function(){
               var url = $(this).attr('href');
               for ( var i=0;i< objApps.length;i++ ) {
                   if (url.indexOf("/"+objApps[i]+"/")>-1) {
                      $(this).attr("href",url.replace("/"+objApps[i]+"/","/"+objApps[i]+"/#p="));
                   }
               }
           });
}

它的工作原理是,它基本上会查看所有具有'ajx'类的url,它会替换关键字并添加#符号…所以如果js被关闭了,那么url就会像往常一样…所有“应用程序”(网站的每个部分)都有自己的关键字……所以我所需要做的就是添加到js数组上面添加更多的页面…

例如,我的当前设置设置为:

 var objApps= ['ads','user'];

因此,如果我有一个url,如:

www.domain.com/ads/3923/bla/dada/bla

js脚本将取代/ads/部分,所以我的URL将结束

www.domain.com/ads/ p = 3923 /爸爸/ bla bla

然后我使用jquery bbq插件加载相应的页面…

http://benalman.com/projects/jquery-bbq-plugin/

一个几乎适用于所有可能的浏览器的黑客是使用这样的开放类:< A class='data\_articleid\_5' href="link/for/non-js-users.html>;

对于纯粹主义者来说,这并不是那么优雅,但它得到了普遍支持,符合标准,并且非常容易操作。这似乎是最好的方法了。如果你序列化,修改,复制你的标签,或者做其他任何事情,数据将保持附加,复制等。

唯一的问题是您不能以这种方式存储不可序列化的对象,如果您在那里放置非常大的对象,可能会有限制。

第二种方法是使用伪属性,例如:< A articleid='5' href="link/for/non-js-users.html">

这更优雅,但不符合标准,而且我不能100%确定是否支持。许多浏览器完全支持它,我认为IE6支持JS访问,但不支持CSS选择器(在这里这并不重要),可能有些浏览器会完全混淆,你需要检查一下。

做一些有趣的事情,比如序列化和反序列化,会更加危险。

使用id到纯JS散列通常是可行的,除非你试图复制你的标记。如果你有tag <a href="…" id="link0">,通过标准的JS方法复制它,然后尝试修改附加到一个副本的数据,另一个副本也会被修改。

如果不复制标记或使用只读数据,这不是问题。如果你复制标签,它们被修改了,你需要手动处理。