Compartir a través de


Vínculo profundo a una aplicación

Los vínculos profundos de Microsoft Teams son herramientas eficaces que permiten a los usuarios navegar directamente a contenido o acciones específicos dentro de una aplicación. Los vínculos profundos están configurados para realizar varias acciones, como abrir una pestaña, iniciar un cuadro de diálogo de instalación de la aplicación o examinar dentro de la aplicación.

Nota:

En este tema se refleja la versión 2.0.x de la biblioteca cliente JavaScript de Microsoft Teams (TeamsJS). Si usa una versión anterior, consulte la introducción a la biblioteca TeamsJS para obtener instrucciones sobre las diferencias entre la versión más reciente de TeamsJS y las versiones anteriores.

Estos son algunos de los escenarios en los que puede usar un vínculo profundo:

  • Instalación de aplicaciones: puede usar vínculos profundos que permiten a los usuarios saber más sobre una aplicación e instalarla en distintos ámbitos.
  • Bots y conectores: puede usar vínculos profundos en los mensajes de bots y conectores para informar a los usuarios sobre los cambios en la pestaña o sus elementos.
  • Vaya a una página específica: puede crear vínculos profundos que permitan a los usuarios navegar a páginas específicas dentro de la aplicación.
  • Aplicación personalizada: puede generar vínculos profundos para una aplicación personalizada. Sin embargo, si una aplicación de la Tienda Microsoft Teams comparte el mismo identificador de aplicación que el identificador de aplicación personalizado, el vínculo profundo abre la aplicación desde la Tienda Teams en lugar de la aplicación personalizada.
  • Para dispositivos móviles: también puede crear un vínculo profundo a una aplicación para dispositivos móviles después de que la aplicación se apruebe para el cliente móvil de Teams. Para que el vínculo profundo funcione en Teams iOS, necesita el id. de equipo de Apple App Store Connect. Para obtener más información, consulte cómo actualizar el id. de equipo de Apple App Store Connect.

Los vínculos profundos permiten a los usuarios de la aplicación abrir un cuadro de diálogo de instalación de aplicaciones para conocer cualquier información sobre la aplicación o instalarla en contextos diferentes. Puede crear un vínculo profundo a una aplicación de las siguientes maneras:

Con el vínculo profundo, puede abrir un cuadro de diálogo de instalación de la aplicación directamente desde el cliente de Teams mediante el identificador de aplicación.

https://teams.microsoft.com/l/app/<your-app-id>?tenantId=<tenantId>

<your-app-id> es el identificador de la aplicación (fxxxxxxx-0xxx-4xxx-8xxx-cxxxxxxxxxxx).

Id. de aplicación para diferentes tipos de aplicaciones

En la tabla siguiente se enumeran los distintos tipos de identificadores de aplicación usados para diferentes tipos de aplicaciones para vínculos profundos:

Tipo de aplicación Tipo de identificador de aplicación
Aplicación personalizada cargada en Teams Identificador de manifiesto
Aplicaciones enviadas al catálogo de la organización Id. de catálogo de la organización
Aplicaciones enviadas a la Tienda Teams Id. de tienda

Para obtener más información, consulte cómo buscar el identificador en función del identificador de manifiesto de la aplicación.

Las aplicaciones pueden usar la biblioteca cliente javaScript de Microsoft Teams (TeamsJS) para iniciar el cuadro de diálogo de instalación de la aplicación, lo que elimina la necesidad de generación manual de vínculos profundos. Este es un ejemplo de cómo desencadenar el cuadro de diálogo de instalación de la aplicación mediante TeamsJS dentro de la aplicación:

// Open an app install dialog from your tab
if(appInstallDialog.isSupported()) {
    const dialogPromise = appInstallDialog.openAppInstallDialog({ appId: "<appId>" });
    dialogPromise.
      then((result) => {/*Successful operation*/}).
      catch((error) => {/*Unsuccessful operation*/});
}
else { /* handle case where capability isn't supported */ }

Para más información, vea appInstallDialog.

Los usuarios de la aplicación pueden examinar el contenido de Teams desde la pestaña mediante TeamsJS. Puede usar un vínculo profundo para examinar dentro de la aplicación si la pestaña necesita conectar usuarios con otro contenido en Teams, como un canal, un mensaje, otra pestaña o para abrir un cuadro de diálogo de programación. En algunos casos, la navegación también se puede realizar con TeamsJS y se recomienda usar las funcionalidades con tipo de TeamsJS siempre que sea posible.

Puede configurar vínculos profundos para examinar dentro de la aplicación de las siguientes maneras:

Las pestañas personales tienen un ámbito personal, mientras que las pestañas de canal y grupo usan ámbitos team o group. Los dos tipos de tabulación tienen una sintaxis ligeramente diferente, ya que solo la pestaña configurable tiene una channel propiedad asociada a su objeto de contexto. Para obtener más información sobre los ámbitos de pestaña, consulte manifiesto de aplicación.

Para crear un vínculo profundo en un bot, conector o tarjeta de extensión de mensaje, use el formato siguiente:

https://teams.microsoft.com/l/entity/<appId>/<entityId>?tenantId=<tenantId>&webUrl=<entityWebUrl>&label=<entityLabel>&context=<context>&openInMeeting=false

  • Si el bot envía un mensaje que contiene un TextBlock con un vínculo profundo, se abre una nueva pestaña del explorador cuando el usuario selecciona el vínculo. Esto sucede en Chrome y en la aplicación de escritorio de Teams cuando se ejecutan en Linux.

  • Si el bot envía la misma dirección URL de vínculo profundo a , Action.OpenUrlla pestaña Teams se abre en la pestaña del explorador actual cuando el usuario selecciona el vínculo.

Parámetros de consulta

Nombre del parámetro Descripción
appId Identificador del Centro de administración de Microsoft Teams.

Ejemplo: fe4a8eba-2a31-4737-8e33-e5fae6fee194
entityId Identificador de la pestaña, que proporcionó al configurar la pestaña. Al generar una dirección URL para la vinculación profunda, siga usando el identificador de entidad como nombre de parámetro en la dirección URL. Al configurar la pestaña, el objeto de contexto hace referencia a entityId como page.id.

Ejemplo: Lista de tareas 123
entityWebUrl o subEntityWebUrl Un campo opcional con una dirección URL de reserva que se usará si el cliente no admite la representación de la pestaña.

Ejemplo: https://tasklist.example.com/123
Otra posibilidad:
https://tasklist.example.com/list123/task456
entityLabel o subEntityLabel Etiqueta para el elemento de la pestaña que se va a usar al mostrar el vínculo profundo.

Ejemplo: Lista de tareas 123 o Tarea 456
context.subEntityId Un identificador para el elemento dentro de la pestaña. Al generar una dirección URL para la vinculación profunda, siga usando subEntityId como nombre de parámetro en la dirección URL. Al configurar la pestaña, el objeto de contexto hace referencia a subEntityId como page.subPageId.

Ejemplo: Tarea 456
context.channelId Id. de canal de Microsoft Teams que está disponible en la pestaña contexto. Esta propiedad solo está disponible en pestañas configurables con un ámbito de equipo. No está disponible en pestañas estáticas, que tiene un ámbito personal .

Ejemplo: 19:cbe3683f25094106b826c9cada3afbe0@thread.skype
context.chatId Identificador de chat que está disponible en el contexto de pestaña para el chat de grupo y reunión.

Ejemplo: 17:b42de192376346a7906a7dd5cb84b673@thread.v2
context.contextType Chat es el único compatible con contextType reuniones.

Ejemplo: chat
openInMeeting Use openInMeeting para controlar la experiencia del usuario cuando la pestaña de destino está asociada a una reunión. Si el usuario interactúa con el vínculo profundo en una experiencia de reunión en curso, Teams abre la aplicación en el panel del lado de la reunión. Establezca este valor false en para abrir siempre la aplicación en la pestaña de chat de reunión en lugar del panel lateral, independientemente del estado de la reunión. Teams omite cualquier valor distinto de false.

Ejemplo: false

Importante

  • Asegúrese de que todos los parámetros de consulta y los espacios en blanco estén correctamente codificados mediante URI. A continuación se muestra un ejemplo de parámetros de consulta codificados por URI:

    var encodedWebUrl = encodeURIComponent('https://tasklist.example.com/123/456&label=Task 456');
    var encodedContext = encodeURIComponent(JSON.stringify({"subEntityId": "task456"}));
    var taskItemUrl = 'https://teams.microsoft.com/l/entity/fe4a8eba-2a31-4737-8e33-e5fae6fee194/tasklist123?webUrl=' + encodedWebUrl + '&context=' + encodedContext;
    
  • No se admite el vínculo profundo a una aplicación de Teams con URI codificado en Outlook.

Puede configurar vínculos profundos en la aplicación a través de TeamsJS para permitir a los usuarios examinar diferentes páginas dentro de la aplicación. El comportamiento de navegación de una aplicación de Teams extendida en Microsoft 365 Office depende de dos factores:

  1. Destino al que apunta el vínculo profundo.
  2. Host en el que se ejecuta la aplicación de Teams.

Si la aplicación de Teams se ejecuta dentro del host donde se dirige el vínculo profundo, la aplicación se abre directamente dentro del host. Sin embargo, si la aplicación de Teams se ejecuta en un host diferente desde el que se dirige el vínculo profundo, la aplicación se abre primero en el explorador.


Compatibilidad con vínculos profundos en TeamsJS

TeamsJS permite que las aplicaciones de Teams extendidas en Outlook y Microsoft 365 comprueben si el host admite la funcionalidad que intenta usar. Para comprobar la compatibilidad de un host con una funcionalidad, puede usar la función isSupported() asociada al espacio de nombres de la API. TeamsJS organiza las API en funcionalidades mediante espacios de nombres. Por ejemplo, antes de usar una API en el pages espacio de nombres, puede comprobar el valor booleano devuelto desde pages.isSupported() y realizar la acción adecuada en el contexto de la aplicación y la interfaz de usuario de la aplicación. Para obtener más información, consulte Creación de pestañas y otras experiencias hospedadas con la biblioteca TeamsJS.

En el código siguiente se muestra cómo navegar a una entidad específica dentro de la aplicación de Teams:

Puede desencadenar una navegación desde la pestaña mediante la función pages.navigateToApp() como se muestra en el código siguiente:

if (pages.isSupported()) {
  const navPromise = pages.navigateToApp({ appId: <appId>, pageId: <pageId>, webUrl: <webUrl>, subPageId: <subPageId>, channelId:<channelId>});
  navPromise.
     then((result) => {/*Successful navigation*/}).
     catch((error) => {/*Failed navigation*/});
}
else { /* handle case where capability isn't supported */ }

La funcionalidad de páginas de la biblioteca TeamsJS proporciona compatibilidad para la navegación entre pestañas dentro de una aplicación. En concreto, el pages.currentApp espacio de nombres ofrece una función navigateTo(NavigateWithinAppParams) para permitir la navegación a una pestaña específica dentro de la aplicación actual y una función navigateToDefaultPage() para navegar a la primera pestaña definida en el manifiesto de la aplicación. En el código siguiente se muestra cómo navegar a una pestaña específica y predeterminada:

En el código siguiente se muestra cómo navegar a una pestaña específica:

if (pages.currentApp.isSupported()) {
    const navPromise = pages.currentApp.navigateTo({pageId: <pageId>, subPageId: <subPageId>});
    navPromise.
        then((result) => {/*Successful navigation*/}).
        catch((error) => {/*Failed navigation*/});
}
else {/*Handle situation where capability isn't supported*/
    const navPromise = pages.navigateToApp({appId: <appId>, pageId: <pageId>});
    navPromise.
        then((result) => {/*Successful navigation*/}).
        catch((error) => {/*Failed navigation*/});
}

Nota:

La navegación de la aplicación de pestaña solo se admite en el nuevo cliente de Teams.

Configuración de la navegación del botón Atrás

Cuando una aplicación tiene varias pestañas, un usuario puede usar el botón Atrás de la aplicación host de Microsoft 365 para retroceder en el historial de navegación. Sin embargo, el historial no incluye las acciones que un usuario realiza dentro de una pestaña. Si desea mejorar la experiencia del botón Atrás, puede mantener su propia pila de navegación interna y configurar un controlador personalizado para las selecciones de botón atrás. Esto se puede realizar a través de la registerBackButtonHandler() función en el espacio de pages.backStack nombres.

Después de registrar el controlador, le ayuda a abordar la solicitud de navegación antes de que el sistema tome medidas. Si el controlador puede administrar la solicitud, debe devolverse true para que el sistema sepa que no es necesario realizar ninguna acción adicional. Si la pila interna está vacía, debe devolverse false para que el sistema pueda llamar a la navigateBack() función en su lugar y realizar la acción adecuada.

Devolver el foco a la aplicación host

Una vez que el usuario comienza a usar elementos dentro de una pestaña, de forma predeterminada, el foco permanece con los elementos del iFrame hasta que el usuario selecciona fuera de ella. Si el iFrame forma parte del usuario que navega con métodos abreviados de teclado (la tecla Tab o la tecla F6), puede centrarse en la aplicación host. Puede centrarse en la aplicación host mediante la pages.returnFocus() función . La returnFocus() función acepta un valor booleano que indica la dirección para avanzar el foco dentro de la aplicación host; true para adelante y false hacia atrás. Por lo general, forward resalta la barra de búsqueda y hacia atrás resalta la barra de la aplicación.

Puede permitir que los usuarios de la aplicación naveguen a un chat personal con la aplicación configurando manualmente el vínculo profundo.

https://teams.microsoft.com/l/entity/<appId>/conversations?tenantId=<tenantId>

appId es el identificador de la aplicación. Para obtener más información, consulte Id. de aplicación para diferentes tipos de aplicaciones.

Puede compartir vínculos profundos a entidades en aplicaciones de Teams para navegar al contenido y la información de la aplicación de pestaña. Por ejemplo, si la aplicación de pestaña contiene una lista de tareas, los miembros del equipo pueden crear y compartir vínculos a tareas individuales. Cuando el usuario de la aplicación selecciona el vínculo, se desplaza a la pestaña que se centra en el elemento específico.

Agregue una acción de vínculo de copia a cada elemento de la manera que mejor se adapte a la interfaz de usuario. Cuando el usuario realice esta acción, llame pages.shareDeepLink() a para mostrar un cuadro de diálogo que contiene un vínculo que el usuario puede copiar en el Portapapeles. Cuando realice esta llamada, pase un id. para el elemento. Se vuelve a poner en contexto cuando se sigue el vínculo y se vuelve a cargar la pestaña.

pages.shareDeepLink({ subPageId: <subPageId>, subPageLabel: <subPageLabel>, subPageWebUrl: <subPageWebUrl> })

Debe reemplazar los parámetros siguientes por la información adecuada:

Nombre del parámetro Descripción
subPageId Identificador único del elemento dentro de la página a la que está vinculando en profundidad.
subPageLabel Etiqueta del elemento que se va a usar para mostrar el vínculo profundo.
subPageWebUrl Dirección URL de reserva que se usará si el cliente no puede representar la página.

Para obtener más información, vea pages.shareDeepLink().

Nota:

  • Este vínculo profundo es diferente de los vínculos proporcionados por el elemento de menú Copiar vínculo a pestaña , que solo genera un vínculo profundo que apunta a esta pestaña.
  • shareDeepLink no funciona en plataformas móviles de Teams.

Los vínculos profundos de las pestañas de SharePoint Framework (SPFx) permiten a los usuarios navegar directamente a pestañas específicas dentro de un sitio de SharePoint o una aplicación de Teams. Esto mejora la experiencia del usuario al proporcionar acceso rápido al contenido y la funcionalidad pertinentes.

Puede usar el siguiente formato de vínculo profundo en un bot, conector o tarjeta de extensión de mensaje:

https://teams.microsoft.com/l/entity/<appId>/<EntityId>?webUrl=<entityWebUrl>/<EntityName>.

Nota:

  • Cuando un bot envía un TextBlock mensaje con un vínculo profundo, se abre una nueva pestaña del explorador cuando los usuarios seleccionan el vínculo. Esto sucede en Chrome y en la aplicación de escritorio de Microsoft Teams, ejecutados en Linux.
  • Si el bot envía la misma dirección URL de vínculo profundo en un Action.OpenUrl, la pestaña Teams se abre en el explorador actual cuando el usuario selecciona el vínculo. No se abre una nueva pestaña del explorador.

Parámetros de consulta

Valor Descripción
APP_ID El identificador de manifiesto.

Ejemplo: fxxxxxxx-0xxx-4xxx-8xxx-cxxxxxxxxxxx
entityID Identificador de elemento que proporcionó al configurar la pestaña.

Ejemplo: tasklist123
entityWebUrl Dirección URL de reserva que se usará si el cliente no admite la representación de la pestaña.

Ejemplo: https://tasklist.example.com/123 o https://tasklist.example.com/list123/task456
entityName Etiqueta para el elemento de la pestaña que se va a usar al mostrar el vínculo profundo.

Ejemplo: Task List 123 o Task 456

Un vínculo profundo de cuadro de diálogo es una serialización del TaskInfo objeto con otros dos detalles, y, opcionalmente, APP_ID .BOT_APP_ID

  • https://teams.microsoft.com/l/task/APP_ID?url=<TaskInfo.url>&height=<TaskInfo.height>&width=<TaskInfo.width>&title=<TaskInfo.title>&completionBotId=BOT_APP_ID

  • https://teams.microsoft.com/l/task/APP_ID?card=<TaskInfo.card>&height=<TaskInfo.height>&width=<TaskInfo.width>&title=<TaskInfo.title>&completionBotId=BOT_APP_ID

Para conocer los tipos de datos y los valores permitidos para <TaskInfo.url>, <TaskInfo.card>, <TaskInfo.height>, <TaskInfo.width> y <TaskInfo.title>, consulte Objeto TaskInfo.

Sugerencia

Codifique la dirección URL del vínculo profundo al usar el card parámetro , por ejemplo, la función de JavaScriptencodeURI().

En la siguiente tabla se proporciona información sobre APP_ID y BOT_APP_ID:

Valor Tipo Obligatorio Descripción
APP_ID string - Para aplicaciones de terceros, use la aplicación id desde el manifiesto o desde el APP_ID Centro de administración de Teams, ya que son idénticas.

- Para aplicaciones personalizadas o aplicaciones personalizadas creadas para su organización (aplicaciones LOB), use desde el APP_ID Centro de administración de Teams o use el Graph API.

- La matriz validDomains del manifiesto de APP_ID debe contener el dominio para url si url está presente en la dirección URL del vínculo profundo. El identificador de aplicación ya se conoce cuando se invoca un cuadro de diálogo desde una pestaña o un bot, por lo que no se incluye en TaskInfo.
BOT_APP_ID string No Si se especifica un valor para completionBotId, el objeto result se envía mediante un mensaje task/submit invoke al bot especificado. Debe BOT_APP_ID especificarse como bot en el manifiesto de la aplicación, que no se puede enviar a ningún bot.

Nota:

APP_ID y BOT_APP_ID puede ser el mismo en muchos casos, si una aplicación tiene un bot recomendado para usarlo como identificador de una aplicación y si hay uno.

También puede generar un vínculo profundo para compartir la aplicación para realizar la fase e iniciar o unirse a una reunión.

Para obtener vínculos profundos para compartir contenido para realizar la fase, consulte vínculo profundo para compartir contenido en la fase de las reuniones.

Nota:

  • La generación de un vínculo profundo para compartir contenido para la fase de las reuniones solo está disponible en la versión preliminar del desarrollador público.
  • El vínculo profundo para compartir contenido para la fase de reunión solo se admite en el cliente de escritorio de Teams.

Puede generar un vínculo profundo al panel lateral de la reunión en una reunión.

Use el siguiente formato para un vínculo profundo al panel lateral de la reunión:

https://teams.microsoft.com/l/entity/<appId>/<entityId>?webUrl=<entityWebUrl>&label=<entityLabel>&context=<context>.

De forma predeterminada, se abre un vínculo profundo en un panel lateral de la reunión. Para abrir un vínculo profundo directamente en una aplicación en lugar del panel lateral de la reunión, agregue openInMeeting=false como se muestra en el siguiente formato de vínculo profundo:

https://teams.microsoft.com/l/entity/<appId>/<entityId>?webUrl=<entityWebUrl>&label=<entityLabel>&context=<context>&openInMeeting=false

Para obtener más información, consulte vínculo profundo a una pestaña.

Un vínculo profundo no se abre en el panel lateral de la reunión en los siguientes escenarios:

  • No hay ninguna reunión activa.
  • La aplicación no tiene sidePanel el contexto declarado en el manifiesto de la aplicación.
  • openInMeeting se establece false en en el vínculo profundo.
  • El vínculo profundo se selecciona fuera de la ventana o componente de la reunión.
  • El vínculo profundo no coincide con la reunión actual, por ejemplo, si el vínculo profundo se crea a partir de otra reunión.

Puede invocar Stageview a través de un vínculo profundo desde la pestaña ajustando la dirección URL del vínculo profundo en la app.openLink(url) API. El vínculo profundo también se puede pasar a través de una acción OpenURL en la tarjeta. La openMode propiedad definida en la API determina la respuesta de Stageview. Para obtener más información, consulte invocación de Stageview a través de un vínculo profundo.

Procedimientos recomendados

  • Los vínculos profundos solo funcionan correctamente si la pestaña se configuró mediante la biblioteca v0.4 o posterior, ya que tiene un identificador de entidad. Los vínculos profundos a las pestañas sin identificadores de entidad siguen a la pestaña, pero no pueden proporcionar el sub'EntityId a la pestaña.
  • En Microsoft Windows, Teams no puede controlar vínculos profundos que superen los 2048 caracteres debido al INTERNET_MAX_URL_LENGTH límite de Windows ShellExecuteEx API.
  • Al crear un vínculo profundo, asegúrese de que la ruta de acceso al cliente de Teams y otros metadatos caben dentro de este límite.
  • Si el vínculo profundo contiene datos grandes, incluya un identificador único en el vínculo que la aplicación puede usar para capturar los datos necesarios del servicio back-end.

Ejemplo de código

Ejemplo de nombre Descripción .NET Node.js TypeScript
Uso de vínculos profundos subEntityId En este ejemplo se muestra cómo usar un vínculo profundo desde un chat de bot a una pestaña que consume .subEntityId También muestra vínculos profundos para:
- Navegar a una aplicación
- Navegar a un chat
- Abrir un cuadro de diálogo de perfil
- Abrir un cuadro de diálogo de programación
View View ND
Navegación de la aplicación de tabulación En este ejemplo se muestra cómo navegar entre pestañas dentro de la aplicación. ND View ND
Tabulación de valores de paso de vínculo profundo En este ejemplo se muestra cómo usar vínculos profundos dinámicos para transmitir valores a aplicaciones web independientes y de pestaña. ND ND View