Marks an object's __toString() method as returning markup.
Objects that implement this interface will not be automatically XSS filtered by the render system or automatically escaped by the theme engine.
If there is any risk of the object's __toString() method returning user-entered data that has not been filtered first, it must not be used. If the object that implements this does not perform automatic escaping or filtering itself, then it must be marked as "@internal". For example, Views has the internal ViewsRenderPipelineMarkup object to provide a custom render pipeline in order to render JSON and to fast render fields. By contrast, FormattableMarkup and TranslatableMarkup always sanitize their output when used correctly.
If the object is going to be used directly in Twig templates it should implement \Countable so it can be used in if statements.
\Drupal\Component\Render\MarkupTrait
\Drupal\Core\Template\TwigExtension::escapeFilter()
\Drupal\Component\Render\FormattableMarkup
\Drupal\Core\StringTranslation\TranslatableMarkup
\Drupal\views\Render\ViewsRenderPipelineMarkup
Name | Modifiers | Type | Description |
---|---|---|---|
MarkupInterface::__toString | public | function | Returns markup. |
© 2001–2016 by the original authors
Licensed under the GNU General Public License, version 2 and later.
Drupal is a registered trademark of Dries Buytaert.
https://api.drupal.org/api/drupal/core!lib!Drupal!Component!Render!MarkupInterface.php/interface/MarkupInterface/8.1.x