首页 > 开发 > HTML > 正文

XHTML标签的自关闭的写法应该注意的问题

2020-09-18 22:20:29
字体:
来源:转载
供稿:网友

      xhtml里面的img标记应该这样写:<img alt="" src="" />,这种写法也就是所谓的自关闭,在xml中是完全合法的写法。如果你熟悉xml相关的开发,可能也就习惯于这种写法,想着xml中任何不含子节点的元素都可以这样写,那么xhtml中没有内容的标签也都可以这样写。xhtml中理论上当然允许任何标签以自关闭的方法来书写,然而浏览器兼容性却带来了新问题,那就是ie无法正确识别某些标签的自关闭写法。 字串8

      请尝试输入以下xhtml代码并在ie中浏览:<p>hello <script type="text/javascript" /> world</p>,你会发现只能看到前面的hello而不见后面的world,这事情让人挺无法解释的吧。可能有不少人都曾经遇到过这个问题,并且花了几个小时在上面都找不到合理的解释。 字串4

      解释源自另外一段类似的代码:<p>hello <textarea /> world</p>,你在ie中看看其显示效果,能够得到合理的解释了吗?我们能够看到前面的hello正常显示了,而后面的world则显示在textarea里面,这证明ie并没有正确识别textarea标签已经自关闭了,而是当它没有关闭,并将后面的内容识别为textarea内部的内容。 

      这时候我们就明白前面那段代码为什么看不到后面的world了,因为它被当作script的一部分来识别了。这就说明了,在我们使用xhtml时并不能好像xml那样随意的使用自关闭的写法,只有少数原本不需要关闭的标签可以用自关闭的写法,其他标签即使没有任何内容最好也用成对的关闭写法。 

      最后需要提醒大家的是,其实弱智的parser不仅仅ie有,很多地方都可能碰到由于parser不严谨而引起的问题,所以我们在书写xhtml的时候还是要迁就一些老html继承下来的习惯,不能好像真的xml那样自以为符合标准了就随意写。不信?那么再试一个吧:<p>hello <br></br> world</p>,留意ie与opera中的显示效果。

      xhtml一些相关的规范:

      1.所有的标记都必须要有一个相应的结束标记

      2.所有标签的元素和属性的名字都必须使用小写

      3.所有的xml标记都必须合理嵌套

      4.所有的属性必须用引号""括起来

      5.把所有<和&特殊符号用编码表示 

      6.给所有属性赋一个值

      7.不要在注释内容中使“--”

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表