Xrm.Utility (riferimento lato client)
Data di pubblicazione: gennaio 2017
Si applica a: Dynamics 365 (online), Dynamics 365 (on-premises), Dynamics CRM 2016, Dynamics CRM Online
L'oggetto Xrm.Utility fornisce un contenitore per le funzioni utili non direttamente correlate alla pagina corrente.
Queste funzionalità sono disponibili in ogni pagina dell'applicazione che supporta lo scripting. È possibile utilizzarle negli script del modulo o nei comandi della barra multifunzione. Per le risorse Web HTML, sono disponibili quando si include la pagina ClientGlobalContext.js.aspx. Per ulteriori informazioni, vedere Funzione GetGlobalContext e ClientGlobalContext.js.aspx (riferimento sul lato client).
Funzioni
Interazioni
Utilizzare alertDialog e confirmDialog per visualizzare i messaggi agli utenti e impostare il codice per l'esecuzione in base alla risposta. Queste funzionalità devono essere utilizzate con i client mobili Dynamics 365 (telefoni e tablet) al posto dei metodi window.alert e window.confirm.Funzionalità native del dispositivo (client mobili Dynamics 365)
Utilizza getBarcodeValue e getCurrentPosition per usare le funzionalità native dei dispositivi mobili per recuperare il valore di codice a barre o per recuperare la posizione corrente del dispositivo.isActivityType
Stabilire se un'entità è un'entità di tipo impegno.openEntityForm
Apre un modulo dell'entità.openQuickCreate
Per Aggiornamento 1 di Microsoft Dynamics CRM Online 2015 o versione successiva, utilizza questa funzione per aprire un nuovo modulo rapido di creazione. Puoi utilizzare questa funzione per impostare i valori predefiniti utilizzando i mapping di attributi o attributi specifici. Se un utente salva il record, puoi acquisire un riferimento al record creato.openWebResource
Apre una risorsa Web HTML.
Interazioni
Esistono due tipi di finestre di dialogo: alertDialog e confirmDialog. Queste sono incluse per l'utilizzo con script che funzionano con i client mobili Dynamics 365 (telefoni e tablet). I client mobili Dynamics 365 non consentono l'utilizzo di funzioni JavaScript che bloccano il flusso di codice, ad esempio window.alert e window.confirm. Utilizzare questi metodi invece degli altri nel caso sia necessario visualizzare un messaggio all'utente. La differenza principale è che questi metodi non bloccheranno il codice finché un utente non li chiude. Essi contengono un parametro della funzione di richiamata per indicare quale codice eseguire in base alla risposta dell'utente.
Nota
Nei client mobili Dynamics 365 (telefoni e tablet) l'utilizzo del metodo window.alert verrà sostituito con l'utilizzo di Xrm.Utility.alertDialog senza una richiamata. In questo modo verrà visualizzato il messaggi ma l'esecuzione del codice non verrà bloccata come con window.alert. Questo mapping di window.alert a Xrm.Utility.alertDialog nei client mobili Dynamics 365 è dichiarato deprecato e verrà rimosso dalla prossima versione principale. Eseguire la migrazione del codice disponibile per utilizzare Xrm.Utility.alertDialog anziché window.alert.
alertDialog
Verrà visualizzata una finestra di dialogo contenente un messaggio definito dall'applicazione.
Xrm.Utility.alertDialog(message,onCloseCallback)
Parametri
Nome
Tipo
Obbligatorio
Descrizione
messaggio
String
Sì
Il testo del messaggio da visualizzare nella finestra del messaggio.
onCloseCallback
Funzione
No
Una funzione da eseguire quando viene selezionato il pulsante OK.
Note
Questo metodo è disponibile solo per Entità aggiornate.
confirmDialog
Viene visualizzata una finestra di dialogo di conferma che contiene un messaggio facoltativo e i pulsanti OK e Annulla.
Xrm.Utility.confirmDialog(message,yesCloseCallback,noCloseCallback)
Parametri
Nome
Tipo
Obbligatorio
Descrizione
messaggio
String
Sì
Il testo del messaggio da visualizzare nella finestra di dialogo
yesCloseCallback
Funzione
No
Una funzione da eseguire quando viene selezionato il pulsante OK.
noCloseCallback
Funzione
No
Una funzione da eseguire quando viene selezionato il pulsante Annulla.
Note
Questo metodo è disponibile solo per Entità aggiornate.
Funzionalità native del dispositivo (client mobili Dynamics 365)
Utilizza questi metodi per i client Dynamics 365 per smartphone e Dynamics 365 per tablet per arricchire l'esperienza utente per gli utenti aziendali mobili nei settori delle vendite, dell'assistenza sul campo e in altre aree:
Nota
Questi metodi sono stati introdotti in Aggiornamento di dicembre 2016 per Dynamics 365 (online e locale).
getBarcodeValue
Restituisce le informazioni del codice a barre, ad esempio il codice del prodotto, digitalizzato utilizzando la fotocamera del dispositivo.
Xrm.Utility.getBarcodeValue().then(successCallback, errorCallback)
Parametri
Nome
Tipo
Necessario
Descrizione
successCallback
Funzione
Sì
Funzione da chiamare quando il valore di codice a barre è restituito.
errorCallback
Funzione
Sì
Una funzione per la chiamata per l'operazione non ha esito positivo. Verrà passato un oggetto errore con la proprietà message che descrive i dettagli di errore.
Note
Affinché il metodo getBarcodeValue funzioni, i client mobili Dynamics 365 devono poter accedere alla fotocamera del dispositivo, abilitata per impostazione predefinita.Esempio
Nel codice di esempio seguente viene illustrato come utilizzare questo metodo.Xrm.Utility.getBarcodeValue().then( function (result) { Xrm.Utility.alertDialog("Barcode value: " + result); }, function (error) { Xrm.Utility.alertDialog(error.message); })
getCurrentPosition
Restituisce la posizione corrente utilizzando la funzionalità di georilevazione del dispositivo.
Xrm.Utility.getCurrentPosition().then(successCallback, errorCallback)
Parametri
Nome
Tipo
Necessario
Descrizione
successCallback
Funzione
Sì
Funzione da chiamare quando le informazioni correnti di georilevazione sono restituite. Un oggetto di georilevazione con gli attributi seguenti viene passato alla funzione.
coords: contiene un set di coordinate geografiche con l'accuratezza associata nonché un set di altri attributi facoltativi come l'altitudine e la velocità.
timestamp: rappresenta l'ora in cui l'oggetto è stato acquistato ed è rappresentato come DOMTimeStamp.
errorCallback
Funzione
Sì
Una funzione per la chiamata per l'operazione non ha esito positivo. Verrà passato un oggetto con le proprietà seguenti:
code: numero. il codice di errore.
message: stringa. Messaggio localizzato che descrive i dettagli dell'errore.
Se l'impostazione di posizione utente non è abilitata nel dispositivo mobile, il messaggio di errore indica lo stesso. Se si utilizza una versione precedente del client mobile Dynamics 365 o se la funzionalità di georilevazione non è disponibile nel dispositivo mobile, null viene passato alla richiamata dell'errore.
Note
Affinché il metodo getCurrentPosition funzioni, la funzionalità di georilevazione deve essere abilitata nel dispositivo e i client mobili Dynamics 365 devono disporre delle autorizzazioni per l'accesso alla posizione del dispositivo, che non è abilitata per impostazione predefinita.Esempio
Nel codice di esempio seguente viene illustrato come utilizzare questo metodo.Xrm.Utility.getCurrentPosition().then (function (location) { Xrm.Utility.alertDialog("Latitude: " + location.coords.latitude + ", Longitude: " + location.coords.longitude); }, function (error) { Xrm.Utility.alertDialog(error.message); })
isActivityType
Stabilire se un'entità è un'entità di tipo impegno.
Xrm.Utility.isActivityType(entityName)
Parametro
Nome
Tipo
Obbligatorio
Descrizione
entityName
String
Sì
logicalName di un'entità.
Valore restituito
Tipo
Descrizione
Boolean
True se l'entità è un'entità di impegno, altrimenti false.
openEntityForm
Apre un modulo di entità per un record di entità nuovo o esistente tramite le opzioni impostate come parametri.
Xrm.Utility.openEntityForm(name,id,parameters,windowOptions)
Parametri
Nome
Tipo
Obbligatorio
Descrizione
nome
String
Sì
Nome logico dell'entità.
ID
String
No
La rappresentazione di stringa di un identificatore univoco o il record da aprire nel modulo. Se non impostato, viene aperto un modulo per creare un nuovo record.
parameters
Oggetto
No
Oggetto dictionary che passa parametri aggiuntivi al modulo. I parametri non validi genereranno un errore.
I parametri aggiuntivi della stringa di query sono:
ID del modulo: per impostare il valore ID del modulo principale da utilizzare quando è disponibile più di un modulo. Il parametro è formid.
ID del campo predefiniti: per impostare i valori predefiniti per un nuovo modulo del record. Per ulteriori informazioni, vedere Impostare i valori del campo utilizzando parametri passati a un modulo.
I parametri cmdbar e navbar descritti in Parametri stringa di query per la pagina Main.aspx.
Parametri della stringa di query personalizzata: un modulo può essere configurato per accettare i parametri personalizzati della stringa di query. Per ulteriori informazioni, vedere Configurare un modulo in modo che accetti i parametri querystring personalizzati.
windowOptions
Oggetto
No
Per Aggiornamento 1 di Microsoft Dynamics CRM Online 2015 o versione successiva utilizza questo parametro facoltativo nell'applicazione Web per verificare come il modulo viene aperto. Puoi aprire un modulo in una nuova finestra passando un oggetto dictionary con una proprietà openInNewWindow booleana impostata su true.
Questo parametro viene ignorato nei client mobili Dynamics 365 (telefoni e tablet).
Note
Tramite questa funzione puoi assicurare che agli utenti non venga richiesto di accedere di nuovo in determinate circostanze.Esempi
Aprire un nuovo record di account utilizzando il modulo predefinitoXrm.Utility.openEntityForm("account");
Aprire un record di account esistente utilizzando il modulo predefinito
Xrm.Utility.openEntityForm("account","A85C0252-DF8B-E111-997C-00155D8A8410");
Aprire un nuovo record di account con un modulo specifico e valori predefiniti dell'impostazione
var parameters = {}; parameters["formid"] = "b053a39a-041a-4356-acef-ddf00182762b"; parameters["name"] = "Test"; parameters["telephone1"] = "(425) 555-1234"; Xrm.Utility.openEntityForm("account", null, parameters);
Aprire un nuovo record di account utilizzando il modulo predefinito in una nuova finestra
var windowOptions = { openInNewWindow: true }; Xrm.Utility.openEntityForm("account",null,null,windowOptions);
openQuickCreate
Per Aggiornamento 1 di Microsoft Dynamics CRM Online 2015 o versione successiva, utilizza questa funzione per aprire un nuovo modulo rapido di creazione. Puoi utilizzare questa funzione per impostare i valori predefiniti utilizzando i mapping di attributi o attributi specifici. Se un utente salva il record, puoi acquisire un riferimento al record creato.
Xrm.Utility.openQuickCreate(entityLogicalName,createFromEntity,parameters).then(successCallback, errorCallback);
Parametri
Nome
Tipo
Obbligatorio
Descrizione
entityLogicalName
String
Sì
Nome logico dell'entità da creare.
createFromEntity
Lookup
No
Definisce un record che fornirà i valori predefiniti in base ai valori dell'attributo di cui è stato eseguito il mapping.
Un oggetto ricerca dispone delle seguenti proprietà String:
entityType: nome logico dell'entità.
id: rappresentazione di stringa di un valore GUID per il record.
name: valore dell'attributo primario del record.
parameters
Oggetto
No
Oggetto dictionary che passa parametri di stringa di query aggiuntivi al modulo. I parametri non validi della stringa di query genereranno un errore.
I parametri aggiuntivi della stringa di query sono:
ID del campo predefiniti: per impostare i valori predefiniti per un nuovo modulo del record. Per ulteriori informazioni, vedere Impostare i valori del campo utilizzando parametri passati a un modulo.
Parametri della stringa di query personalizzata: un modulo può essere configurato per accettare i parametri personalizzati della stringa di query. Per ulteriori informazioni, vedere Configurare un modulo in modo che accetti i parametri querystring personalizzati.
successCallback
Funzione
No
La funzione che verrà chiamata quando un record viene creato. Questa funzione ha passato un oggetto come parametro. Questo oggetto include una proprietà savedEntityReference con le proprietà seguenti per identificare il record creato:
entityType: nome logico dell'entità.
id: rappresentazione di stringa di un valore GUID per il record.
name: valore dell'attributo primario del record creato.
errorCallback
Funzione
No
Una funzione per la chiamata per l'operazione non ha esito positivo.
Verrà passato un oggetto con le proprietà seguenti:
errorCode: Number. il codice di errore.
message: String. un messaggio di errore localizzato.
Note
Questa funzione è disponibile solo per Aggiornamento 1 di Microsoft Dynamics CRM Online 2015 o versione successiva.Nell'applicazione Web è previsto un limite di 10 moduli di creazione rapidi annidati. Se questo limite è superato la funzione apre il modulo di entità completo anziché il modulo di creazione rapida.
Esempio
Quando il codice viene eseguito in un modulo dell'entità account, viene impostato un modulo di creazione rapida per creare un nuovo account figlio con un nome predefinito in modo da includere il nome dell'account padre.var thisAccount = { entityType: "account", id: Xrm.Page.data.entity.getId() }; var callback = function (obj) { console.log("Created new " + obj.savedEntityReference.entityType + " named '" + obj.savedEntityReference.name + "' with id:" + obj.savedEntityReference.id); } var setName = { name: "Child account of " + Xrm.Page.getAttribute("name").getValue() }; Xrm.Utility.openQuickCreate("account", thisAccount, setName).then(callback, function (error) { console.log(error.message); });
Se il codice viene eseguito con gli strumenti per sviluppatori browser (strumenti F12) quanto segue rappresenta l'output della console se eseguito nel contesto di un account denominato "A. Datum Corporation (sample)" e l'utente non modifica il nome predefinito impostato per il nuovo account figlio.
Created new account named 'Child account of A. Datum Corporation (sample)' with id:{1D4BFF87-E8C5-E411-80CF-00155DB58496}
openWebResource
Apre una risorsa Web HTML.
Nota
Questa funzione non è supportata per i client mobili Dynamics 365 (telefoni e tablet) e l'hub di servizio interattivo.
Xrm.Utility.openWebResource(webResourceName,webResourceData,width, height)
Parametri
Nome
Tipo
Necessari
Descrizione
webResourceName
String
Sì
Nome della risorsa Web HTML da aprire.
webResourceData
String
No
Dati da passare nel parametro di dati.
width
Numero
No
Larghezza in pixel della finestra da aprire.
height
Numero
No
Altezza in pixel della finestra da aprire.
Valore restituito
Oggetto della finestra.Note
Una risorsa Web HTML può accettare i valori di parametro descritti in Passare i parametri alle risorse Web HTML. Questa funzione fornisce solo il passaggio nel parametro dati facoltativo. Per passare i valori per gli altri parametri validi, è necessario aggiungerli al parametro webResourceName.Esempi
Aprire una risorsa Web HTML denominata "new_webResource.htm"Xrm.Utility.openWebResource("new_webResource.htm");
Aprire una risorsa Web HTML incluso un singolo elemento di dati per il parametro dati
Xrm.Utility.openWebResource("new_webResource.htm","dataItemValue");
Aprire una risorsa Web HTML passando più valori tramite il parametro dati
var customParameters = encodeURIComponent("first=First Value&second=Second Value&third=Third Value"); Xrm.Utility.openWebResource("new_webResource.htm",customParameters);
Nota
Tali valori devono essere estratti dal valore del parametro di dati nella risorsa Web HTML. Per ulteriori informazioni, vedere Esempio: passare più valori a una risorsa Web tramite il parametro dati
Aprire una risorsa Web HTML con i parametri previsti dalla risorsa Web HTML
Xrm.Utility.openWebResource("new_webResource.htm?typename=account&userlcid=1033");
Per ulteriori informazioni, vedere Passare i parametri alle risorse Web HTML.
Aprire una risorsa Web HTML, impostando l'altezza e la larghezza
Xrm.Utility.openWebResource("new_webResource.htm", null, 300,300);
Vedere anche
Riferimento programmazione sul lato client
Aprire moduli, visualizzazioni, interazioni e report con un URL
Impostare i valori del campo utilizzando parametri passati a un modulo
Configurare un modulo in modo che accetti i parametri querystring personalizzati
Riferimento rapido dello scripting dei moduli
Creare il codice per moduli di Microsoft Dynamics 365
Utilizzare il modello a oggetti Xrm.Page
Microsoft Dynamics 365
© 2017 Microsoft. Tutti i diritti sono riservati. Copyright