這篇文章主要介紹了PHP strip_tags保留多個HTML標籤的方法,需要的朋友可以參考下
本文介紹了PHP strip_tags函數保留多個HTML標籤的方法,可以使用第二個參數來設定不需要刪除的標籤,主要涉及strip_tags的第二個參數
strip_tags 函數
語法
string strip_tags ( string str [, string allowable_tags] )
傳回一個移除了HTML標籤的字串;可以使用第二個參數來設定不需要刪除的標籤。
使用方法:
前提:假如現在有這樣一個字串,
$str = "<p>我来自<b><a href='//www.php.cn'>php中文网</a></b></p>";
1,不保留任何HTML標籤,程式碼會是這樣:
echo strip_tags($str); // 输出:我来自php中文网
2,只保留3499910bf9dac5ae3c52d5ede7383485一個標籤的話,只需要將3499910bf9dac5ae3c52d5ede7383485字串寫到strip_tags的第二個參數中:
echo strip_tags($str, "<a>"); // 输出:我来自<a href='//www.php.cn'>php中文网</a>
3,要保留40e90f15b24b48ecd88139346ce80383…多個標籤,只需要將多個標籤用空格分隔後寫到strip_tags的第二個參數中:
echo strip_tags($str, "<p> <b>"); // 输出:<p>我来自<b>php中文网</b></p>
如果要使用php刪除html標記中的特定標籤呢?
這個就需要程式碼來實現了,如下:
function strip_selected_tags($text, $tags = array()) { $args = func_get_args(); $text = array_shift($args); $tags = func_num_args() > 2 ? array_diff($args, array($text)) : (array) $tags; foreach($tags as $tag) { if (preg_match_all('/<'.$tag. '[^>]*>([^<]*)</'.$tag. '>/iu', $text, $found)) { $text = str_replace($found[0], $found[1], $text); } } return preg_replace('/(<('.join('|', $tags). ')( | |.)*/>)/iu', '', $text); } $str = "[url="] 123[/url]"; echo strip_selected_tags($str, array('b'));
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
在php中用html_entity_decode實作HTML實體轉義
以上是關於PHP strip_tags保留多個HTML標籤的詳細內容。更多資訊請關注PHP中文網其他相關文章!