PS:
Natürlich wird man nicht sämtlichen JS Code über Templates generieren. Aber es gibt Lösungen die sind gar nicht anders möglich. Ich habe ja nicht umsonst das Beispiel mit dem %url% Platzhalter gebracht: Während man in Formularen das action-Attribute einfach weglassen kann, ist das nämlich in Sachen XHR und fetchAPI nicht möglich, da muss ein URL notiert sein an welchen der Request gesendet wird.
Also wird bei mir für diesen Platzhalter grundsätzlich dieser Wert gesetzt und wird zu einer Variablen, die von JS genutzt werden kann. D.h., im Effekt ist es es gar keine Variable weil, bis auf wenige Ausnahmen, sämtliche AJAX//Fetch Requests die eine Seite feuern soll, stets auf sich selbst gerichtet sind. Was daran sollte denn da einen Test erschweren? Das Gegenteil ist der Fall!
Und auch hier würde die Ausnahme dazu führen daß ein Platzhalter gesetzt wird. Beispiel Konfiguration:
[/sunrise.html]
xhr_url = http://example.org/sunrise
Beim Bau der Response wird der entsprechende Platzhalter in den STASH gesetzt:
# Interface Methode
sub init{
my $self = shift;
$self->{STASH}{xhr_url} = $self->eav('xhr_url');
}
Und schließlich zum Rendern sowohl STASH (Datenversteck) als auch Template übergeben:
$self->render($self->{BODY}, $self->{STASH});
So daß in der ausgelieferten Response dann das Template
xhr.open("GET","%xhr_url%?"+params);
zu
xhr.open("GET","http://example.org/sunrise?"+params);
gerendert wird. Das Bereitstellen von Variablen aus der Konfiguration heraus über Platzhalter in das Template ist also eine ganz normale Sache und sozusagen Alltag im Geschäftsleben eines Framework.
MfG