分类存档: mobile web - 第2页

HTML 4与XHTML 1.0区别

翻译w3c的http://www.w3.org/TR/xhtml1/ 第四部分,具体的不同还要参考DOM(不是很喜欢DOM的个别地方,用JS操作一个元素时,原本简单的东西往往得很多句才能搞定,再次抱怨一下,呵呵)和XML。

编写手机页面时所用的xhtml mp和xhtml basic 依照xhtml标准,虽然浏览器一般都较宽容,但不推荐旧的写法。

XHTML文档必须具有良好完整的排版(well-formed)

编排良好性(Well-formedness)是XML引入的一个新概念.从本质上说,元素必须有结束标签,或者必须以特殊方式书写,而且元素必须嵌套.

尽管SGML规定重叠(overlapping)是非法的,但现有的浏览器普遍允许重叠.

正确:嵌套元素(nested elements)

<p>梦之都 <em>XHTML教程</em>.</p>

不正确:层叠元素(overlapping elements)

<p>梦之都 <em>XHTML教程</p>.</em>

元素和属性名必须小写

对于所有HTML元素和属性名, XHTML文档必须使用小写. 因为XML是大小写敏感的.如 <li><LI> 是不同的标签.

对非空元素,必须使用结束标签

在基于SGML的HTML4中的一些隐含结束意义的元素允许忽略结束标签.XML不允许忽略结束标签.除了在DTD中被声明为空的元素,所有元素必须有结束标签.

正确:结束的元素(terminated elements)

<p>梦之都的XHTML教程.</p><p>梦之都的CSS教程.</p>

不正确:未结束的元素(unterminated elements)

<p>梦之都的XHTML教程.<p>梦之都的CSS教程.

属性值必须在引号中

所有的属性值必须在引号中,即使是以数字形式的属性值

正确:在引号中的属性值(quoted attribute values)

<table rows="3">

不正确:不在引号中的属性值(unquoted attribute values)

<table rows=3>

属性最小化

XML不支持属性最小化.属性-属性值必须完整成对的写出.像disabled,checked这样的属性名不能在不指定属性值的情况下出现.

正确:非最小化属性(unminimized attributes)

<input checked="checked">

不正确:最小化属性(minimized attributes)

<input checked>

空元素

空元素必须有结束标签,或者起始标签必须以/>结束.例如,<br/><hr></hr>.参看HTML兼容性指导HTML Compatibility Guidelines中的信息,以保证向后兼容HTML 4用户代理程序.

正确:结束的空元素(terminated empty elements)

<br/><hr/>

错误:未结束的空标签(unterminated empty elements)

<br><hr>

属性值中的空白字符处理

  • 删去引导和后序空白符
  • 将一个或多个空白符(包括换行)转换成单个字符间空间

Script and Style 元素

XHTML中,scriptstyle元素被声明为#PCDATA内容形式,因此,<和&被看作是标识的开始,&lt和&amp等HTML实体将被XML处理器看作为实体引用而分别被认为是<和&.将scriptstyle元素的内容隐蔽在CDATA标记中避免了这些实体的扩张.

<script>
<![CDATA[
... unescaped script content ...
]]>
</script>

CDATA部分被XML处理器识别,表现为文档对象模型中的一个结点.替代的方式是使用外部script和style文档.

SGML排斥

SGML给作者的DTD可以指定在一个元素内部禁止出现的元素.这样的禁止在XML中是不可能的.

例如,严格的HTML 4 DTD”禁止”任何深度的’a'元素对另一’a'元素的嵌套.在XML中无法写出这些的”禁止”.虽然这些禁止不能被定义在DTD中,但是一些元素不应该被嵌套.对不能被嵌套的元素Element Prohibitions的总结.

具有’id’和’name’属性的元素

HTML4定义了name属性的元素有a,applet,form,frame,iframe,img and map.HTML4还引入了id属性.这两个属性都是被设计用为片段标识符.

在 XML中,片段标识符是ID,每个元素只能有一个ID类型的属性.因此,在XHTML1.0中,id属性被定义为ID类型.为保证XHTML1.0文档是 结构良好(well-structured)的XML文档,在定义一个片段标识符时,XHTML文档必须使用id属性,即使是对那些以前用name属性的 元素.参看 HTML Compatibility Guidelines,确保XHTML文档以text/html媒体类型使用时,这些”锚(anchors)”能向后兼容.

注意,在XHTML 1.0中,name属性是不赞成使用的,在以后的XHTML版本中将被删除。

有预定义值的属性

在HTML 4和XHTML都有一些属性,它们有预先确定且有限的值(例如, type属性的input元素) 。在SGML和XML中 ,这些被称为枚举属性。在HTML 4中 ,这些值是不区分大小写的,所以TEXT和text是一样的。在XML中,这些值是区分大小写的,而在XHTML 1所有这些值都应该是小写的。

手机cookie共享

setcookie($key,$name,$expire,$path,”.domain.com”)
cookie共享的时候,如a.domain.com和b.domain.com共享一个cookie,一定要在domain前加上一点,要不就有可能没法共享这个cookie。

mobile ok checker

http://validator.w3.org/mobile/ 检查所写的mobile web page 是否符合标准。其实我觉得不用完全符合,呵呵。

手机web开发资料

3G牌照发了,近期要开始仔细研究手机端的web开发了,在网上找了找资料,中文的真不是一般的少,简直就是没有,唉,还是看E文的吧。

把找到的网站整理一下,以便查找。

1. http://www.openmobilealliance.org/ OMA,WapForum与前OMA合并后的组织,WML及XHTML MP的制订者。不过我在者没找到啥东西,http://www.openmobilealliance.org/Application/Search/?search=xhtmlmp 这个链接是关于xhtml mp的pdf文档。

2. http://www.w3c.org W3C,XHTML Basic 制定者,http://www.google.com/custom?q=XHTML+Basic+1.1&sitesearch=www.w3.org&domains=www.w3.org 这个链接可以找到w3c上关于xhtml basic的内容。http://www.w3.org/TR/mobileOK-basic10-tests/http://www.w3.org/TR/mobile-bp/ .当然,还有更多内容,http://www.w3.org/TR/http://www.w3.org/Mobile/

3. http://www.developershome.com/ Developers’ Home ,网站上有些关于手机web开发的教程和文章,http://www.developershome.com/wap/xhtmlmp/ 这个链接是关于xhtml mp的部分。

4. http://dev.opera.com/articles/mobile/ Opera,上面有些Opera提供的关于mobile的内容,http://dev.opera.com/articles/view/mobile-markup-xhtml-basic-1-1/ 这是一篇讲XHTML Basic 1.1的。

5. http://en.wikipedia.org/wiki/XHTML_Mobile_Profilehttp://en.wikipedia.org/wiki/XHTML ,维基百科上关于xhtml mp,xhtml,xhtml basic的部分。

6. http://www.passani.it/gap/ Global Authoring Practices for the Mobile Web

7. http://developer.openwave.com/documentation/xhtml_mp_css_reference/index.html openwave上关于xhtmlmp的文档。

8. http://mobilewebbook.com/ Cameron Moll的一本书,有预览版,没找着下载的地方,先放在这,以后再找。http://cameronmoll.com/ ,他的网站。
另一本书Mobile Web Development

9.  http://www.smashingmagazine.com/2009/01/13/mobile-web-design-trends-2009/ 闲人们组织了个大会,讨论了一下09年手机web的发展趋势。

10. http://mobiforge.com/

先这些,找着新的再补。