JavaScript Cheat Sheet

Verificar si una variable esta inicializada

if (typeof a !== "undefined")

Console

console.log() -> representacion en string de algo
console.dir() -> devuelve un arbol de lo que realmente "es" lo que se pasa como parametro
e.currentTarget -> retorna el elemento original al que se le attach el evento. Esto es por ejemplo cuando dentro de un link ponemos texto y una imagen. Si utilizamos e.target nos va a deolver span o img como elemnto.
e.currentTarget = $(this) de Jquery

Event bubbling

    1. Cuando hacemos click en un elemento HTML. Causamos un evento Click.
    2. Supongamos que el click lo hacemos en un elemento de este tipo
      <a href="#">
          <span>LINK</span>
      </a>
    3. Al hacerle click en realidad estamos haciendo click en el elemento SPAN. Entonces:
      1. Si existe algun listener de un evento click adjuntado a ese elemento se ejecuta.
      2. Luego el navegador sube un nivel, en este caso se encuentra con un tag A. Entonces realiza la misma acción: Si existe algun listener de un evento click adjuntado a ese elemento se ejecuta.
      3. El paso 2 se repite hasta llegar al elemento BODY

e.preventDefault() y e.stopPropagation()

Otra cosa que podemos hacer es modificar el comportamiento del navegador ante un evento

$table.find('.some-class').on('click', function (e) {
    e.preventDefault();  // no realizar el comportamiento por defecto del navegador
    e.stopPropagation(); // no "bubble" el evento a elementos superiores

   //la siguiente linea realiza las mismas acciones que las 2 anteriores
   //return false;
});

e.target()

Es una propiedad del evento que apunta al elemento que fue clickeado.
Es un objeto del tipo DOM Element

e.target() vs e.currentTarget() 

<a class="link" href="#">
    <span><img src="image.png" /> LINK</span>
</a>

Cuando hacemos click en la imagen e.target sera igual al elemento img, y cuando hacemos click en el text link, e.target será igual al elemento span. Pero si utilizamos e.currentTarget nos devolverá el elemento al cual le adjuntamos el evento que esn este caso es el elemento A

$table.find('.some-class').on('click', function (e) {
    //nos muestra el elemento clickleado
    console.log(e.target); 
    //nos muestra el elemento al cual se le adjunto el evento sin importar a cual de sus elementos
    //se les hizo click
    console.log(e.currentTarget); 
});

Node

Instalar nvm

$ curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.0/install.sh | bash
$ export NVM_DIR="$HOME/.nvm"
$ [ -s "$NVM_DIR/nvm.sh” ] && \. “$NVM_DIR/nvm.sh"
$ [ -s "$NVM_DIR/bash_completion" ] && \.   "$NVM_DIR/bash_completion"
$ nvm --version

//instalar versión
nvm install 8.16.0
//Cambiar versión
$ nvm use 8.16.0

Yarn

Instalar Yarn

//falta


$ yarn init //inicializa un package.json
//Babel convierte solo las nuevas construcciones y sintaxis de los nuevos lenguajes de JS a versiones anteriores
//Si hay nuevas funciones u objetos necesitamos Polifill 
$ yarn add babel-cli --dev
$ yarn add babel-preset-env --dev
$ touch .babelrc 
//agrega lo sigueinte
{
    presets: ["env"]
}
$./node_modules/bin/babel filte/path/to/transpile -o filte/path/transpiled

ES6

Arrow Functions

//before
function(data) {};

//ES6
(data) => {};
data => {};

Si la funcion solo un solo return, se puede usar de las siguientes maneras

() => {
    return 'hola';
};

() => 'hola';


Importante:
Arrow functions anónimas preservan el valor de this, dentro de ellas
En Jquery con Arrow functions
() => {
    $row.fadeOut('normal', () => {
        //Antes
        $(this).fadeOut();
        //ES6
        $row.fadeOut();
    })
}

() => {
    //Antes
    $row.find('div').each(function() {
        $(this).val(2);
    });
    //ES6
    $row.find('div').each((index, element) => {
        $(element).val(2);
    })
}

var, let y const

var: permite reasignar el valor de la variable, tiene scope de funcion, hace variable "hoisting"
let: permite reasignar el valor de la variable, tiene scope de bloque (if por ejemplo), no hace variable "hoisting"
const: no permite reasignar el valor de la variable.
Ejemplo:
const myVar = 1;
myVar = 2; //nos devuelve un error

const myObj = { name: 'Joe'};
myObj.name = 'Doe' //esta permitido

Object literals y Optional Args


cont url = 'http://mydomain.com';
const myObj = { url: url};
const myObj = { url }; //Si la key y el value son iguales se puede usar solo una vez

//Métodos dentro de objetos

const obj = {

    //Antes
    updateRow: function() {
        //update
    }
    //ES6
    updateRow() {
        //update
    }
    //Ademas se pueden establecer parametros opcionales
    updateRow(max = 400) {
        //update
    }
}

Clases

class Helper {
    constructor(maxValue) {
        this.maxValue = maxValue;
        //code
    }

    //La nueva sintaxis get nos permite definir esta especie de propiedad
    // que luego la podemos llamar como Helper._rows
    // tambien existe "set"
    get _rows() {
        //return rows
    }
    //Si esta "propiedad" no usa this adentro, la podemos declarar como estática
    static get _someConst() {
        //return a const value
    }
    //Y la llamamos como Helper._someConst


    static  _utility() {
        //return a calculation
    }
    //Y la llamamos como Helper._utility

    //metodo comun
    getDetails() {
        //code
    }

}

//Herencia

class CustomHelper extends Helper {
    
    //sobreescribir
    getDetails() {
       //new code
    }

    //llamar al metodo de la clase padre
    getParentDetails() {
        super.getDetails()
    }

    //sobre escribir el constructor
    constructor(maxValue, otherValue) {
        super(maxValue);
        this.otherValue = otherValue;
    }


}

const custom = new CustomHelper(100);

Destructuring

const obj = {name: 'Joe', lastName: 'Doe', age: '28'};
//crea tres variables con los valores de obj
let {name, lastName, age} = obj;
//admás se pueden agregar keys que no existan y ponerles valores por defecto
let {name, lastName, age, citizenship = 'spain'} = obj;

//con Arrays: es por posición
const carsArray = ['audi', 'vw', 'ferrari'];
let [car1, car2] = carsArray;

Spread Operator

//con Arrays
const carsArray = ['audi', 'vw', 'ferrari'];

let printCars = (car1, car2, car3) => {
    console.log(car1, car2, car3);
}

//Funciona como si completaran 1 a 1 los argumentos
printCars(...carsArray);

// tambien sirve para array merge
let newCarsArray = ['fiat', 'opel', ...carsArray];

//tambien sirve para copiar un array y agregar nuevos valores solo a la copia 

let copyOfCarsArray = newCarsArray;
copyOfCarsArray.push('porshe');
//esto nos da como resultado que   copyOfCarsArray y newCarsArray poseen porshe
//Por que los arrays se pasan por referencia
let copyOfCarsArray = [...newCarsArray];
copyOfCarsArray.push('porshe');
//esto nos da como resultado que copyOfCarsArray solamente contiene a porshe


Template Strings

//Antes
var nombre = 'Joe';
var mensaje = "Hola mi nombre es: "+ nombre;

//ES6
var nombre = 'Joe';
var mensaje = `Hola mi nombre es: ${nombre}`;

//Además permite tener string con line breaks
var mensaje = 
`Hola mi nombre es: 
Joe Doe
`;

For Loop

//for para colecciones menos objetos
for (let names of data.names) {
}
//for para objetos
for (let names in data.names) {
}

Funciones

// look up the name
// of the item based on the "id" argument.
const { name } = this.props.items.find(i => i.id === id);


this.props.items.map(({ id, name }) => (
    
  • {name}
  • ))}

    Symfony Cheat Sheet

    Response:

    Devolver un Archivo PDF

    use Symfony\Component\HttpFoundation\BinaryFileResponse;
    //..
    return new BinaryFileResponse('/path/al/archivo.pdf');
    

    JSON Response

    use Symfony\Component\HttpFoundation\JsonResponse;
    //..
    $response = new JsonResponse();
    $response->setData(array(
        'data' => 123
    ));
    return $response;

    Cache:

    Cambiar permisos:

    Symfony 2:

    $ HTTPDUSER=`ps aux | grep -E '[a]pache|[h]ttpd|[_]www|[w]ww-data|[n]ginx' | grep -v root | head -1 | cut -d\  -f1`
    $ sudo setfacl -R -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX app/cache app/logs
    $ sudo setfacl -dR -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX app/cache app/logs
    
    #Comandos anteriores en una sola linea
    HTTPDUSER=`ps aux | grep -E '[a]pache|[h]ttpd|[_]www|[w]ww-data|[n]ginx' | grep -v root | head -1 | cut -d\  -f1`;setfacl -R -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX app/cache app/logs;setfacl -dR -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX app/cache app/logs;
    

    Symfony 3:

    $ HTTPDUSER=`ps axo user,comm | grep -E '[a]pache|[h]ttpd|[_]www|[w]ww-data|[n]ginx' | grep -v root | head -1 | cut -d\  -f1`
    $ sudo setfacl -R -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX var
    $ sudo setfacl -dR -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX var
    
    #Comandos anteriores en una sola linea
    HTTPDUSER=`ps axo user,comm | grep -E '[a]pache|[h]ttpd|[_]www|[w]ww-data|[n]ginx' | grep -v root | head -1 | cut -d\  -f1`;setfacl -R -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX var;setfacl -dR -m u:"$HTTPDUSER":rwX -m u:`whoami`:rwX var;
    

    Doctrine:

    Dump

    echo '<pre>';
    \Doctrine\Common\Util\Debug::dump($entities);
    echo'</pre>';
    

    Controller:

    Dump

    
    //$variable = Variable a imprimir
    //$this = El controlador
    dump($variable, $this);
    

    Twig:

    Dump

    
    //variable = Variable a imprimir
    //Se puede no pasar una variable e imprime todas las variables que existen en el template
    {{ dump(variable)}}
    

    Crear proyecto en Symfony 4
    //Opcion 1
    $ composer self-update
    $ composer create-project symfony/skeleton my_project
    //Opcion 2
    $ symfony new my_project
    $ cd my_project
    $ symfony check:req
    $ php -S 127.0.0.1:8000 -t public
    //Symfony 5 no necesario
    $ git init
    $ git add .
    $ git commit
    //Symfony 5 no necesario
    $ composer require server
    $ composer require annotations
    $ composer require twig
    $ composer require asset
    $ composer require profiler –dev
    $ composer require debug
    //Descarga el pack ORM
    $ composer require orm
    //Entonces podemos obviar estos comandos
    $ composer require doctrine
    //Fin Entonces podemos obviar estos comandos

    $ composer require stof/doctrine-extensions-bundle
    $ composer require orm-fixtures –dev
    $ composer require zenstruck/foundry –dev //permite crear fixtures con factories

    $ composer require maker –dev
    $ composer require form validator twig-bundle security-csrf annotations
    $ composer require nesbot/carbon -> para mostrar fechas al estilo «hace 2 dias»
    $ composer require knplabs/knp-time-bundle -> para mostrar fechas al estilo «hace 2 dias»
    $ composer require test –dev

    Paginación:
    $ composer require knplabs/knp-paginator-bundle

    Traducciones:
    $ composer require symfony/translation

    Front End:
    $ composer require encore
    $ yarn install
    $ ./node_modules/.bin/encore dev –watch
    //$ ./node_modules/.bin/encore dev-server Esto hace que los archivos se generen en el server lo que hace
    //que se generen automaticamente pero sin el efecto secundario de renderizar la pagina sin que esten listo y
    //ademas refresca con los cambios
    $ yarn add eslint –dev
    $ touch .eslintrc.js
    Agrega este contenido dentro de .eslintrc.js
    module.exports = {
    extends: [‘eslint:recommended’],
    parserOptions: {
    ecmaVersion: 6,
    sourceType: ‘module’,
    ecmaFeatures: {
    jsx: true
    }
    },
    env: {
    browser: true,
    es6: true,
    node: true
    },
    rules: {
    «no-console»: 0,
    «no-unused-vars»: 0
    }
    };
    Ir a settings en PHP storm, buscar eslint y habilitarlo

    //Validar con eslint el código
    $ ./node_modules/.bin/eslint assets/

    Inside webpack.connfig.js make this change
    //.enableSingleRuntimeChunk()
    .disableSingleRuntimeChunk()

    Para importar entradas en twig
    {{ encore_entry_css_files(‘app’) }}
    {{ encore_entry_js_files(‘app’) }}

    Twig extensions:

    $ composer require twig/extensions
    Activar la extension que queremos utlizar en el archivo config/packages/twig_extensions.yml

    Doctrine:

    $ ./bin/console doctrine:database:create
    $ ./bin/console make:entity
    $ ./bin/console make:migration  // crea un archivo con las consultas sql para crear las tablas en la base de datos, conviene añadir estos archivos en git
    $ ./bin/console doctrine:migrations:migrate // ejecuta el archivo migrations y va iterando entre las versiones de estos archivos
    $ ./bin/console doctrine:migration:status

    TESTING

    composer require –dev phpunit/phpunit symfony/test-pack

    FIXTURES
    //Fake fixtures
    $ composer require zenstruck/foundry –dev
    $ symfony make:factory
    //Crear fixtures
    $ ./bin/console make:fixtures
    // Cargar fixtures
    $ ./bin/console doctrine:fixtures:load

    //Ejecutar una consulta directamente en la base de datos
    $ ./bin/console doctrine:query:sql ‘Select * from products’

    PHPStorm Y Symfony
    1. Instalar Symfony plugin
    2. Instalar PHP annotations plugin
    3. PHP Toolbox plugin
    4. Buscar Symfony plugin y hacer click en el check «Enable plugin for this project»
    5. Buscar «composer» y seleccionamos el archivo composer de nuestro proyecto

    Symfony Server
    $ symfony serve
    $ symfony serve -d //correrlo como demon
    $ symfony local:serve:stop

    Comandos utiles
    1. Lista de servicios disponibles

    
    ./bin/console debug:autowiring
    
    //Todos los servicios en el contenedor
    ./bin/console debug:container --show-private
    

    2. Ver la configuracion de un servicio

    
    ./bin/console config:dump NOMBRE_DEL_BUNDLE
    
    

    3. Ver las variables de entorno


    ./bin/console about

    php bin/console debug:container –env-vars

    php bin/console debug:container –env-vars -e test

    Security

    Obenert contraseña encodeada
    ./bin/console security:encode-password

    Crear un voter
    ./bin/console make:voter

    Crear un normalizer:
    ./bin/console make:serializar:normalizer

    Crear un validator
    ./bin/console make:validator

    
    
    
    
    

    Easy Admin:

    Dump

    $  composer require admin