最近 jQuery 更新到 1.6 版,雖然我沒有在用
可是還是測試看看新功能
結果發現新的 data 功能有 bug

jQuery 1.6 data() bug demo code:

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>jQuery 1.6 data() Bug</title>
<script type="text/javascript" src="jquery-1.6.js"></script>
<script type="text/javascript">
$(function () {
 $("span").each(function(){
  console.log(JSON.stringify($(this).data()));
 });
});
</script>
</head>
<body>
<span data-x="data" />
<span data-x-x="data" />
<span data-x-x-x="data" />
<span data-x-xx-x="data" />
</body>
</html>

用 Chrome 瀏覽器執行輸出結果

{"x":"data"}
{"xX":"data"}
{}
{"xXxX":"data"}

實在令人搞不懂,為什麼 data attribute 這樣寫 data-x-x-x 就不能 parse 了呢?
其它三個類似的寫法卻又可以正常 work