- Tipos primitivos
- number
- string
- object
Dos tipos:
-
Números normales que se almacenan en un formato binario de doble precisión de 64 bits siguiendo el estandar IEEE 754 (1 bit para el signo, 11 para el exponente y 52 para la mantisa). Estos son los que usamos normalmente.
-
BigInt (ES2020) permite representar números enteros mayores de 253 - 1. Este es un nuevo tipo primitivo.
const maximoNumero = 1.7976931348623157e+308 // 2^53 - 1
const minimoNumero = 5e-324 // -(2^53 - 1)
const numerajo = 1200
const mismoNumerajo = 1.2e3
const aunElMismoNumerajo = 0.12e4
const otroNumero = -56.21312
const mismoNumero = -5.621312e+4
Tenemos 5 alias importantes:
Number.MAX_VALUE // 1.7976931348623157e+308
Number.MIN_VALUE // 5e-324
Number.MAX_SAFE_INTEGER // 9007199254740991
Number.MAX_SAFE_INTEGER // -9007199254740991
// Esta es la diferenia entre 1 y el valor más pequeño mayor que uno que se puede representar como Number
Number.EPSILON // 2.220446049250313e-16
Y tres símbolos especiales:
Number.POSITIVE_INFINITY // Infinity
Number.NEGATIVE_INFINITY // -Infinity
Number.NaN // NaN
Hay que tener cuidado con cómo escribimos los números, hay ciertos prefijos que se usan para indicar con qué base estamos trabajando:
const miNumeroTramposo = 0888 // Oro parece, plata no es
const miNumeroOctal = 0777 // 511 en decimal, el 0 delante significa que es octal
const miNumeroBinario = 0b01111111100000000000000000000000 // 0b indica que es binario
const miNumeroHexadecimal = 0xA // 0x indica que es Hexadecimal
#####Métodos:
.toExponential(n)
Devuelve un string con el valor numérico redondeado a n decimales en coma flotante.
const numerito = 77.1234;
console.log(numerito.toExponential()); // 7.71234e+1
console.log(numerito.toExponential(4)); // 7.7123e+1
console.log(numerito.toExponential(2)); // 7.71e+1
console.log(77.1234.toExponential()); // 7.71234e+1
.toFixed(n)
: Devuelve un string con el valor numérico redondeado a n decimales en punto fijo.
const numObj = 12345.6789;
numObj.toFixed(); //'12346' redondeo
numObj.toFixed(1); //'12345.7'
numObj.toFixed(6); //'12345.678900' Se añaden ceros en caso necesario
(1.23e+20).toFixed(2); //'123000000000000000000.00'
(0).toFixed(2); //'0.00'
2.34.toFixed(1); //'2.3' redondeo
-2.34.toFixed(1); //-2.3 Numeros negativos no son devueltos como cadenas.
(-2.34).toFixed(1); //'-2.3' En caso de usar paréntesis se salta la limitación
.toLocaleString(lang)
const numero = 3500;
// En Local
console.log(numero.toLocaleString()); // 3.500
// En Árabe
console.log(numero.toLocaleString('ar-EG')); // ٣٬٥٠٠
// En Chino decimal
console.log(numero.toLocaleString('en-us')); // 三,五〇〇
.toPrecision(n)
: Devuelve un número con n dígitos
const numero = 5.123456;
console.log(numero.toPrecision()); // 5.123456
console.log(numero.toPrecision(5)); // 5.1235
console.log(numero.toPrecision(2)); // 5.1
console.log(numero.toPrecision(1)); // 5
console.log((1234.5).toPrecision(2)); // 1.2e+3 (En ocasiones )
.toString(base)
: Devuelve un string con en el número en la base que indiquemos
console.log((17).toString()); // '17'
console.log((17.2).toString()); // '17.2'
console.log((-0xff).toString(2)); // '-11111111'
console.log((4064).toString(16)); // 'fe0'
.parseInt(numero, base)
: Devuelve un número entero en una base específica (10 por defecto)
parseInt(" 0xF", 16); // 15
parseInt(" F", 16); // 15
parseInt("17", 8); // 15
parseInt(021, 8); // 15
parseInt("015", 10); // 15
parseInt(15.99, 10); // 15
parseInt("15,123", 10); // 15
parseInt("FXX123", 16); // 15
parseInt("1111", 2); // 15
parseInt("15*3", 10); // 15
parseInt("15e2", 10); // 15
parseInt("15px", 10); // 15
parseInt("12", 13); // 15
parseFloat(numero)
: Devuelve un número decimal a partir de una cadena
Number.parseFloat("3.14"); // 3.14
Number.parseFloat("314e-2"); // 3.14
Number.parseFloat("0.0314E+2"); // 3.14
Number.parseFloat("3.14textos..."); // 3.14
Number.parseFloat("1textos..."); //1
Math
es un objeto incorporado que tiene propiedades y métodos para constantes y funciones matemáticas. No es un objeto de función.
-
E
: Constante de Euler -
LN2
: Logaritmo natural de 2 -
LN10
: Logaritmo natural de 10 -
LOG2E
: Logaritmo de E con base 2 -
LOG10E
: Logaritmo de E con base 10 -
PI
: Número PI -
SQRT1_2
: Raíz cuadrada de 1/2 -
SQRT2
: Raíz cuadrada de 2
const constanteDeEulers = Math.E // ~2.718
const lnDe2 = Math.LN2 // ~0.693
const lnDe10 = Math.LN10 // ~2.303
const log2DeE = Math.LOG2E // ~1.443
const log10DeE = Math.LOG10E // ~0.434
const pi = Math.PI // ~3.14159
const sqrt1Entre2 = Math.SQRT1_2 // ~0.707
const sqrt2 = Math.SQRT2 // ~1.414
La precisión de estos métodos depende de la implementación. Diferentes navegadores pueden dar resultados diferentes, e incluso esto puede variar dependiendo del Sistema Operativo o la arquitectura.
.pow(base, exp)
: Devuelve la base elevada al exponente. Equivalente al operador**
.
const cuatro = Math.pow(2, 2)
const dos = Math.pow(8, 1/3)
.round(n)
: Devuelve el valor de n redondeado al entero más cercano
Math.round(20.5); // 21
Math.round(20.49); // 20
Math.round(-20.51); // -21
.floor(n)
: Devuelve la parte entera de n
Math.floor(20.5); // 20
Math.floor(20.49); // 20
Math.floor(-20.51); // -21
.random()
: Devuelve un número pseudo-aleatorio entre 0 y 1
// Número aleatorio entre 0 (incluido) y 1 (excluido)
Math.random();
// Retorna un entero aleatorio entre min (incluido) y max (excluido)
Math.floor(Math.random() * (max - min)) + min;
const arrayConMuchosValores = []
const indiceRandom = Math.floor(arrayConMuchosValores.length * Math.random())
.max(n1, n2, n3, ..., nm)
: Devuelve el valor más alto de entre los m pasados
Math.max(4, 5, 213, 56, 2) // 213
.min(n1, n2, n3, ..., nm)
: Devuelve el valor más bajo de entre los m pasados
Math.min(4, 5, 213, 56, 2) // 2
.sqrt(num)
: Devuelve la raíz cuadrada de un número
const cuatro = Math.sqrt(16)
- Crea una función que devuelva el perímetro de un círculo a partir de su radios:
// 2PIr
function perimetroCirculo(r) {
}
console.assert(perimetroCirculo(3) === 18.84955592153876)
console.assert(perimetroCirculo(6) === 37.69911184307752)
- Crea una función que devuelva el area de un círculo a partir de su radio:
function areaCirculo(r) {
// πr^2
}
console.assert(areaCirculo(2) === 12.566370614359172)
console.assert(areaCirculo(8) === 201.06192982974676)
- Crea una función que devuelva la hipotenusa de un triángulo a partir de sus catetos (Teorema de pitagoras).
// h^2 = c1^2 + c2^2
function hipotenusa(c1, c2) {
}
console.assert(hipotenusa(1, 2) === 2.23606797749979)
Un objeto que representa una serie de caracteres dentro de una cadena
Tenemos dos formas de crear strings:
- Forma tradicional: usando comillas dobles o simples. Si usamos el operador '+' podemos concatenarlos
const miPrimeritoString = 'Hola mundo'
const miStringConComillasDobles = '¡' + miPrimeritoString + '!' // ¡Hola mundo!
const miStringConSaltosDeLinea = 'Volverán las oscuras golondrinas\n' +
'en tu balcón sus nidos a colgar, \n' +
'y otra vez con el ala a sus cristales \n' +
'jugando llamarán.'
const escapandoComillas = "Este string contiene 'comillas simples', así que lo englobo en comillas dobles".
- String templates: Llegó con ES6 para hacernos muy felices. Se declaran con acento grave (`). Permiten interpolar valores en cadenas de texto respetando los saltos de línea
const pi = Math.PI
const miPrimerStringTemplate = `El número PI vale ${pi} (aprox)`
const random = Math.random()
const stringTemplateConCodigo = `El valor ${random} vale más de 0.5: ${random > 0.5 ? 'si' : 'no'}`
const stringTemplateEnVariasLineas = `
Volverán las oscuras golondrinas
en tu balcón sus nidos a colgar,
y otra vez con el ala a sus cristales
jugando llamarán.`
.length
: Devuelve la longitud de un string
const cadena = 'Fictizia';
console.log(`Fictizia tiene ${cadena.length} caracteres.`);
console.log('Una cadena vacia tiene ' + ''.length + ' caracteres.');
.charAt(posicion)
const cadena = 'Fictizia';
console.log(`El carácter(posición) 3 es "${cadena.charAt(3)}"`)
// También podemos acceder con [3]
console.log(`El carácter(posición) 3 es "${cadena[3]}"`)
.concat(cadena1, cadena2, ...cadenam)
: Concatena el string original con 1 o m strings
const cadena1 = 'Yo '
const cadena2 = 'soy '
const cadena3 = 'Iron Man 🦾'
const momentoEpico = cadena1.concat(cadena2, cadena3)
console.log(momentoEpico)
.repeat(repeticiones)
: Repite tantas veces como se indique el string original
const cerveza = '🍺';
const cuantosSomos = 16;
const canias = cerveza.repeat(cuantosSomos * 2)
console.log(canias)
.indexOf(cadena)
: Devuelve el primer índice en el que se encuentra un strinng o -1. Es case sensitive.
'No sabes nada, Jon Nieve'.indexOf('jon') // -1
'No sabes nada, Jon Nieve'.indexOf('Jon') // 14
.lastIndexOf(cadena)
: Devuelve el último índice en el que se encuentra un strinng o -1. Es case sensitive.
'No sabes nada, Jon Nieve'.lastIndexOf('E') // -1
'No sabes nada, Jon Nieve'.lastIndexOf('e') // 23
.includes(string)
: Devuelve si un string existe dentro de otro.
'cuarentena'.includes('sol') // false como una catedral
.match(regex)
: Devuelve las ocurrencias de una expresión regular
const ocurrencias = 'No sabes nada Jon Nieve'.match(/s/ig)
.replace(string, reemplazo)
: Devuelve un string en el que se sustituye el string o regexp recibido por el valor de reemplazo dado. Dicho valor puede ser un string, una función o una expresión regular.
const miCadena = 'I love you tres mil'
const miCadenaConNúmero = miCadena.replace('tres mil', '3000') // I love you 3000
.split(separador)
: Devuelve un array con el string original separado por el string proporcionado como parámetro.
const frutasParaComprar = '🍌, 🍊, 🍎, 🍐, 🥝'
const frutasComoArray = frutasParaComprar.split(', ') // ['🍌', '🍊', '🍎', '🍐', '🥝']
.slice(inicio, fin)
: Devuelve un segmento de un array. El atributo fin es opcional. No modifica el array original, lo copia. Acepta números negativos.
const cadena = 'I❤️you 3000'
console.log(cadena.slice(7)); // 3000
console.log(cadena.slice(-4)); // 3000
console.log(cadena.slice(0, 6)); // I❤️you
console.log(cadena.slice(0, -5)); // I❤️you
También podemos usar .substring
, pero sólo si usamos números positivos.
.substr(inicio, n)
: Devuelve n caracteres de una cadena a partir del índice recibido.
const cadena = 'I❤️you 3000'
console.log(cadena.substr(0, 6)); // I❤️you
console.log(cadena.substr(7, 4)); // 3000
.toLowerCase()
: Devuelve el string con letras minúsculas
const hulkTimido = 'Hulk aplasta'.toLowerCase() // hulk aplasta
.toUpperCase()
: Devuelve el string con letras mayúsculas
const hulkCabreado = 'Hulk aplasta'.toUpperCase() // HULK APLASTA
.trim()
: Devuelve el string sin espacios vacíos al principio y al final
console.log(' Yo soy Batman '.trim()) // Yo soy Batman
trimEnd()
: Primo hermano de trim, devuelve el string sin espacios en blanco por el final.Existe el aliastrimRight
.
console.log(' Yo soy Batman '.trimEnd()) // Yo soy Batman
trimStart()
: Primo hermano de trim, devuelve el string sin espacios en blanco por inicio. Existe el aliastrimLeft
console.log(' Yo soy Batman '.trimStart()) // Yo soy Batman
- Crea una función que reciba un string y un número n y devuelva el string repetido n veces:
function repeat(str, n) {
}
console.assert(repeat('Batman ', 3) === 'Batman Batman Batman ')
- Crea una función que reciba una frase como string y devuelva la palabra más larga:
function palabraMasLarga(str) {
}
console.assert(palabraMasLarga("Erase una vez que se era") === "Erase")
- Crea una función que reciba un string y lo devuelva con todas las palabras con su primera letra mayúscula.
function ponPrimeraMayuscula(str) {
}
console.assert(ponPrimeraMayuscula("En un lugar de la Mancha de cuyo nombre no quiero acordarme") === "En Un Lugar De La Mancha De Cuyo Nombre No Quiero Acordarme")
- Crea una función que reciba un string y lo devuelva en camelCase
function camelize(str) {
}
console.assert(camelize("Hola a todos que tal") === "holaATodosQueTal");
- Crea una función que reciba un número y devuelva un string con formato ordinal inglés. Esto es:
-
acaba en 1 -->
301st
-
acaba en 2 -->
302nd
-
acaba en 3 -->
303rd
-
cualquier otra cosa -->
300th
function englishFormat(num) {
const lastNumber = num % 10
switch(lastNumer) {
case 1:
return `${num}st`;
case 2:
return `${num}nd`;
case 3:
return `${num}rd`;
default:
return `${num}th`
}
}
- Vamos a emular una "posible" pandemia. El mundo se representará como un string como el siguiente:
01000000X000X011X0X
Donde los valores representan lo siguiente:
- '0': no contagiado
- '1': contagiado
- 'X': océano
Tenemos que calcular el porcentaje de personas contagiadas en el mundo. Para ello tenemos que tener en cuenta lo siguiente:
- El virus no se puede propagar por el océano.
- Si una persona se contagia en un continente todas las personas se contagian en ese continente.
- Los continentes no están conectados por los extremos
Casos de prueba:
-
Input: '01000000X000X011X0X' Output: ~73.33333
-
Input: '01X000X010X011XX' Output: ~72.72727272727273
-
Input: 'XXXXX' Output: 0
-
Input: '0000000010' Output: 100
-
Input: 'X00X000000X10X0100' Output: ~42.857142857142854
function infected(s) {
let numOfInfecteds = 0
const total = s.replace(/X/g, '').length
if(total === 0) {
return numOfInfecteds
}
const continents = s.split('X')
for(const i of continents) {
if(i.includes('1')) {
numOfInfecteds += i.length
}
}
return (numOfInfecteds * 100) / total
}