百度不收錄手機(jī)網(wǎng)站嗎微信小程序開(kāi)發(fā)一個(gè)多少錢(qián)啊
XML中的CDATA標(biāo)簽的作用
1.XML 文檔中的所有文本均會(huì)被解析器解析。只有 CDATA 區(qū)段中的文本會(huì)被解析器忽略。
2.PCDATA - 被解析的字符數(shù)據(jù)
XML 解析器通常會(huì)解析 XML 文檔中所有的文本。當(dāng)某個(gè) XML 元素被解析時(shí),其標(biāo)簽之間的文本也會(huì)被解析:
解析字符數(shù)據(jù)(PCDATA)是 XML 解析器解析的文本數(shù)據(jù)使用的一個(gè)術(shù)語(yǔ)。
3.CDATA - (未解析)字符數(shù)據(jù)
術(shù)語(yǔ) CDATA 指的是不應(yīng)由 XML 解析器進(jìn)行解析的文本數(shù)據(jù)(Unparsed Character Data)。
像 “<” 和 “&” 字符在 XML 元素中都是非法的。
“<” 會(huì)產(chǎn)生錯(cuò)誤,因?yàn)榻馕銎鲿?huì)把該字符解釋為新元素的開(kāi)始。
“&” 會(huì)產(chǎn)生錯(cuò)誤,因?yàn)榻馕銎鲿?huì)把該字符解釋為字符實(shí)體的開(kāi)始。
某些文本,比如 JavaScript 代碼,包含大量 “<” 或 “&” 字符。為了避免錯(cuò)誤,可以將腳本代碼定義為 CDATA。
CDATA 部分中的所有內(nèi)容都會(huì)被解析器忽略。
CDATA 部分由 “<![CDATA[" 開(kāi)始,由 "]]>” 結(jié)束:
<!--根據(jù)用戶注冊(cè)時(shí)間來(lái)查詢,開(kāi)始時(shí)間,結(jié)束時(shí)間-->
<select id="getUserByRegisterTime" parameterType="java.util.Map" resultMap="userMap">方法一:使用字符實(shí)體代替 大于符號(hào)>(>) 小于符號(hào)<(<) &符號(hào)(&) SELECT * FROM t_user WHERE registration_time >= #{begin} and registration_time <= #{end}當(dāng)然方法一的這種方式不夠見(jiàn)名知意,于是采用方法二會(huì)得到大多數(shù)人的理解。方法二:使用<![CDATA[]]><![CDATA[SELECT * FROM t_user WHERE registration_time >= #{begin} and registration_time <= #{end}]]>
</select>
有關(guān)字符實(shí)體的網(wǎng)址:https://www.w3school.com.cn/html/html_entities.asp
在上面的例子中,解析器會(huì)忽略 CDATA 部分中的所有內(nèi)容。
關(guān)于 CDATA 部分的注釋:
CDATA 部分不能包含字符串 “]]>”。也不允許嵌套的 CDATA 部分。
標(biāo)記 CDATA 部分結(jié)尾的 “]]>” 不能包含空格或折行。