Área Web
Las áreas web pueden mostrar varios tipos de contenido web dentro de sus formularios: páginas HTML con contenidos estáticos o dinámicos, archivos, imágenes, JavaScript, etc. El motor de renderizado del área web depende de la plataforma de ejecución de la aplicación y de la opción motor de renderizado seleccionada.
Es posible crear varias áreas web en el mismo formulario. Tenga en cuenta, sin embargo, que el uso de las áreas web debe seguir varias reglas.
Several dedicated standard actions, numerous language commands as well as generic and specific form events allow the developer to control the functioning of web areas. Se pueden utilizar variables específicas para intercambiar información entre el área y el entorno 4D.
Propiedades específicas
Variables asociadas
Se pueden asociar dos variables específicas a cada área web:
URL
--para controlar la URL mostrada por el área webProgression
-- para controlar el porcentaje de carga de la página mostrada en el área web.
A partir de 4D v19 R5, la variable Progression ya no se actualiza en las Áreas Web que utilizan el motor de renderizado del sistema Windows.
Motor de renderización web
Puede elegir entre dos motores de renderizado para el área web, dependiendo de las especificaciones de su aplicación.
Seleccionar el motor de renderizado web anidado permite llamar a los métodos de 4D desde el área web y asegurarse de que las funcionalidades en macOS y Windows sean similares. Se recomienda seleccionar el motor de renderizado del sistema cuando el área web está conectada a Internet porque siempre se beneficia de las últimas actualizaciones de seguridad.
Acceder a los métodos 4D
Cuando la propiedad Acceso a métodos 4D está seleccionada, puede llamar a métodos 4D desde un área web.
- Esta propiedad sólo está disponible si el área web utiliza el motor de renderizado web integrado.
- Por razones de seguridad, ya que permite ejecutar código 4D, esta opción solo debe habilitarse para páginas de confianza, como las páginas generadas por la aplicación.
Objeto $4d
El motor de renderizado web integrado suministra el área con un objeto JavaScript llamado $4d que puede asociar con cualquier método de proyecto 4D usando la notación de objeto ".".
Por ejemplo, para llamar al método HelloWorld
de 4D, basta con ejecutar la siguiente declaración:
$4d.HelloWorld();
JavaScript is case sensitive so it is important to note that the object is named $4d (with a lowercase "d").
La sintaxis de las llamadas a los métodos 4D es la siguiente:
$4d.4DMethodName(param1,paramN,function(result){})
-
param1...paramN
: puede pasar tantos parámetros como necesite al método 4D. Estos parámetros pueden ser de cualquier tipo soportado por JavaScript (cadena, número, array, objeto). -
function(result)
: función a pasar como último argumento. Esta función "callback" se llama de forma sincrónica una vez que el método 4D termina de ejecutarse. Recibe el parámetroresult
. -
result
: Execution result of the 4D method. Este resultado puede ser de cualquier tipo soportado por JavaScript (cadena, número, array, objeto).
Por defecto, 4D trabaja en UTF-8. Cuando devuelva un texto que contenga caracteres extendidos, por ejemplo, caracteres con acentos, asegúrese de que la codificación de la página mostrada en el área web esté declarada como UTF-8, ya que de lo contrario los caracteres podrían representarse incorrectamente. En este caso, añada la siguiente línea en la página HTML para declarar la codificación:
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
Ejemplo 1
Dado un método proyecto 4D llamado today
que no recibe parámetros y devuelve la fecha actual como una cadena.
Código 4D del método today
:
#DECLARE : Text
return String(Current date;System date long)
En el área web, el método 4D puede ser llamado con la siguiente sintaxis:
$4d.today()
The 4D method does not receive any parameters but it does return the result to the callback function called by 4D after the execution of the method. Queremos mostrar la fecha en la página HTML que es cargada por el área web.
Aquí está el código de la página HTML:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<script type="text/javascript">
$4d.today(function(result)
{
var curDate = result;
document.getElementById("mydiv").innerHTML=curDate;
});
</script>
</head>
<body>Today is: <div id="mydiv"></div>
</body>
</html>
Ejemplo 2
The 4D project method calcSum
receives parameters and returns their sum:
Código 4D del método calcSum
:
#DECLARE (... : Real) -> $sum : Real
// receives n Real type parameters
// and returns a Real
var $i; $n : Integer
$n:=Count parameters
For($i;1;$n)
$0:=$0+${$i}
End for
El código JavaScript que se ejecuta en el área web es el siguiente:
$4d.calcSum(33, 45, 75, 102.5, 7, function(theSum)
{
var result = theSum // result is 262.5
});
Acciones estándar
Existen cuatro acciones estándar específicas para gestionar automáticamente las áreas web: Open Back URL
, Open Forward URL
, Refresh Current URL
y Stop Loading URL
. Estas acciones pueden asociarse a botones o comandos de menú y permiten una rápida implementación de interfaces web básicas. Estas acciones pueden asociarse a botones o comandos de menú y permiten una rápida implementación de interfaces web básicas.
Eventos formulario
Los eventos formulario específicos están destinados a la gestión programada de las áreas de la web, más concretamente a la activación de los enlaces:
On Begin URL Loading
On URL Resource Loading
On End URL Loading
On URL Loading Error
On URL Filtering
On Open External Link
On Window Opening Denied
Además, las áreas web soportan los siguientes eventos de formulario genéricos:
Reglas de las áreas web
Interfaz de usuario
Cuando se ejecuta el formulario, las funciones estándar de la interfaz del navegador están disponibles para el usuario en el área web, lo que permite la interacción con otras áreas del formulario:
- Comandos menú Edición: cuando el área web tiene el foco, los comandos del menú Edición pueden utilizarse para realizar acciones como copiar, pegar, seleccionar todo, etc., según la selección.
- Menú contextual: es posible utilizar el [menú contextual] estándar (properties_Entry.md#context-menu) del sistema con el área web. Display of the context menu can be controlled using the
WA SET PREFERENCE
command. - Arrastrar y soltar: el usuario puede arrastrar y soltar texto, imágenes y documentos dentro del área web o entre un área web y los objetos de los formularios 4D, según las propiedades de los objetos 4D.
Por razones de seguridad, no se permite por defecto cambiar el contenido de un área web mediante la acción de arrastrar y soltar un archivo o una URL. En este caso, el cursor muestra un icono de "prohibido" . Tiene que usar la instrucción
WA SET PREFERENCE(*; "warea";WA enable URL drop;True)
para mostrar un icono "drop" y generar el eventoOn Window Opening Denied
. In this event, you can call theWA OPEN URL
command or set the URL variable in response to a user drop.
Las funciones de arrastrar y soltar descritas anteriormente no son compatibles con las áreas web que utilizan el motor de renderizado del sistema macOS.
Subformularios
Por razones relacionadas con los mecanismos de redibujado de ventanas, la inserción de un área web en un subformulario está sujeta a las siguientes restricciones:
- El subformulario no debe poder desplazarse
- Los límites del área web no deben superar el tamaño del subformulario
No se soporta la superposición de un área web sobre o debajo de otros objetos formulario.
Conflicto entre el área web y el servidor web (Windows)
En Windows, no se recomienda acceder, a través de un área web, al servidor web de la aplicación 4D que contiene el área, ya que esta configuración podría provocar un conflicto que paralice la aplicación. Por supuesto, un 4D remoto puede acceder al servidor web de 4D Server, pero no a su propio servidor web.
Inserción del protocolo (macOS)
Las URLs manejadas por programación en áreas web bajo macOS deben comenzar con el protocolo. Por ejemplo, debe pasar la cadena "http://www.mysite.com" y no sólo "www.mysite.com".
Acceso al inspector web
Puede visualizar y utilizar un inspector web dentro de las áreas web de sus formularios o en las áreas web fuera de la pantalla. El inspector web es un depurador que permite analizar el código y el flujo de información de las páginas web.
Para mostrar el inspector Web, puede ejecutar el comando WA OPEN WEB INSPECTOR
o utilizar el menú contextual del área web.
-
Execute the
WA OPEN WEB INSPECTOR
command
This command can be used directly with onscreen (form object) and offscreen web areas. -
Use the web area context menu
This feature can only be used with onscreen web areas and requires that the following conditions are met:- el menú contextual del área web está activado
- el uso del inspector está expresamente autorizado en el área mediante la siguiente declaración:
WA SET PREFERENCE(*;"WA";WA enable Web inspector;True)
Con el motor de renderizado del sistema de Windows, un cambio en esta preferencia requiere que se tenga en cuenta una acción de navegación en el área (por ejemplo, una actualización de la página).
For more information, refer to the description of the WA SET PREFERENCE
command.
Cuando haya realizado los ajustes como se ha descrito anteriormente, entonces tendrá nuevas opciones como Inspeccionar el elemento en el menú contextual del área. Al seleccionar esta opción, se muestra la ventana del inspector web.
Para una descripción detallada de las funcionalidades de este depurador, consulte la documentación que ofrece el motor de renderizado web.
Propiedades soportadas
Estilo de línea de borde - Fondo - Clase - Menú contextual - Altura - Tamaño horizontal - Izquierda - Método - Nombre del objeto - Progresión - Derecha - Arriba - Tipo - URL - Usar motor de renderizado web incrustado - Variable o expresión - Tamaño vertical - Visibilidad - Ancho
4DCEFParameters.json
El 4DCEFParameters.json es un archivo de configuración que permite la personalización de los parámetros CEF para gestionar el comportamiento de las áreas web dentro de las aplicaciones 4D.
Se suministran interruptores predeterminados, pero puede reemplazarlos usando un archivo 4DCEFParameters.json personalizado.
En la fase de desarrollo (utilizando la aplicación 4D), cree un archivo 4DCEFParameters.json en la siguiente ubicación:
- Windows:
Users\[userName]\AppData\Roaming\4D\4DCEFParameters.json
- macOS:
$HOME/Library/Application Support/4D/4DCEFParameters.json
Antes de generar la aplicación final, añada el archivo personalizado 4DCEFParameters.json a la carpeta Resources del proyecto.
Añadir un archivo 4DCEFParameters.json personalizado puede afectar fundamentalmente a todas las áreas web integradas de 4D, incluyendo las áreas 4D View Pro. Es responsabilidad del desarrollador asegurarse de que los interruptores personalizados no desestabilizan la aplicación 4D.
El formato del archivo 4DCEFParameters.json es el siguiente:
{
"switches":{
"key":value
},
"macOS":{
"switches": {
"key":value
}
},
"windows": {
"switches": {
"key":value
}
}
}
La estructura del archivo 4DCEFParameters.json contiene:
- switches: una lista de switches CEF y sus correspondientes valores aplicados tanto para macOS como para Windows.
- macOS.switches: conmutadores CEF específicos de macOS.
- windows.switches: interruptores CEF específicos para Windows.
Los interruptores del archivo personalizado tienen prioridad. En caso de duplicación de interruptores dentro del mismo archivo, los interruptores definidos en la subsección específica de la plataforma ("macOS.switches" o "windows.switches") tienen prioridad y son usadas para la configuración.
La lista de conmutadores compatibles evoluciona constantemente y está gestionada por el equipo de desarrollo de CEF. Para obtener información sobre los conmutadores disponibles, debe consultar la comunidad de desarrolladores de CEF.
Ejemplos
Archivo por defecto
El archivo 4DCEFParameters.json por defecto contiene los siguientes cambios:
{
"switches":{
"enable-media-stream":true,
"enable-print-preview":true
},
"macOS":{
"switches": {
"use-mock-keychain": true
}
},
"windows": {
"switches": {
"disable-features": "WinUseBrowserSpellChecker"
}
}
}
Ejemplo de desactivación del interruptor por defecto
{
"switches": {
"disable-javascript": true,
"disable-web-security": true
}
}
Ejemplo para Autoplay
{
"switches":{
"autoplay-policy": "no-user-gesture-required"
}
}
Ver también
Especifique sus propios parámetros para inicializar el área web integrada (entrada de blog)