Introducción a WebView2 en aplicaciones WPF
En este artículo se explica cómo configurar las herramientas de desarrollo y crear una aplicación WebView2 inicial para Windows Presentation Foundation (WPF) y obtener información sobre los conceptos de WebView2 en el camino.
En este tutorial, usará la plantilla de proyecto Aplicación WPF o Aplicación WPF (.NET Framework) para crear una aplicación WPF y, a continuación, instalará el SDK de WebView2 para que el proyecto agregue WebView2.
Proyecto completado
Hay disponible una versión completa de este proyecto de tutorial en el repositorio WebView2Samples :
- Nombre de ejemplo: WPF_GettingStarted
- Directorio del repositorio: WPF_GettingStarted
- Archivo de solución: WPFSample.sln
Paso 1: Instalación de Visual Studio con compatibilidad con .NET
Este tutorial requiere Microsoft Visual Studio, no Microsoft Visual Studio Code. En este artículo se describe principalmente el uso de Visual Studio 2022.
Instale Visual Studio. Instale la compatibilidad con el desarrollo de escritorio de .NET para obtener las plantillas de proyecto necesarias, como se indica a continuación.
Si está en la pantalla de inicio de Visual Studio, desplácese hasta la parte inferior del cuadro de diálogo Crear un nuevo proyecto y haga clic en el vínculo Abrir sin código. Se abre Visual Studio.
En Visual Studio, seleccione Herramientas>Obtener herramientas y características. Se abre la ventana Instalador de Visual Studio y se abre el cuadro de diálogo Modificar .
Seleccione la carga de trabajo desarrollo de escritorio de .NET para que haya una marca de verificación en ella.
En la sección Detalles> de instalación.Desarrollo> de escritorio de NETincluido a la derecha, asegúrese de que aparecen las herramientas de desarrollo de escritorio de .NET y las herramientas de desarrollo de .NET Framework 4.7.2, con una marca de verificación junto a ellas.
En la sección Detalles> de instalación. Desarrollo> de escritorio de NETOpcional a la derecha:
- Si usa Visual Studio 2022, asegúrese de que las herramientas de desarrollo para .NET estén seleccionadas:
- Si usa Visual Studio 2019, asegúrese de que las herramientas de desarrollo de .NET están seleccionadas:
Haga clic en el botón Modificar .
Este tutorial también funciona con Visual Studio 2017. Consulte Descargas anteriores de Visual Studio. Instale la compatibilidad con .NET para obtener las plantillas de proyecto necesarias, de forma similar a los pasos anteriores.
Paso 2: Creación de una aplicación WebView2 de una sola ventana
Empiece por crear un proyecto de escritorio básico que contenga una sola ventana principal.
Decida si desea crear un proyecto de .NET Core/5/6 (más reciente) o un proyecto de aplicación de WPF (.NET Framework) (anterior). Para más información, vea:
- Historial de .NET en ¿Qué es .NET? Introducción e información general.
- .NET en Wikipedia.
Siga la sección correspondiente a continuación.
Creación de un proyecto de .NET Core/5/6
Si va a crear un proyecto de .NET Core/5/6, siga estos pasos. De lo contrario, vaya a Creación de un proyecto de aplicación wpf (.NET Framework).
Abra Microsoft Visual Studio, como Visual Studio 2022.
En el panel de apertura, haga clic en Crear nuevo proyecto. O bien, en la ventana principal de Visual Studio, seleccione Archivo>nuevo>proyecto. Se abre el cuadro de diálogo Crear un nuevo proyecto .
En el cuadro de texto Buscar plantillas , escriba
WPF Application
. El panel Crear un nuevo proyecto muestra las plantillas de proyecto instaladas que coinciden con el texto especificado. En este artículo se muestran los diálogos de C# en lugar de VB; Ambos lenguajes son compatibles con WebView2.Si usa Visual Studio 2022, haga clic en una plantilla de proyecto que tenga el título Aplicación WPF y el texto de descripción Un proyecto para crear una aplicación wpf de .NET:
Si usa Visual Studio 2019, haga clic en una plantilla de proyecto que tenga el título Aplicación WPF y el texto de descripción Un proyecto para crear una aplicación WPF de .NET Core:
Si la plantilla de proyecto anterior no aparece en la lista, consulte Paso 1: Instalación de Visual Studio con compatibilidad con .NET anterior para instalar herramientas de desarrollo de escritorio de .NET.
Haga clic en el botón Siguiente .
Se abre el cuadro de diálogo Configurar el nuevo proyecto: Aplicación WPF :
En el cuadro de texto Nombre del proyecto, escriba un nombre de proyecto, como MyWpfDotnetCoreWv2App.
En el cuadro de texto Ubicación , seleccione una ruta de acceso en la unidad local, como
C:\Users\myusername\Documents\MyProjects
y, a continuación, haga clic en el botón Siguiente .Aparece el cuadro de diálogo Información adicional , con una lista desplegable Marco de destino :
Seleccione .NET Core 3.1 o posterior, como .NET 6.0. (No seleccione .NET Core 3.0). A continuación, haga clic en el botón Crear .
El proyecto inicial de aplicación WPF de .NET Core se abre en Visual Studio:
Vaya al paso 3: compilación y ejecución del proyecto inicial sin WebView2 a continuación.
Creación de un proyecto de aplicación de WPF (.NET Framework)
Si va a crear un proyecto de aplicación de WPF (.NET Framework), siga estos pasos. De lo contrario, vaya al Paso 3: Compilación y ejecución del proyecto inicial sin WebView2.
Abra Microsoft Visual Studio, como Visual Studio 2022.
En el panel de apertura, haga clic en Crear nuevo proyecto. O bien, en la ventana principal de Visual Studio, seleccione Archivo>nuevo>proyecto. Se abre el cuadro de diálogo Crear un nuevo proyecto .
En el cuadro de texto Buscar plantillas , escriba
WPF App
. El panel Crear un nuevo proyecto muestra las plantillas de proyecto instaladas que coinciden con el texto especificado. En este artículo se muestran los diálogos de C# en lugar de VB; Ambos lenguajes son compatibles con WebView2.Haga clic en una plantilla de proyecto que tenga el título aplicación WPF (.NET Framework) y el texto de descripción aplicación cliente de Windows Presentation Foundation:
Si la plantilla de proyecto anterior no aparece en la lista, consulte Paso 1: Instalación de Visual Studio con compatibilidad con .NET anterior para instalar herramientas de desarrollo de escritorio de .NET.
Haga clic en el botón Siguiente .
Se abre el cuadro de diálogo Configurar el nuevo proyecto: Aplicación WPF (.NET Framework):
En el cuadro de texto Nombre del proyecto, escriba un nombre de proyecto, como MyWpfDotnetFwkWv2App.
En el cuadro de texto Ubicación , seleccione una ruta de acceso en la unidad local, como
C:\Users\myusername\Documents\MyProjects
.En la lista desplegable Marco , seleccione .NET Framework 4.6.2 o posterior.
Haga clic en el botón Crear.
El proyecto inicial de aplicación wpf (.NET Framework) se abre en Visual Studio:
Paso 3: Compilación y ejecución del proyecto inicial sin WebView2
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
El proyecto se ejecuta y muestra una ventana vacía:
Es posible que tenga que instalar la versión de .NET Framework seleccionada, como se indica a continuación.
Si la aplicación no se abre, seleccione Depurar>inicio sin depuración.
Si no ha instalado la versión seleccionada de .NET Framework, puede obtener el siguiente cuadro de diálogo: "No se pudo iniciar esta aplicación. La aplicación requiere una de las siguientes versiones de .NET Framework: . NETFramework,Version=v4.8.1: ¿Desea instalar esta versión de .NET Framework ahora?"
Si obtiene este tipo de cuadro de diálogo, vaya a Descargar .NET Framework y descargue e instale la versión necesaria del paquete para desarrolladores (no el runtime). Por ejemplo, descargue
ndp481-devpack-enu.exe
enC:\Users\username\Downloads
y haga doble clic en el archivo para instalarlo.Si se le solicita, reinicie el equipo:
Vaya al archivo descargado, como
ndp481-devpack-enu.exe
enC:\Users\username\Downloads
y, de nuevo, haga doble clic en el archivo descargado para instalar el paquete para desarrolladores de .NET Framework. Aparece un cuadro de diálogo Correcto:Si se le solicita, reinicie el equipo de nuevo.
Abra Visual Studio y abra la solución que ha creado.
Presione F5 para ejecutar la aplicación inicial (que se muestra anteriormente), sin incluir aún el SDK de WebView2.
Cierre la aplicación inicial.
Paso 4: Instalación del SDK de WebView2
En Visual Studio, use el Administrador de paquetes NuGet para agregar el SDK de WebView2 al proyecto, como se indica a continuación:
En el Explorador de soluciones, haga clic con el botón derecho en el nombre del proyecto (en función de la plantilla de proyecto .NET (Core) o .NET Framework y, a continuación, seleccione Administrar paquetes NuGet:
En la parte superior izquierda, haga clic en la pestaña Examinar . En la barra de búsqueda, escriba
Microsoft.Web.WebView2
y haga clic en el paquete Microsoft.Web.WebView2 .El cuadro de diálogo Administrador de paquetes NuGet muestra los resultados de la búsqueda, incluido un paquete Microsoft.Web.WebView2 . El cuadro de diálogo tiene un número de versión y el botón Instalar .
Acepte la versión predeterminada y, a continuación, haga clic en el botón Instalar .
En el cuadro de diálogo Vista previa de cambios , haga clic en el botón Aceptar .
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
El proyecto se ejecuta y muestra una ventana vacía. Esto comprueba que WebView2 está instalado y funcionando, aunque WebView2 no tiene contenido que mostrar todavía:
Cierre la aplicación.
Paso 5: Creación de un único control WebView2
Agregue un control WebView2 a la aplicación.
En el
MainWindow.xaml
archivo , para agregar el espacio de nombres XAML WebView2, inserte la siguiente línea dentro de la<Window/>
etiqueta :xmlns:wv2="clr-namespace:Microsoft.Web.WebView2.Wpf;assembly=Microsoft.Web.WebView2.Wpf"
Asegúrese de que el código de
MainWindow.xaml
tenga un aspecto similar al siguiente:<Window x:Class="WPF_Getting_Started.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:{YOUR PROJECT NAME}" xmlns:wv2="clr-namespace:Microsoft.Web.WebView2.Wpf;assembly=Microsoft.Web.WebView2.Wpf" mc:Ignorable="d" Title="MainWindow" Height="450" Width="800" > <Grid> </Grid> </Window>
Para agregar el control WebView2, reemplace las
<Grid>
etiquetas por el código siguiente. LaSource
propiedad establece el URI inicial que se muestra en el control WebView2.<DockPanel> <wv2:WebView2 Name="webView" Source="https://www.microsoft.com" /> </DockPanel>
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
Asegúrese de que el control WebView2 muestra https://www.microsoft.com:
Paso 6: Navegación
Permitir que los usuarios cambien la dirección URL que muestra el control WebView2 agregando una barra de direcciones a la aplicación.
En el
MainWindow.xaml
archivo, agregue una barra de direcciones copiando y pegando el código siguiente dentro del<DockPanel>
que contiene el control WebView2. Mantenga el código existente debajo del nuevo fragmento de código.<DockPanel DockPanel.Dock="Top"> <Button x:Name="ButtonGo" DockPanel.Dock="Right" Click="ButtonGo_Click" Content="Go" /> <TextBox Name="addressBar"/> </DockPanel>
Asegúrese de que la
<DockPanel>
sección delMainWindow.xaml
archivo coincide con el código siguiente:<DockPanel> <DockPanel DockPanel.Dock="Top"> <Button x:Name="ButtonGo" DockPanel.Dock="Right" Click="ButtonGo_Click" Content="Go"/> <TextBox Name = "addressBar"/> </DockPanel> <wv2:WebView2 Name = "webView" Source = "https://www.microsoft.com" /> </DockPanel>
En
MainWindow.xaml.cs
, para agregar elCoreWebView2
espacio de nombres, inserte el código siguiente en la parte superior del archivo:using Microsoft.Web.WebView2.Core;
En el
MainWindow.xaml.cs
archivo, copie el código siguiente para crear elButtonGo_Click
método . Este código navega por el control WebView2 hasta la dirección URL especificada en la barra de direcciones.private void ButtonGo_Click(object sender, RoutedEventArgs e) { if (webView != null && webView.CoreWebView2 != null) { webView.CoreWebView2.Navigate(addressBar.Text); } }
Pegue el código directamente después de la
Public MainWIndow
declaración, como se muestra en el código siguiente:namespace WpfApp1 { /// <summary> /// Interaction logic for MainWindow.xaml /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } void ButtonGo_Click(object sender, RoutedEventArgs e) { if (webView != null && webView.CoreWebView2 != null) { webView.CoreWebView2.Navigate(addressBar.Text); } } } }
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
Escriba una nueva dirección URL en la barra de direcciones y elija Ir. Por ejemplo, escriba
https://www.bing.com
.Asegúrese de que el control WebView2 abre la dirección URL especificada.
Asegúrese de escribir una dirección URL completa en la barra de direcciones. La aplicación genera un
ArgumentException
si la dirección URL no comienza conhttp://
ohttps://
.La aplicación de ejemplo muestra el sitio web de Bing con la dirección URL
https://www.bing.com
en la barra de direcciones:
Paso 7: Eventos de navegación
Durante la navegación por la página web, el control WebView2 genera eventos. La aplicación que hospeda controles WebView2 escucha los eventos siguientes:
NavigationStarting
SourceChanged
ContentLoading
HistoryChanged
NavigationCompleted
En el diagrama anterior se muestra la secuencia de eventos. Los eventos de navegación comienzan con un nuevo documento.
Ruta de acceso correcta
Una ruta de acceso correcta incluye la secuencia completa de eventos:
- Inicio de la navegación.
- Origen cambiado, con posible entrada del mismo documento.
- Carga de contenido.
- Cambios en el historial.
- Navegación completada.
Para obtener más información, vea Eventos de navegación para aplicaciones WebView2.
Ruta de acceso de error
Si se produce un error, la ruta de acceso de error pasa directamente desde el inicio de la navegación hasta la navegación completada, omitiendo los eventos intermedios.
Cuando se produce un error, se generan los siguientes eventos y pueden depender de la navegación a una página web de error:
SourceChanged
ContentLoading
HistoryChanged
Redireccionamiento
Si se produce una redirección HTTP, hay varios NavigationStarting
eventos en una fila.
Ejemplo que muestra eventos de navegación
Para mostrar cómo usar los eventos, registre un controlador para NavigationStarting
que cancele las solicitudes que no sean HTTPS, como se indica a continuación.
En el
MainWindow.xaml.cs
archivo, modifique el constructor para que coincida con la parte superior del código siguiente. Debajo del constructor, agregue laEnsureHttps
función :public MainWindow() { InitializeComponent(); webView.NavigationStarting += EnsureHttps; } void EnsureHttps(object sender, CoreWebView2NavigationStartingEventArgs args) { String uri = args.Uri; if (!uri.StartsWith("https://")) { args.Cancel = true; } }
En el constructor,
EnsureHttps
se registra como controlador de eventos en elNavigationStarting
evento en el control WebView2.SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
Intente abrir un sitio HTTP. Asegúrese de que el control WebView2 permanece sin cambios.
Intente abrir un sitio HTTPS. El control WebView2 permite abrir sitios HTTPS.
Paso 8: Scripting
Puede usar aplicaciones host para insertar código JavaScript en controles WebView2 en tiempo de ejecución. Puede realizar una tarea en WebView2 para ejecutar JavaScript arbitrario o agregar scripts de inicialización. JavaScript insertado se aplica a todos los nuevos documentos de nivel superior y a los marcos secundarios hasta que se quita JavaScript.
El Código JavaScript insertado se ejecuta con un tiempo específico:
- Ejecútelo después de la creación del objeto global.
- Ejecútelo antes de que se ejecute cualquier otro script incluido en el documento HTML.
Por ejemplo, agregue scripts que envíen una alerta cuando un usuario navegue a sitios que no sean HTTPS, como se indica a continuación:
Modifique la
EnsureHttps
función para insertar un script en el contenido web que usa el método ExecuteScriptAsync .void EnsureHttps(object sender, CoreWebView2NavigationStartingEventArgs args) { String uri = args.Uri; if (!uri.StartsWith("https://")) { webView.CoreWebView2.ExecuteScriptAsync($"alert('{uri} is not safe, try an https link')"); args.Cancel = true; } }
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
Asegúrese de que la aplicación muestra una alerta al navegar a un sitio web que no usa HTTPS.
Paso 9: Comunicación entre el host y el contenido web
El host y el contenido web se pueden comunicar de las siguientes maneras mediante postMessage
:
El contenido web de un control WebView2 puede publicar un mensaje en el host mediante
window.chrome.webview.postMessage
. El host controla el mensaje mediante cualquier registroWebMessageReceived
en el host.Hospeda mensajes de publicación en contenido web en un control WebView2 mediante
CoreWebView2.PostWebMessageAsString
oCoreWebView2.PostWebMessageAsJSON
. Los controladores agregados awindow.chrome.webview.addEventListener
.
El mecanismo de comunicación pasa mensajes del contenido web al host mediante funcionalidades nativas.
En el proyecto, cuando el control WebView2 navega a una dirección URL, muestra la dirección URL en la barra de direcciones y alerta al usuario de la dirección URL que se muestra en el control WebView2.
En
MainWindow.xaml.cs
, actualice el constructor y cree unaInitializeAsync
función para que coincida con el código siguiente. LaInitializeAsync
función espera a EnsureCoreWebView2Async, porque la inicialización deCoreWebView2
es asincrónica.public MainWindow() { InitializeComponent(); webView.NavigationStarting += EnsureHttps; InitializeAsync(); } async void InitializeAsync() { await webView.EnsureCoreWebView2Async(null); }
Después de inicializar CoreWebView2 , registre un controlador de eventos para responder a
WebMessageReceived
. EnMainWindow.xaml.cs
, actualiceInitializeAsync
y agregueUpdateAddressBar
mediante el código siguiente:async void InitializeAsync() { await webView.EnsureCoreWebView2Async(null); webView.CoreWebView2.WebMessageReceived += UpdateAddressBar; } void UpdateAddressBar(object sender, CoreWebView2WebMessageReceivedEventArgs args) { String uri = args.TryGetWebMessageAsString(); addressBar.Text = uri; webView.CoreWebView2.PostWebMessageAsString(uri); }
Para que el control WebView2 envíe y responda al mensaje web, después
CoreWebView2
de inicializarse, el host hace lo siguiente:- Inserta un script en el contenido web que registra un controlador para imprimir el mensaje desde el host.
- Inserta un script en el contenido web que publica la dirección URL en el host.
En
MainWindow.xaml.cs
, actualiceInitializeAsync
para que coincida con el código siguiente:async void InitializeAsync() { await webView.EnsureCoreWebView2Async(null); webView.CoreWebView2.WebMessageReceived += UpdateAddressBar; await webView.CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync("window.chrome.webview.postMessage(window.document.URL);"); await webView.CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync("window.chrome.webview.addEventListener(\'message\', event => alert(event.data));"); }
SeleccioneGuardar todo en archivo> para guardar el proyecto.
Pulse F5 para compilar y ejecutar el proyecto.
Al abrir un nuevo URI, el control WebView2 muestra el URI en la barra de direcciones.
La aplicación de ejemplo muestra el URI en la barra de direcciones y en el sitio web de Microsoft: https://www.microsoft.com
Enhorabuena, ha creado su primera aplicación WebView2.
Vea también
developer.microsoft.com:
- Microsoft Edge WebView2 : introducción inicial a las características de WebView2 en developer.microsoft.com.
Páginas locales:
- Aplicación de ejemplo de WPF
- Administrar carpetas de datos de usuario
-
Código de ejemplo para WebView2 : una guía para el
WebView2Samples
repositorio. - Procedimientos recomendados de desarrollo para aplicaciones WebView2
GitHub: