- From: Kang-Hao (Kenny) Lu <kennyluck@w3.org>
- Date: Tue, 07 Jun 2011 12:08:06 +0800
- To: 中文HTML5同樂會ML <public-html-ig-zh@w3.org>
最近的一個大新聞是 Google、Microsoft Bing 跟 Yahoo! 推出了 schema.org 的 語意搜尋用的 Microdata 字彙庫[1]。撇開到底 Facebook Open Graph Protocol 跟 schema.org 的 Microdata 到底能不能一起用這個大家雖然都關心但是 FAQ[2] 還無解的問題,這個新聞讓我認真的去看了一下 Microdata 提供的 DOM API,想 跟大家討論一下跟 Microdata 標準[3]裡面的一些問題。 [1] http://schema.org/ [2] http://schema.org/docs/faq.html [3] http://dev.w3.org/html5/md/#dom-itemid 1. 規範寫到,要用 itemtype 就一定要先有 itemscope 屬性,而要用 itemid 就 一定要先有 itemtype 屬性,問題是 itemscope 除了標示說這是一個 "item" 以 外,似乎沒有其他功能,加上文檔如果要合乎 XHTML5 的語法的話,勢必要寫冗長 的 itemscope="itemscope" 。 我個人是覺得在有 itemtype 的時候 itemscope 可以省略,不過根據 HTML5 編輯 Ian Hickson 跟 Google 做的可用性測試,不省使用者比較不會出錯。我強烈懷疑 這個結果、、 2. document.getItems(type) - 回傳有某 itemtype 的 item(也就是 HTML 元素) a. 規範寫到它只回傳「頂層」的 item,也就是沒有 itemprop 屬性的 item。 我可以理解這項決定的好處跟壞處,壞處是這似乎是這有一點讓人意外,好處是如 果要全部的 item 而不是只有頂層的,似乎用 document.querySelectorAll("[itemtype=TYPE"]) 就好了,就不需要多一個 API 了。 b. 除了 document.getItems 以外,該不該有 element.getItems,不過有這個 的話,須不需要更改「頂層」的定義。 3. 該不該有 document.getItemById?還是用 document.querySelector("[itemid=ID") 就好? 我覺得這些 API 的好處是似乎可以在不更改AJAX JS 碼的情形下更改頁面的 HTML 設計,比如說我每次要更改微博狀態: var statusObj = ... // 先得到一個 JSON 物件 (現在流行用 JSON 嗎?還是直 接 AJAX 傳 HTML 比較多?) var newItem = document.getItems("status")[0].cloneNode(true); newItem.properties["statusText"].itemValue = statusObj.text; ... 現在會有 AJAX 網站使用這種模式嗎?可能用 document.getElementsByClassName (或是$(.xxx) )代替 getItems之類的? 我的問題是,Microdata 的規範定義了把 Microdata 轉 JSON 的方法,我們需要 把 JSON 轉回成 HTML 的 API 嗎?如果要,怎麼樣的設計比較好? 此致 呂 康豪(Kenny), 中文興趣小組W3C連絡人 推特: http://twitter.com/kanghaolu 噗浪: http://www.plurk.com/kennyluck 新浪微博: http://t.sina.com.cn/1950042164
Received on Tuesday, 7 June 2011 04:04:45 UTC