search

Home  >  Q&A  >  body text

javascript - 在页面中,除了xmp,textarea以及js转义外,还有什么办法可以让html标签在不被浏览器解析而正常显示呢?

如标题内容,请问各位还有什么其他方案吗?谢谢啦~

PHP中文网PHP中文网2819 days ago536

reply all(3)I'll reply

  • 迷茫

    迷茫2017-04-10 14:55:57

    要符合“内部的html标签不被解析”,我们根据HTML5的标准,分元素类别讨论吧:

    1. Void Elements,如br等。
      他们不允许有内部文本。
    2. Foreign Elements,如svgmathml的相关标签
      跟xml语法一致,他们内部文本若不想被当作标签解析,只有用<![CDATA[]]>包裹
    3. RCDATA elements:即textareatitle
      他们不能嵌套自身,内部的实体会被转义,内部的<不会被当作tag open解析。
      因此,他们内部的其他标签自然不会被解析。
    4. Raw text elements:即scriptstyle
      他们不能嵌套自身,内部的实体不会被转义,内部的<不会被当作tag open解析。
      因此,他们内部的其他标签自然不会被解析。
    5. Normal elements,普通的元素,基本上上列没有提及的都属于这一列,包括precode
      他们的特点是,内部的实体会被转义,内部的<可能根据上下文,被当作tag open解析。
      他们内部的文本若想展示标签文本而不解析,必须先转义<&lt;>&gt;

    如果目标是让HTML标签文本内容正常显示而不被解析,最简单的方案是嵌入到<script type="text/html"><script type="text/template">内部,并加上display: block即可。

    HTML4旧有的有xmplistingplaintext类似于HTML5的Raw text elements,可以包含标签而不解析,内部实体不被转义,但是已经在HTML5中废弃。

    reply
    0
  • 大家讲道理

    大家讲道理2017-04-10 14:55:57

    https://developer.mozilla.org/en-US/docs/Web/HTML/Element/plaintext
    https://developer.mozilla.org/en-US/docs/Web/HTML/Element/listing

    reply
    0
  • 巴扎黑

    巴扎黑2017-04-10 14:55:57

    reply
    0
  • Cancelreply