Intereting Posts
Laravel 4 удаление нескольких моделей, связанных с внешними ключами Как найти поле через внешний ключ в cakephp3.xx? сервер иногда возвращает chunked transfer encoding Создание файла .zip Хранить IPv6 в базе данных Yii создает несколько заголовков строк и объединяет их с другими столбцами в GridView отправлять электронную почту, используя php PHP Неустранимая ошибка: вызов неопределенной функции test_input () в C: \ wamp \ www \ web \ new9.php в строке 11 Как я могу изменить meta (alt и название) в миниатюре каталога, миниатюре продукта? – Woocomerce Larvel Cartalyst Sentinel – Добавление столбца имени пользователя в таблицу пользователей (что является правильным способом) Как я могу обновить только определенные поля в структуре Yii? Сохранить изображение с кодировкой base64 с запросом AJAX в PHP Новый объект Mysqli – Null Преобразование английских цифр в арабские цифры Преобразование массива в строку

Удалить атрибут стиля из HTML-тегов

Я не слишком хорош с регулярными выражениями, но с PHP я хочу удалить атрибут style из тегов HTML в строку, возвращающуюся с TinyMCE.

Поэтому измените <p style="...">Text</p> на простое ванильное <p>Test</p> .

Как я могу достичь этого с помощью функции preg_replace() ?

Прагматическое регулярное выражение (<[^>]+) style=".*?" решит эту проблему во всех разумных случаях. Часть матча, которая не является первой захваченной группой, должна быть удалена, например:

 $output = preg_replace('/(<[^>]+) style=".*?"/i', '$1', $input); 

Сопоставьте a < с одним или несколькими «не», пока мы не выйдем в space а часть style="..." . /i заставляет его работать даже с STYLE="..." . Замените этот матч на $1 , который является захваченной группой. Он оставит тег как есть, если тег не включает style="..." .

Что-то вроде этого должно работать (предупреждение непроверенного кода):

 <?php $html = '<p style="asd">qwe</p><br /><p class="qwe">qweqweqwe</p>'; $domd = new DOMDocument(); libxml_use_internal_errors(true); $domd->loadHTML($html); libxml_use_internal_errors(false); $domx = new DOMXPath($domd); $items = $domx->query("//p[@style]"); foreach($items as $item) { $item->removeAttribute("style"); } echo $domd->saveHTML(); 

Я прокомментировал функцию @Mayerln. Он работает, но DOMDocument действительно содержит кодировку. Вот моя версия simplehtmldom

 function stripAttributes($html,$attribs) { $dom = new simple_html_dom(); $dom->load($html); foreach($attribs as $attrib) foreach($dom->find("*[$attrib]") as $e) $e->$attrib = null; $dom->load($dom->save()); return $dom->save(); } 

Ну вот:

 <?php $html = '<p style="border: 1px solid red;">Test</p>'; echo preg_replace('/<p style="(.+?)">(.+?)<\/p>/i', "<p>$2</p>", $html); ?> 

Кстати, как указывали другие, регулярное выражение для этого не предлагается.

Я использую это:

 function strip_word_html($text, $allowed_tags = '<a><ul><li><b><i><sup><sub><em><strong><u><br><br/><br /><p><h2><h3><h4><h5><h6>') { mb_regex_encoding('UTF-8'); //replace MS special characters first $search = array('/&lsquo;/u', '/&rsquo;/u', '/&ldquo;/u', '/&rdquo;/u', '/&mdash;/u'); $replace = array('\'', '\'', '"', '"', '-'); $text = preg_replace($search, $replace, $text); //make sure _all_ html entities are converted to the plain ascii equivalents - it appears //in some MS headers, some html entities are encoded and some aren't //$text = html_entity_decode($text, ENT_QUOTES, 'UTF-8'); //try to strip out any C style comments first, since these, embedded in html comments, seem to //prevent strip_tags from removing html comments (MS Word introduced combination) if(mb_stripos($text, '/*') !== FALSE){ $text = mb_eregi_replace('#/\*.*?\*/#s', '', $text, 'm'); } //introduce a space into any arithmetic expressions that could be caught by strip_tags so that they won't be //'<1' becomes '< 1'(note: somewhat application specific) $text = preg_replace(array('/<([0-9]+)/'), array('< $1'), $text); $text = strip_tags($text, $allowed_tags); //eliminate extraneous whitespace from start and end of line, or anywhere there are two or more spaces, convert it to one $text = preg_replace(array('/^\s\s+/', '/\s\s+$/', '/\s\s+/u'), array('', '', ' '), $text); //strip out inline css and simplify style tags $search = array('#<(strong|b)[^>]*>(.*?)</(strong|b)>#isu', '#<(em|i)[^>]*>(.*?)</(em|i)>#isu', '#<u[^>]*>(.*?)</u>#isu'); $replace = array('<b>$2</b>', '<i>$2</i>', '<u>$1</u>'); $text = preg_replace($search, $replace, $text); //on some of the ?newer MS Word exports, where you get conditionals of the form 'if gte mso 9', etc., it appears //that whatever is in one of the html comments prevents strip_tags from eradicating the html comment that contains //some MS Style Definitions - this last bit gets rid of any leftover comments */ $num_matches = preg_match_all("/\<!--/u", $text, $matches); if($num_matches){ $text = preg_replace('/\<!--(.)*--\>/isu', '', $text); } $text = preg_replace('/(<[^>]+) style=".*?"/i', '$1', $text); return $text; } 

В дополнение к ответу Лоренцо Маркона:

Использование preg_replace для выбора всего, кроме атрибута стиля:

 $html = preg_replace('/(<p.+?)style=".+?"(>.+?)/i', "$1$2", $html); 

Вы могли бы обработать его на стороне клиента, самым простым было бы с jQuery. Что-то вроде:

 $("#tinyMce p").removeAttr("style");