E - Palíndromo

ejercicio Este ejercicio consiste en trabajar con cadenas (string) y con arrays (matrices) utilizando algunos de los métodos de éstos objetos.

Para realizar el script he utilizado los métodos de string: toLowerCase, y replace().

Convertimos una cadena a un array con el método:  split(). Y le damos la vuelta con el método: reverse().

Para comparar ambos arrays y no tener que utilizar bucles, los vuelvo a convertir en cadenas (con el método: toString()) y las comparo.

Los condicionales if...else son los ya utilizados habitualmente para decidir el mensaje a mostrar en la caja #resultado.

Con el método addEventListener capturamos el evento focus de la caja textarea y borramos la caja #resultado.

Merece la pena mencionar la pequeña expresión regular (/ /g'') para quitar todos los espacios.

Código JavaScript


// ========================================
//  Código JavaScript
//  PALINDROMO
//  (cc) 2017, 3con14.pro
// ========================================

var dato = document.getElementById('dato');

dato.addEventListener('focus', function(){
    var resultado = document.getElementById('resultado');
    resultado.innerHTML = '';
})

function Palindromo() {
    var dato = document.getElementById('dato').value;
    var resultado = document.getElementById('resultado');
    var spanB = '<hr><span class="v">';
    var spanR = '<hr><span class="r">';
    var mensaje = '';
    var original, sinsp;
    var m_original, m_alreves, m_sinsp;

    original = dato.toLowerCase(dato);    // Original en minusculas
    sinsp = original.replace(/ /g,'');    // En minúsculas y sin espacios

    m_original = sinsp.split('');         // como array al derecho
    m_alreves  = sinsp.split('');         
    m_alreves.reverse();                 // como array al revés

    if (isNaN(dato) == false || dato == '') {
        mensaje = '¡¡ ERROR !!';
    } else {
        mensaje  = 'Original: ' + m_original + '<br>';
        mensaje += 'Al revés: ' + m_alreves;
        if ( m_original.toString() == m_alreves.toString() ) {     // comparamos strings
            mensaje += spanB + 'Es un Palíndromo' + '';
        } else {
            mensaje += spanR + 'NO es un Palíndromo' +'</span>';
        }
    }
    resultado.innerHTML = mensaje;
}


Código HTML



<!DOCTYPE html>
<html lang="es">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="description" content="Curso de JS">
    <meta name="author" content="(cc) 3con14" />
    <title>Ejemplo con String</title>
    <link rel="stylesheet" href="/css/estilos.css">
</head>
<body>
    <div class="contenedor">
        <div id="titulo">Palíndromos</div>
        <div id="info">
            <p>Definir una función que determine si la cadena de texto que el usuario escribe es un palíndromo, es decir, si se lee de la misma forma desde la izquierda y desde la derecha.</p>
            <p>Ejemplos: "La ruta nos aporto otro paso natural".</p>
            <p>¡Ojo!: NO escribas acentos ni signos de puntuación. (no lo he implementado en JS).</p>
        </div>
        <label for="dato">Escribe una frase:</label>
        <textarea id="dato" onfocus="this.select();">Odio la luz azul al oido</textarea>
        <br>
        <button onclick="Palindromo();" class="boton rojo">Verificar Palíndromo</button>

        <div id="resultado"></div>
    </div>

<script src="/js/codigo.js"></script>
</body>
</html>

Reglas CSS


/*  ========================================
//  Hoja de estilos CSS
//  PALINDROMO
//  (cc) 2017, 3con14.pro
============================================ */

* { 
  margin     : 0;
  padding    : 0;
  box-sizing : border-box;
  transition : all 0.25s ease-in;
}
:focus { outline: 0 none transparent; }
body {
  min-height       : 100vh;
  font             : 16px/1.2 sans-serif;
  display          : flex;
  background-color : rgba(70, 130, 180, 0.6);
}
h1,h2,h3,h4,h5,h6,p { padding: 0.2rem; }
hr { 
  border: 0;
  margin: 0.5em 0;
  height: 1px;
  background-color: rgba(0, 0, 0, 0.5);
}
ol, ul { margin: 0.5em 0 0.5em 35px; }
.txt-S  { font-size:  80%; }
.txt-M  { font-size:  90%; }
.txt-L  { font-size: 110%; }
.dcha   { text-align: right; }
.centro { text-align: center; }

.contenedor {
  max-width        : 800px;
  width            : 90%;
  min-height       : 90vh;
  margin           : auto;
  padding          : 2rem;
  border-top       : 10px solid rgba(0, 0,0, 0.2);
  background-color : rgba(0, 0, 0, 0.05);
}
label, input { 
  margin  : 0.5rem 0.1rem 0.5rem 0.1rem;
  padding : 0.3rem 0.2rem 0.2rem 0.2rem;
  border  : 0;
}
input { 
  background-color : rgba(255,255,255,0.2);
  font             : 1.1em "Lucida Console", "Courier New", monospace;
}
.inp-txt { 
  border      : 1px solid #fff;
  font        : 1.1em "Lucida Console", "Courier New", monospace;
  box-shadow  : 0.5px 0.5px 3px 0 rgba(112, 112, 112, 0.8) inset;
}
.inp-chk {
  width          : 1.2rem;
  height         : 1.2rem;
  vertical-align : middle;
  display        : inline-block;
}
#info, #resultado {
  min-height : 10vh;
  margin     : 1em 0;
  padding    : 0.5em;
  overflow   : auto;  
}
textarea {
  max-width  : 100vw;
  width      : 96%;
  min-height : 10vh;
  display    : block;
  border     : 0;
  overflow   : auto;
  padding    : 1em;
  margin     : 0.5em;
  border     : thin solid #fff;
  box-shadow : 1px 1px 4px 1px rgba(0, 0, 0, 0.3) inset;
}
#titulo { 
  font : 900 1.3em/1.2 verdana,sans-serif;
  color: rgba(0, 0, 0, 0.6);
}
#info { 
  font             : italic 1em/1.1 serif;
  background-color : rgba(255, 255, 255, 0.1);
  overflow         : auto;  
}
#resultado { 
  background-color : rgba(0, 0, 0, 0.05);
  font             : 100 1.2em/1.2 "Lucida Console", "Courier New", monospace;
}
.r { background-color: rgba(255, 0, 0, 0.6); }
.v { background-color: rgba(0,255, 0, 0.6); }
.a { background-color: rgba(0, 0, 255, 0.6); }
.r, .v, .a { color: #000; padding: 5px 10px; }

/* BOTONES */
 button {
  margin    : 0.5em 0.25em;
  padding   : 0.25em 0.5em;
  cursor    : pointer;
  font-size : 1em;
  border    : 0;
 }
.boton {
  text-align    : center; text-decoration : none;
  font-family   : "Lucida Console", "Courier New", monospace;
  display       : inline-block; position : relative;
  background    : #777; color : #FFF;
  text-shadow   : 1px 1px 1px rgba(0, 0, 0, 0.7);
  padding       : 5px 13px; margin : 10px 5px;
  border-radius : 100px; white-space : nowrap;
  border        : 1px solid transparent;
  transition    : all 0.1s ease-in-out;
  border        : 1px solid transparent;  
}
.gris         { background: #777; box-shadow: 0px 3px 0 0 #444; }
.gris:hover   { background: hsla(0, 0%, 57%, 1); }
.rojo         { background: #E74C3C; box-shadow: 0px 3px 0 0 hsla(6, 63%, 36%, 1); }
.rojo:hover   { background: hsla(5, 100%, 70%, 1); }
.verde        { background: #2ECC71; box-shadow: 0px 3px 0 0 hsla(145, 63%, 32%, 1); }
.verde:hover  { background: hsla(145, 70%, 60%, 1); }
.azul         { background: #3498DB; box-shadow: 0px 3px 0 0 hsla(204, 54%, 44%, 1); }
.azul:hover   { background: hsla(204, 77%, 60%, 1); }
.rojo:active, .verde:active, .azul:active, .gris:active { transform: translateY(4px); }
.rojo:hover, .verde:hover, .azul:hover, .gris:hover     { border: 1px solid rgba(255, 255, 255, 0.4); }

Demo

t 006 palindromo

 

Imprimir Correo electrónico

Visitas...

Hoy ........ 4

Ayer ....... 5

Mes ........ 44

Total ........ 5892

En línea...

Hay 7 invitados y ningún miembro en línea

< 3con14 - LAB / >

1998 - 2017, www.3con14.biz
(cc) Jesús Plaza M.
RECONOCIMIENTOS