这篇文章主要介绍了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,要保留e388a4556c0f65e1904146cc1a846bee与a4b561c25d9afb9ac8dc4d70affff419…多个标签,只需要将多个标签用空格分隔后写到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中文网其他相关文章!