A set of Tag Helpers that can capture a script block and render it later in another place.
- Add a reference to the package:
or
PM> Install-Package CaptureRenderTagHelper
MyGreatProject> dotnet add package CaptureRenderTagHelper
- Restore packages:
MyGreatProject> dotnet restore
- Register the Tag Helpers in your application's
_ViewImports.cshtml
file:@addTagHelper *, CaptureRenderTagHelper
Razor sections does not work in partial views or in display templates. This TagHelper will capture a script
block in the partial view or in the display template and render it later on the page.
To capture a script block add capture
attribute to a <script>
tag
<script capture='<UniqueID>'>
... JS code to capture
</script>
and to render this block, add render
attribute to an empty <script>
block in another file, specifying the same UniqueID
:
<script render='<UniqueID>'>
</script>
Multiple blocks can be captured by passing the same ID.
<script capture='Foo'>
console.log('Foo 1');
</script>
<script capture='Foo'>
console.log('Foo 2');
</script>
and later rendered with a single script
tag:
<script render='Foo'></script>
which by default will expand into two script
tags that were captured previously.
<script>
console.log('Foo 1');
</script>
<script>
console.log('Foo 2');
</script>
By default the script blocks will be rendered in the same order as they were captured.
This can be changed by setting priority
attribute upon capture.
<script capture="SimplePriority" priority="3">
console.log('SimplePriority 1');
</script>
<script capture="SimplePriority" priority="2">
console.log('SimplePriority 2');
</script>
<script capture="SimplePriority" priority="1" src="SimplePriority.js"></script>
The result of rendering this:
<script src="SimplePriority.js"></script>
<script>
console.log('SimplePriority 2');
</script>
<script>
console.log('SimplePriority 1');
</script>
There are couple of ways to tell ScriptRenderTagHelper
to merge captured blocks
-
By using
auto-merge
attribute on the render tag helper.If set to true, render tag helper will merge script blocks that have content and not marked with
allow-merge='false'
upon capture.<script capture="AutoMerge"> console.log('AutoMerge 1'); </script> <script capture="AutoMerge"> console.log('AutoMerge 2'); </script> <script capture="AutoMerge" src="AutoMerge.js"></script> // somewhere in another file <script render="AutoMerge" auto-merge="true"> </script>
the output of the render would be
<script> console.log('AutoMerge 1'); console.log('AutoMerge 2'); </script> <script src="AutoMerge.js"></script>
-
By setting
allow-merge='true'
upon capture.In this case only blocks that are explicitly marked for merge will be merged on render.
<script capture="ExplicitMerge" allow-merge="true"> console.log('ExplicitMerge 1'); </script> <script capture="ExplicitMerge" allow-merge="true"> console.log('ExplicitMerge 2'); </script> <script capture="ExplicitMerge" allow-merge="true" src="ExplicitMerge.js"></script> // somewhere in another file <script render="ExplicitMerge" auto-merge="false"> </script>
the output is
<script> console.log('ExplicitMerge 1'); console.log('ExplicitMerge 2'); </script> <script src="ExplicitMerge.js"></script>
Same as with auto merge, script references do not get merged.
To prevent the merge of one particular script block, set allow-merge='false'
.
From version 0.3.1 render
tag helper will automatically detect script blocks with identical src
attributes and will omit duplicates.
This is useful when need to render multiple display templates or components on the same page that have a script reference.
For example, in the following case:
<script capture="NoDuplicate" src="Duplicate.js"></script>
<script capture="NoDuplicate">
console.log('NoDuplicate 1');
</script>
<script capture="NoDuplicate" src="Duplicate.js"></script>
/// Later in the code
<script render="NoDuplicate">
</script>
the output will be:
<script src="Duplicate.js"></script>
<script>
console.log('NoDuplicate 1');
</script>
This can be disabled by setting no-duplicate-source
to false
:
<script render="NoDuplicateDisabled" no-duplicate-source="false">
</script>