Código de JavaScript - Función para utilizar AJAX sin ninguna framework

Imágen de perfil
Val: 285
Bronce
Ha aumentado 1 puesto en JavaScript (en relación al último mes)
Gráfica de JavaScript

Función para utilizar AJAX sin ninguna frameworkgráfica de visualizaciones


JavaScript

Publicado el 14 de Abril del 2019 por Info (84 códigos)
832 visualizaciones desde el 14 de Abril del 2019
Este código muestra como utilizar AJAX con javascript para hacer nuestros desarrollos, sin tener que utilizar ningún framework

1
estrellaestrellaestrellaestrellaestrella(1)

Publicado el 14 de Abril del 2019gráfica de visualizaciones de la versión: 1
833 visualizaciones desde el 14 de Abril del 2019
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Este código ha sido obtenido de: https://stackoverflow.com/questions/8567114/how-to-make-an-ajax-call-without-jquery

el archivo x.php para este ejemplo, lo único que hace es devolver un json con los valores recibidos, ya sean por GET o POST:
1
2
3
4
5
6
7
8
9
10
11
12
<?php
 
$result=[];
foreach($_GET as $key=>$value) {
	$result[$key]=$value;
}
 
foreach($_POST as $key=>$value) {
	$result[$key]=$value;
}
 
echo json_encode($result);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<script>
const ajax = {
 
    /**
     * Función que nos inicializa el objeto
     * @return object
     */
    _x:function () {
        if (typeof XMLHttpRequest !== 'undefined') {
            return new XMLHttpRequest();
        }
        let versions = [
            "MSXML2.XmlHttp.6.0",
            "MSXML2.XmlHttp.5.0",
            "MSXML2.XmlHttp.4.0",
            "MSXML2.XmlHttp.3.0",
            "MSXML2.XmlHttp.2.0",
            "Microsoft.XmlHttp"
        ];
 
        let xhr;
        for (let i = 0; i < versions.length; i++) {
            try {
                xhr = new ActiveXObject(versions[i]);
                break;
            } catch (e) {
            }
        }
        return xhr;
    },
 
    /**
     * Funcion que hace el envio AJAX
     * @param str url
     * @param str callback - nombre de la función a devolver el resultado
     * @param str method - [POST|GET]
     * @param str data
     */
    _send:function (url, callback, method, data) {
        let x = this._x();
        x.open(method, url, true);
        x.onreadystatechange = function() {
 
            // Si el estado de la conexion es completa
            if (x.readyState === 4) {
                if (x.status >= 400) {
                    x.showError(x.status);
                }
                if (x.status === 200) {
                    callback(x.responseText)
                }
            }
        };
        if (method == 'POST') {
            x.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
        }
        x.send(data)
    },
 
    /**
     * Funcion para hacer una llamada AJAX enviando los datos por GET
     * @param str url
     * @param str callback - nombre de la función a devolver el resultado
     * @param json data
     */
    get:function (url, callback, data) {
        let query = [];
        for (let key in data) {
            query.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key]));
        }
        this._send(url + (query.length ? '?' + query.join('&') : ''), callback, 'GET', null)
    },
 
    /** Funcion para hacer una llamada AJAX enviando los datos por POST
     * @param str url
     * @param str callback - nombre de la función a devolver el resultado
     * @param json data
     */
    post:function (url, callback, data) {
        let query = [];
        for (let key in data) {
            query.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key]));
        }
        this._send(url, callback, 'POST', query.join('&'))
    }
};
 
/* Ejemplo del envio de datos por POST*/
ajax.post("x.php", callback, {"a":2});
 
function callback(e){
    console.log(e);
}
</script>



Comentarios sobre la versión: 1 (1)

Imágen de perfil
15 de Abril del 2019
estrellaestrellaestrellaestrellaestrella
No ha dejado ningún comentario
Responder

Comentar la versión: 1

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s5256