这是我最近一直在使用的一种技术:
<div id="someelement">
    <!-- {
        someRandomData: {a:1,b:2},
        someString: "Foo"
    } -->
    <div>... other regular content...</div>
</div>
注释对象与父元素(即#someelement)绑定。
这是解析器:http : //pastie.org/511358
要获取任何特定元素的数据,只需调用parseData对该元素的引用作为唯一参数即可:
var myElem = document.getElementById('someelement');
var data = parseData( myElem );
data.someRandomData.a; // <= Access the object staight away
可能比这更简洁:
<li id="foo">
    <!--{specialID:245}-->
    ... content ...
</li>
访问它:
parseData( document.getElementById('foo') ).specialID; // <= 245
使用此功能的唯一缺点是,它不能与自动关闭元素(例如<img/>)一起使用,因为注释必须位于该元素内才能被视为该元素的数据。
编辑:
该技术的显着优势:
- 易于实施
- 难道不无效HTML / XHTML
- 易于使用/理解(基本JSON表示法)
- 比大多数替代品毫不干扰且语义上更清洁
这是解析器代码(从上方的http://pastie.org/511358复制,以防在pastie.org上变得不可用):
var parseData = (function(){
    var getAllComments = function(context) {
            var ret = [],
                node = context.firstChild;
            if (!node) { return ret; }
            do {
                if (node.nodeType === 8) {
                    ret[ret.length] = node;
                }
                if (node.nodeType === 1) {
                    ret = ret.concat( getAllComments(node) );
                }
            } while( node = node.nextSibling );
            return ret;
        },
        cache = [0],
        expando = 'data' + +new Date(),
        data = function(node) {
            var cacheIndex = node[expando],
                nextCacheIndex = cache.length;
            if(!cacheIndex) {
                cacheIndex = node[expando] = nextCacheIndex;
                cache[cacheIndex] = {};
            }
            return cache[cacheIndex];
        };
    return function(context) {
        context = context || document.documentElement;
        if ( data(context) && data(context).commentJSON ) {
            return data(context).commentJSON;
        }
        var comments = getAllComments(context),
            len = comments.length,
            comment, cData;
        while (len--) {
            comment = comments[len];
            cData = comment.data.replace(/\n|\r\n/g, '');
            if ( /^\s*?\{.+\}\s*?$/.test(cData) ) {
                try {
                    data(comment.parentNode).commentJSON =
                        (new Function('return ' + cData + ';'))();
                } catch(e) {}
            }
        }
        return data(context).commentJSON || true;
    };
})();