Aqui está uma sugestão de demonstração:
add_action( 'admin_enqueue_scripts', function()
{
wp_enqueue_script( 'my-script', '/my-script.js', ['underscore', 'backbone'], '1.0' );
wp_add_inline_script( 'my-script', 'alert("hello world");' );
// Add our template
if( function_exists( 'wpse_add_inline_tmpl' ) )
wpse_add_inline_tmpl(
$handle = 'my-script',
$id = 'my-tmpl',
$tmpl = '<div class="section intro">{{{ data.section.intro }}}</div>'
);
} );
onde definimos nossa função wpse_add_inline_tmpl()
personalizada como:
function wpse_add_inline_tmpl( $handle, $id, $tmpl )
{
// Collect input data
static $data = [];
$data[$handle][$id] = $tmpl;
// Append template for relevant script handle
add_filter(
'script_loader_tag',
function( $tag, $hndl, $src ) use ( &$data, $handle, $id )
{
// Nothing to do if no match
if( ! isset( $data[$hndl][$id] ) )
return $tag;
// Script tag replacement aka wp_add_inline_script()
if ( false !== stripos( $data[$hndl][$id], '</script>' ) )
$data[$hndl][$id] = trim( preg_replace(
'#<script[^>]*>(.*)</script>#is',
'$1',
$data[$hndl][$id]
) );
// Append template
$tag .= sprintf(
"<script type='text/template' id='%s'>\n%s\n</script>" . PHP_EOL,
esc_attr( $id ),
$data[$hndl][$id]
);
return $tag;
},
10, 3 );
}
Aqui usamos o filtro script_loader_tag
para injetar o código do modelo e usar o identificador e o id para referenciá-lo. Também usamos a tag script substituição da função wp_add_inline_script()
do núcleo.
Espero que você possa testar isso e modificar suas necessidades. Escrever isso como uma aula pode ser uma abordagem melhor; -)