Compartir vía


Tutorial: Escribir el primer script de cliente

¿Listo para escribir su primer script de cliente para ver las cosas en acción? Empecemos Mantengámoslo simple.

Objetivo

Después de finalizar este tutorial, sabrá cómo utilizar el código JavaScript en aplicaciones basadas en modelos, lo que implica los pasos siguientes a un nivel alto:

  • Localizar o crear una solución para agregar su trabajo
  • Escribir el código JavaScript para solucionar un problema del negocio
  • Cargar su código como recurso web
  • Asociar su recurso web a un formulario
  • Configurar eventos de formulario y campo
  • Probar su código

Paso 1: Localizar o crear una solución

Las soluciones son la manera en que las personalizaciones se pueden transportar de un entorno a otro. Debe escribir y probar su código JavaScript en un entorno de desarrollo como parte de una solución no administrada. Cuando haya terminado de probar, exporte la solución como solución administrada e impórtela o instálela en su entorno de producción.

Es posible que ya haya una solución existente que debería usar. La aplicación basada en modelos que desea personalizar con su script ya debería formar parte de una solución. Puede editar esa solución o crear una nueva que dependa de otra solución existente.

Para crear una solución nueva:

  1. Navegue hasta Power Apps.

  2. En el panel de navegación izquierdo, seleccione Soluciones y luego seleccione Nueva solución.

  3. En el cuadro de diálogo desplegable, especifique Nombre para mostrar, Nombre y Editor.

    La mayoría de las empresas tendrán un editor existente que siempre usarán. Debería usar ese editor. Si es la primera persona, puede crear el suyo propio.

    Haga clic en Nuevo editor para abrir el cuadro de diálogo Nuevo editor. En este tutorial, utilizaremos un editor con esta definición:

    Formulario para crear un nuevo editor con información para editor de ejemplo

    Observe el valor de Prefijo. Esto debe ser algo que identifique a su empresa. En este caso, estamos usando example.

    Esta es la solución que usaremos en este tutorial.

    Formulario de solución para la solución de script de primer cliente

  4. Busque o agregue una aplicación basada en modelo a su solución.

    Una nueva solución no incluirá ninguna aplicación basada en modelo. Necesitará agregar una aplicación basada en modelo existente o crear una nueva.

    Nota

    Para este tutorial, asegúrese de que la aplicación incluya la tabla Cuenta. Los scripts y las instrucciones siguientes esperan los campos encontrados en un formulario para la tabla Cuenta.

    Opción A: Agregar una aplicación basada en modelo existente a su solución

    1. En su solución, seleccione Agregar existente>Aplicación>Aplicación basada en modelo.

    Agregar aplicación existente basada en modelo

    1. Seleccione una aplicación existente y haga clic en Agregar.

    Opción B: Crear una nueva aplicación basada en modelo en su solución

    En su solución, puede seleccionar Nuevo>Aplicación>Aplicación basada en modelo.

    Consulte el tutorial Crear la primera aplicación basada en modelo. Cree una aplicación que incluya la tabla Cuenta.

Paso 2: Escribir su código JavaScript

El primer paso es identificar el problema del negocio que intenta abordar usando el scripting del cliente. Una vez que lo haya identificado, debe escribir el código JavaScript que contiene la lógica de negocios personalizada que trata su problema del negocio.

Las aplicaciones basadas en modelo no proporcionan un editor de JavaScript. Use una herramienta de creación externa que proporciona características específicamente para la edición de archivos JavaScript, como Notepad++, Visual Studio Code o Microsoft Visual Studio.

Este es el código JavaScript que utiliza este tutorial:

// A namespace defined for the sample code
// As a best practice, you should always define 
// a unique namespace for your libraries
var Example = window.Example || {};
(function () {
    // Define some global variables
    var myUniqueId = "_myUniqueId"; // Define an ID for the notification
    var currentUserName = Xrm.Utility.getGlobalContext().userSettings.userName; // get current user name
    var message = currentUserName + ": Your JavaScript code in action!";

    // Code to run in the form OnLoad event
    this.formOnLoad = function (executionContext) {
        var formContext = executionContext.getFormContext();

        // Display the form level notification as an INFO
        formContext.ui.setFormNotification(message, "INFO", myUniqueId);

        // Wait for 5 seconds before clearing the notification
        window.setTimeout(function () { formContext.ui.clearFormNotification(myUniqueId); }, 5000);
    }

    // Code to run in the column OnChange event 
    this.attributeOnChange = function (executionContext) {
        var formContext = executionContext.getFormContext();

        // Automatically set some column values if the account name contains "Contoso"
        var accountName = formContext.getAttribute("name").getValue();
        if (accountName.toLowerCase().search("contoso") != -1) {
            formContext.getAttribute("websiteurl").setValue("https://www.contoso.com");
            formContext.getAttribute("telephone1").setValue("425-555-0100");
            formContext.getAttribute("description").setValue("Website URL, Phone and Description set using custom script.");
        }
    }

    // Code to run in the form OnSave event 
    this.formOnSave = function () {
        // Display an alert dialog
        Xrm.Navigation.openAlertDialog({ text: "Record saved." });
    }
}).call(Example);

Copie este código en un archivo de texto y guárdelo con el nombre: Example-form-script.js.

Explicación detallada del código

Veamos el código detalladamente:

  • Defina el espacio de nombres: el código comienza definiendo un espacio de nombres de su script personalizado. Como práctica recomendada, siempre debe crear bibliotecas JavaScript del espacio de nombres para evitar que sus funciones sean reemplazadas por funciones de otra biblioteca.

    var Example = window.Example || {};
    

    En este caso, todas las funciones definidas en esta biblioteca se pueden usar como Example.[functionName]. Debe elegir un espacio de nombres que coincida con el nombre de su editor de soluciones.

  • Definir variables globales: la siguiente sección define algunas variables globales que se usan en el script. La información de contexto está ahora disponible de forma global mediante el método Xrm.Utility.getGlobalContext.

    // Define some global variables
    var myUniqueId = "_myUniqueId"; // Define an ID for the notification
    var currentUserName = Xrm.Utility.getGlobalContext().userSettings.userName; // get current user name
    var message = currentUserName + ": Your JavaScript code in action!";
    
  • Función para ejecutar en el evento OnLoad: esta sección contiene la función que se ejecutará cuando se cargue el formulario de cuenta. Por ejemplo, cuando se crea un nuevo registro de cuenta o al abrir un registro de cuenta existente.

    La función Example.formOnLoad utiliza el parámetro executionContext para obtener el objeto formContext. Cuando conecta más adelante su código al evento de formulario, debe recordar seleccionar la opción de pasar el contexto de ejecución a esta función.

    Esta función muestra una notificación de nivel de formulario mediante el método formContext.ui.setFormNotification.

    Por último, esta función usa el JavaScript setTimeOut para retardar la ejecución del método formContext.ui.clearFormNotification para eliminar la notificación después de 5 segundos.

    // Code to run in the form OnLoad event
    this.formOnLoad = function (executionContext) {
        var formContext = executionContext.getFormContext();
    
        // Display the form level notification as an INFO
        formContext.ui.setFormNotification(message, "INFO", myUniqueId);
    
        // Wait for 5 seconds before clearing the notification
        window.setTimeout(function () { formContext.ui.clearFormNotification(myUniqueId); }, 5000);        
    }
    
  • Función para ejecutar en el evento OnChange: la función Example.attributeOnChange se asociará con la columna Nombre de la cuenta en el formulario de la cuenta para que se ejecute solo cuando cambia el valor del nombre de la cuenta.

    Esta función realiza una búsqueda que no distingue entre mayúsculas y minúsculas de Contoso en el name de la cuenta y, si está presente, establece automáticamente valores para las columnas websiteurl, telephone1 y description del formulario de cuenta.

    // Code to run in the column OnChange event 
    this.attributeOnChange = function (executionContext) {
        var formContext = executionContext.getFormContext();
    
        // Automatically set some column values if the account name contains "Contoso"
        var accountName = formContext.getAttribute("name").getValue();
        if (accountName.toLowerCase().search("contoso") != -1) {
            formContext.getAttribute("websiteurl").setValue("https://www.contoso.com");
            formContext.getAttribute("telephone1").setValue("425-555-0100");
            formContext.getAttribute("description").setValue("Website URL, Phone and Description set using custom script.");
        }
    }
    
  • Función para ejecutar en el evento OnSave: la función Example.formOnSave muestra un cuadro de diálogo de alerta mediante el método Xrm.Navigation.openAlertDialog. Este cuadro de diálogo muestra un mensaje con un botón Aceptar: El usuario puede cerrar la alerta haciendo clic en Aceptar.

    Nota

    Esta función no usa el contexto de ejecución porque Xrm.Navigation. métodos no los requieren.

    // Code to run in the form OnSave event 
    this.formOnSave = function () {
        // Display an alert dialog
        Xrm.Navigation.openAlertDialog({ text: "Record saved." });
    }
    

Paso 3: Cargar su código como recurso web

Ahora que su código está listo, debe cargarlo en su solución.

  1. En su solución seleccione Nuevo>Más>Recurso web.

    Agregar un nuevo recurso web a su solución

  2. En el cuadro de diálogo Nuevo recurso web, haga clic en Elegir archivo y seleccione el archivo Example-form-script.js que guardó anteriormente.

  3. Escriba el Nombre para mostrar, Nombre, y opcionalmente una Descripción. Asegúrese de que el Tipo es JavaScript (JS).

    Nuevo cuadro de diálogo de recursos web para crear un script de formulario de ejemplo

    Nota

    • Observe cómo el Nombre tiene un prefijo que coincide con el prefijo de personalización de editor de soluciones. Hay otras formas de crear recursos web, pero crear un recurso web de esta manera garantiza que el recurso web forma parte de su solución.
    • El nombre del recurso web es example_example-form-script.

Paso 4: Asociar su recurso web a un formulario

  1. En su solución, seleccione Objectos>Aplicaciones>Su aplicación y haga clic en Editar.

    Editar la aplicación en la solución

  2. Expanda Cuenta y seleccione el Formulario de cuenta, haga clic en los puntos suspensivos (...) a la derecha del formulario Información y seleccione Editar.

    Editar el formulario de información de la cuenta

  3. En la navegación izquierda, seleccione Bibliotecas de formulario y haga clic en Agregar biblioteca.

    Agregar biblioteca a formulario

  4. En el cuadro de diálogo Agregar biblioteca de JavaScript, busque el recurso web de JavaScript que creó por nombre: Example Script.

    Cuadro de diálogo Agregar biblioteca de JavaScript

  5. Selecciona el recurso web Script de ejemplo y haga clic en Agregar.

Paso 5: Configurar eventos de formulario y campo

  1. Seleccione la pestaña Eventos.

    Controladores de eventos de formulario

Configurar el evento On Load de formulario

  1. Seleccione el controlador de eventos On Load y haga clic en + Controlador de eventos.

    Configurar el controlador On Load de formulario

    Compruebe los siguiente:

    • El Tipo de evento es On Load.
    • La biblioteca example_example-form-script está seleccionada.
    1. Escriba el nombre de la función en el campo Función. En este caso, Example.formOnLoad.
    2. Seleccione Pasar el contexto de ejecución como primer parámetro.
    3. Haga clic en Listo.

Configurar el evento On Save de formulario

  1. Seleccione el controlador de eventos On Save y haga clic en + Controlador de eventos.

    Configurar el controlador On Save de formulario

    Compruebe los siguiente:

    • El Tipo de evento es On Save.
    • La biblioteca example_example-form-script está seleccionada.
    1. Escriba el nombre de la función en el campo Función. En este caso, Example.formOnSave.

      Nota

      No es necesario elegir Pasar el contexto de ejecución como primer parámetro para esta función porque no la usa.

    2. Haga clic en Listo

Configurar evento On Change de campo

  1. Seleccione el campo Nombre de cuenta y la pestaña Eventos.

    Seleccionar eventos de campo Nombre de cuenta

  2. Seleccione el controlador de eventos On Change y haga clic en + Controlador de eventos.

    Configurar controlador OnChange de campo

    Compruebe los siguiente:

    • El Tipo de evento es On Change.
    • La biblioteca example_example-form-script está seleccionada.
    1. Escriba el nombre de la función en el campo Función. En este caso, Example.attributeOnChange.
    2. Seleccione Pasar el contexto de ejecución como primer parámetro.
    3. Haga clic en Listo

Guardar y publicar sus cambios

Debe Guardar y hacer clic en Publicar.

Paso 6: Probar su código

Se recomienda que actualice su navegador para que los cambios surtan efecto en su instancia de aplicaciones basadas en modelo.

Para probar su código:

  1. Navegue hasta Power Apps.

  2. En el panel de navegación izquierdo, seleccione Aplicaciones.

  3. Haga doble clic en la aplicación basada en modelo que acaba de editar o selecciónela y haga clic en Reproducir.

    Abrir la aplicación para probar

Probar función On Load de formulario

  1. Haga clic en cualquier registro de cuenta de la lista para abrirlo.

  2. Compruebe que aparezca la notificación.

    Notificación al cargar formulario

  3. Compruebe que la notificación desaparece en 5 segundos.

Probar función On Change de campo

  1. Edite el nombre de la cuenta para incluir "Contoso" en el nombre y pasar a la siguiente columna presionando TAB.

  2. Compruebe los valores esperados establecidos en las columnas Teléfono principal, Sitio web y Descripción

    Valores establecidos al cambiar el campo

Probar función On Save de formulario

  1. Haga clic en Guardar.

  2. Compruebe el cuadro de diálogo de alerta con un mensaje que configuró en su código.

    Cuadro de diálogo de alerta cuando se guarda el formulario

  3. Haga clic en Aceptar para cerrar la alerta.

Depuración del código JavaScript para aplicaciones basadas en modelo
Eventos en formularios y cuadrículas en aplicaciones basadas en modelos
Evento de formulario OnLoad
Evento OnSave de formulario (referencia de API de cliente) en aplicaciones basadas en modelos
Evento OnChange de la columna (referencia de la API de cliente)