亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP實(shí)現(xiàn)HTML標(biāo)簽自動補(bǔ)全代碼

 更新時(shí)間:2012年10月04日 18:32:17   作者:  
開發(fā)各種項(xiàng)目中經(jīng)常遇到截取html字符串問題。 比如博客文章列表頁面截取一部分正文、文章正文翻頁截取等
一般情況下先用PHP的 strip_tags 函數(shù)去掉所有html標(biāo)簽,再去掉空格等,然后再用substr或者自己實(shí)現(xiàn)的cn_substr函數(shù)來實(shí)現(xiàn)截取。因?yàn)槿绻幌热サ鬶tml標(biāo)簽,直接截取出來的字符串就會有沒有閉合的標(biāo)簽出現(xiàn),有時(shí)甚至?xí)厝≡跇?biāo)簽上面比如
復(fù)制代碼 代碼如下:
</di ...

今天遇到一個(gè)內(nèi)容翻頁截取問題: 正文是用富文本編輯器寫入的,編輯器上有個(gè)分頁按鈕,點(diǎn)擊之后就往當(dāng)前光標(biāo)位置插入一個(gè)藍(lán)色的

復(fù)制代碼 代碼如下:
<hr />

橫線。然后php直接存入數(shù)據(jù)庫。顯示的時(shí)候,用 explode 函數(shù)根據(jù)這個(gè)

復(fù)制代碼 代碼如下:
<hr />

標(biāo)記來分成一個(gè)數(shù)組,然后根據(jù)當(dāng)前頁碼來顯示某個(gè)片段。 但是有個(gè)嚴(yán)重的問題,比如富文本編輯器寫入:

復(fù)制代碼 代碼如下:

<div style="text-align:center">
content of page 1
<hr />
page 2 content
</div>

如果用explode函數(shù)分開后,
第一頁的內(nèi)容是

復(fù)制代碼 代碼如下:

<div style="text-align:center">

content of page 1
第二頁的內(nèi)容是:

復(fù)制代碼 代碼如下:

page 2 content
</div>

這樣就產(chǎn)生了沒有閉合的標(biāo)簽,直接顯示到頁面上面就會破壞頁面布局。。。
想了很久,也找了網(wǎng)上很多 closetag函數(shù)。但是發(fā)現(xiàn)都針對第一頁那種沒有閉合的標(biāo)簽的閉合。對于第二種沒有開頭的標(biāo)簽就沒辦法了。

針對第一頁那種沒有閉合的標(biāo)簽的閉合的closetags方法是:
復(fù)制代碼 代碼如下:

function closetags($html) {
// 不需要補(bǔ)全的標(biāo)簽
$arr_single_tags = array('meta', 'img', 'br', 'link', 'area');
// 匹配開始標(biāo)簽
preg_match_all('#<([a-z]+)(?: .*)?(?<![/|/ ])>#iU', $html, $result);
$openedtags = $result[1];
// 匹配關(guān)閉標(biāo)簽
preg_match_all('#</([a-z]+)>#iU', $html, $result);
$closedtags = $result[1];
// 計(jì)算關(guān)閉開啟標(biāo)簽數(shù)量,如果相同就返回html數(shù)據(jù)
$len_opened = count($openedtags);
if (count($closedtags) == $len_opened) {
return $html;
}
// 把排序數(shù)組,將最后一個(gè)開啟的標(biāo)簽放在最前面
$openedtags = array_reverse($openedtags);
// 遍歷開啟標(biāo)簽數(shù)組
for ($i = 0; $i < $len_opened; $i++) {
// 如果需要補(bǔ)全的標(biāo)簽
if (!in_array($openedtags[$i], $arr_single_tags)) {
// 如果這個(gè)標(biāo)簽不在關(guān)閉的標(biāo)簽中
if (!in_array($openedtags[$i], $closedtags)) {
// 直接補(bǔ)全閉合標(biāo)簽
$html .= '</' . $openedtags[$i] . '>';
} else {
unset($closedtags[array_search($openedtags[$i], $closedtags)]);
}
}
}
return $html;
}

后來想了一個(gè)辦法,利用瀏覽器自己的html解釋引擎來幫助補(bǔ)全有問題的html片段。具體做法如下:

復(fù)制代碼 代碼如下:

<script>
var div = document.createElement('div');
div.innerHTML ='<?php echo ("<div>這里是被截取的html片段");?>';
document.write(div.innerHTML);
</script>


原理就是先把html片段寫入到一個(gè)空的div里面,然后再從這個(gè)div里面讀取出來。別看寫入和讀取的屬性都是innerHTML,寫入的內(nèi)容和得到的內(nèi)容是不一樣的噢。如果寫入不完整的html片段,瀏覽器會自動補(bǔ)全修正。讀取出來的時(shí)候就已經(jīng)是完整的html dom 片段了。
可是這樣有個(gè)弊端,由于是Js加載內(nèi)容信息的,會對搜索引擎優(yōu)化不好。

相關(guān)文章

  • url請求頭信息全面解讀

    url請求頭信息全面解讀

    這篇文章主要為大家介紹了url請求頭信息全面解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • unicode utf-8 gb18030 gb2312 gbk各種編碼對比

    unicode utf-8 gb18030 gb2312 gbk各種編碼對比

    在修改一個(gè)cms的過程當(dāng)中遇到一個(gè)php截取字符串的函數(shù)(當(dāng)然得兼容中英字符了),因?yàn)閷Ω鞣N編碼的字符范圍和字符表示不清楚,感覺一頭迷霧,雖然可以直接來調(diào)用這個(gè)函數(shù)
    2009-05-05
  • 偽靜態(tài)技術(shù)介紹與優(yōu)缺點(diǎn)分析(較完整篇)

    偽靜態(tài)技術(shù)介紹與優(yōu)缺點(diǎn)分析(較完整篇)

    偽靜態(tài)太適合用在普通的企業(yè)網(wǎng)站上了——既不要求高并發(fā),但同時(shí)又很在乎seo(搜索引擎優(yōu)化),而且也要求后臺可動態(tài)更新。
    2009-11-11
  • 計(jì)算機(jī)程序設(shè)計(jì)并行計(jì)算概念及定義全面詳解

    計(jì)算機(jī)程序設(shè)計(jì)并行計(jì)算概念及定義全面詳解

    最近項(xiàng)目需要實(shí)現(xiàn)程序的并行化,剛好借著翻譯這篇帖子的機(jī)會,了解和熟悉并行計(jì)算的基本概念和程序設(shè)計(jì),有需要的朋友可以借鑒參考下
    2021-11-11
  • Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運(yùn)行l(wèi)eveldb?lmdb文件

    Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運(yùn)行l(wèi)eveldb?lmdb文件

    這篇文章主要為大家介紹了Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運(yùn)行l(wèi)eveldb?lmdb文件教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 使用MobaXterm連接到遠(yuǎn)程服務(wù)器的圖文教程

    使用MobaXterm連接到遠(yuǎn)程服務(wù)器的圖文教程

    這篇文章主要為大家詳細(xì)為大家介紹了如何使用MobaXterm連接到遠(yuǎn)程服務(wù)器,文中通過圖文進(jìn)行了詳細(xì)的講解,有需要的小伙伴可以參考一下
    2023-09-09
  • Trie樹_字典樹(字符串排序)簡介及實(shí)現(xiàn)

    Trie樹_字典樹(字符串排序)簡介及實(shí)現(xiàn)

    有時(shí),我們會碰到對字符串的排序,若采用一些經(jīng)典的排序算法,則時(shí)間復(fù)雜度一般為O(n*lgn),但若采用Trie樹,則時(shí)間復(fù)雜度僅為O(n)
    2014-03-03
  • VsCode運(yùn)行html界面的實(shí)戰(zhàn)步驟

    VsCode運(yùn)行html界面的實(shí)戰(zhàn)步驟

    在VSCode中默認(rèn)編寫的HTML頁面是不能運(yùn)行的,下面這篇文章主要給大家介紹了關(guān)于VsCode運(yùn)行html界面的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • 一文帶你了解ChatGPT?API的使用

    一文帶你了解ChatGPT?API的使用

    ChatGPT是OpenAI公司開發(fā)的一款基于自然語言處理技術(shù)的對話生成模型,,能夠自動學(xué)習(xí)自然語言數(shù)據(jù)的特征,并生成高質(zhì)量的語言文本。本文將為大家來介紹一下ChatGPT的API使用,希望對大家有所幫助
    2023-02-02
  • 阿里巴巴開源 Dragonwell JDK 最新版本 8.1.1-GA 發(fā)布

    阿里巴巴開源 Dragonwell JDK 最新版本 8.1.1-GA 發(fā)布

    距離 Dragonwell JDK 第一個(gè)正式版本 8.0.0-GA 發(fā)布已經(jīng)過去 3 個(gè)月了,項(xiàng)目在 Github 上的 stars 繼續(xù)攀升達(dá)到了 1900。今天我們帶來了最新版本 8.1.1-GA 的發(fā)布,包含了全新的特性和更新,需要的朋友可以參考下
    2019-10-10

最新評論