Custom attributes on <script>
and <link>
tags
Custom attributes can be added to rendered <script>
or <link>
in 3 different ways (by order of priority):
Via global config (
script_attributes
etlink_attributes
) : see the Vite bundle reference.When rendering in Twig - see the Twig functions.
By listening to the
Pentatrion\ViteBundle\Event\RenderAssetTagEvent
(source code) event.
Here is a complete example configuration :
yaml
# config/packages/pentatrion_vite.yaml
pentatrion_vite:
script_attributes:
foo: bar
# config/packages/pentatrion_vite.yaml
pentatrion_vite:
script_attributes:
foo: bar
twig
{{ vite_entry_script_tags('app', {
attr: {
hello: 'world'
}
}) }}
{{ vite_entry_script_tags('app', {
attr: {
hello: 'world'
}
}) }}
php
// src/EventSubscriber/ScriptNonceSubscriber.php
namespace App\EventSubscriber;
use Pentatrion\ViteBundle\Event\RenderAssetTagEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
class ScriptNonceSubscriber implements EventSubscriberInterface
{
public function onRenderAssetTag(RenderAssetTagEvent $event)
{
$tag = $event->getTag();
if ($tag->isInternal()) {
return;
}
if ($tag->isScriptTag() && $event->isBuild()) {
$tag->setAttribute('nonce', 'lookup nonce');
}
$tag->setAttribute('foo', 'bar-modified');
}
public static function getSubscribedEvents()
{
return [
RenderAssetTagEvent::class => 'onRenderAssetTag',
];
}
}
// src/EventSubscriber/ScriptNonceSubscriber.php
namespace App\EventSubscriber;
use Pentatrion\ViteBundle\Event\RenderAssetTagEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
class ScriptNonceSubscriber implements EventSubscriberInterface
{
public function onRenderAssetTag(RenderAssetTagEvent $event)
{
$tag = $event->getTag();
if ($tag->isInternal()) {
return;
}
if ($tag->isScriptTag() && $event->isBuild()) {
$tag->setAttribute('nonce', 'lookup nonce');
}
$tag->setAttribute('foo', 'bar-modified');
}
public static function getSubscribedEvents()
{
return [
RenderAssetTagEvent::class => 'onRenderAssetTag',
];
}
}
vous obtiendrez ceci
html
<script
type="module"
src="/build/assets/app-dc399f15.js"
foo="bar-modified"
hello="world"
nonce="lookup nonce"
></script>
<script
type="module"
src="/build/assets/app-dc399f15.js"
foo="bar-modified"
hello="world"
nonce="lookup nonce"
></script>