AspNetCore.Docs/aspnetcore/blazor/host-and-deploy/configure-trimmer.md

49 lines
2.6 KiB
Markdown
Raw Permalink Normal View History

2020-09-15 00:23:30 +08:00
---
title: Configure the Trimmer for ASP.NET Core Blazor
author: guardrex
description: Learn how to control the Intermediate Language (IL) Trimmer when building a Blazor app.
2021-08-09 03:43:46 +08:00
monikerRange: '>= aspnetcore-5.0'
2020-09-15 00:23:30 +08:00
ms.author: riande
ms.custom: mvc
2024-11-18 21:14:57 +08:00
ms.date: 11/12/2024
2020-09-15 00:23:30 +08:00
uid: blazor/host-and-deploy/configure-trimmer
---
# Configure the Trimmer for ASP.NET Core Blazor
[!INCLUDE[](~/includes/not-latest-version.md)]
2023-04-04 23:06:06 +08:00
This article explains how to control the Intermediate Language (IL) Trimmer when building a Blazor app.
2022-03-15 17:53:00 +08:00
2024-09-12 01:48:54 +08:00
Blazor WebAssembly performs [Intermediate Language (IL)](/dotnet/standard/glossary#il) trimming to reduce the size of the published output. Trimming occurs when publishing an app.
2020-09-15 00:23:30 +08:00
2024-09-12 01:48:54 +08:00
Trimming may have detrimental effects for the published app. In apps that use [reflection](/dotnet/csharp/advanced-topics/reflection-and-attributes/), the IL Trimmer often can't determine the required types for runtime reflection and trim them away. For example, complex framework types for JS interop, such as <xref:System.Collections.Generic.KeyValuePair>, might be trimmed and not available at runtime for JS interop calls. In these cases, we recommend creating your own custom types instead. The IL Trimmer is also unable to react to an app's dynamic behavior at runtime. To ensure the trimmed app works correctly once deployed, test published output frequently while developing.
2020-09-15 00:23:30 +08:00
2024-06-19 05:17:04 +08:00
## Configuration
To configure the IL Trimmer, see the [Trimming options](/dotnet/core/deploying/trimming/trimming-options) article in the .NET Fundamentals documentation, which includes guidance on the following subjects:
2020-09-15 00:23:30 +08:00
2021-02-09 00:19:22 +08:00
* Disable trimming for the entire app with the `<PublishTrimmed>` property in the project file.
* Control how aggressively unused IL is discarded by the IL Trimmer.
* Stop the IL Trimmer from trimming specific assemblies.
2021-02-09 00:19:22 +08:00
* "Root" assemblies for trimming.
* Surface warnings for reflected types by setting the `<SuppressTrimAnalysisWarnings>` property to `false` in the project file.
* Control symbol trimming and debugger support.
* Set IL Trimmer features for trimming framework library features.
2020-09-15 00:23:30 +08:00
2024-06-19 05:17:04 +08:00
## Default trimmer granularity
The default trimmer granularity for Blazor apps is `partial`. To trim all assemblies, change the granularity to `full` in the app's project file:
```xml
<ItemGroup>
<TrimMode>full</TrimMode>
</ItemGroup>
```
For more information, see [Trimming options (.NET documentation)](/dotnet/core/deploying/trimming/trimming-options#trimming-granularity).
2020-09-15 00:23:30 +08:00
## Additional resources
2021-12-12 22:24:04 +08:00
* [Trim self-contained deployments and executables](/dotnet/core/deploying/trimming/trim-self-contained)
* <xref:blazor/performance#intermediate-language-il-trimming>