Aprende-Vim/cap11_modo_visual.md

329 lines
14 KiB
Markdown
Raw Normal View History

2020-11-16 20:08:57 +01:00
# Capítulo 11: Modo visual
2020-09-08 22:33:03 +02:00
Con los editores de texto con interfaz gráfica \(como LibreOffice Writer o Microsoft Word\) probablemente sabes que puedes resaltar un bloque de texto y aplicarle cambios. Vim también puede hacerlo, con el modo visual. Vim tiene tres modos visuales diferentes para usar. En este capítulo, aprenderás cómo utilizar cada uno de los diferestes modos visuales para manipular bloques de texto de manera eficiente.
2020-09-08 22:33:03 +02:00
2020-11-16 20:08:57 +01:00
## Los tres tipos de modos visuales
2020-11-16 20:08:57 +01:00
Los tres modos son:
2020-09-08 22:33:03 +02:00
```text
2020-11-16 20:08:57 +01:00
v Modo visual de selección de caracter
V Modo visual de selección de líneas
Ctrl-v Modo visual de selección de bloque
2020-09-08 22:33:03 +02:00
```
2020-11-16 20:08:57 +01:00
Si tienes el siguiente texto:
```text
2020-11-16 20:08:57 +01:00
uno
dos
tres
2020-09-08 22:33:03 +02:00
```
2020-11-16 20:08:57 +01:00
El modo visual de selección de caracter es utilizado para seleccionar caracteres de forma individual. Pulsa `v` en el primer caracter de la primera línea. Después baja hasta la línea siguiente con `j`. Esto resaltará todo el texto desde "uno" hasta donde este ubicado el cursor. Ahora pulsa `gU`, Vim convertirá a mayúsculas todos los caracteres resaltados.
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
El modo visual de selección de línea funciona con líneas como unidades de selección. Pulsa `V` y observa como Vim selecciona la línea completa en la que esté ubicado el cursor. Igual que en el modo visual de selección de caracter, si ejecutas `gU`, Vim cambiará a mayúsculas las líneas resaltadas.
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
El modo visual de slección de bloque funciona con filas y columnas. Te da más libertad de movimientos que los dos modos anteriores. Pulsando `Ctrl-V` verás qie Vim resalta el caracter bajo el cursor de igual manera que el modo visual de selección de caracter, excepto que ahora en vez de resaltar cada caracter hasta el final de la línea antes de seguir en la línea siguiente, puedes dirigir el cursor hasta la línea siguiente sin que se marquen todos los caracteres de la línea actual. Intenta moverte mediante las teclas `h/j/k/l` y observa los movimientos del cursor y las zonas que se marcan.
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
En la esquina inferior izquierda de la ventana de Vim, verás que se muestra `-- VISUAL --`, `-- VISUAL LINE --` o `-- VISUAL BLOCK --` para indicar el modo visual en que te encuentras.
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
Mientras estás dentro de un modo visual, puedes cambiar a otro de los modos pulsando `v`, `V` o `Ctrl-V`. Por ejemplo, si estás en el modo visual de selección de línea y quieres cambiar al modo visual de selección de bloque, ejecuta `Ctrl-V`. ¡Inténtalo!
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
Hay tres maneras de salir del modo visual: `esc`, `Ctrl-C` y con la misma tecla con la que accediste al modo visual actual.
2020-09-08 22:33:03 +02:00
Esto último significa, que si estás en el modo visual de selección de línea \(`V`\), podrás salir de ese modo pulsando `V` de nuevo. Si estás en el modo visual de selección de caracter, podrás salir pulsando `v`. Si estás en el modo visual de selección de bloque, pulsa `Ctrl-V` para salir de ese modo.
2020-09-08 22:33:03 +02:00
2020-11-20 01:42:19 +01:00
Hay una forma más de entrar en el modo visual:
```text
2020-09-08 22:33:03 +02:00
gv Go to the previous visual mode
```
2020-11-20 01:42:19 +01:00
Este comando seleccionará el mismo modo visual y el mismo resaltado de texto de la última vez.
2020-09-08 22:33:03 +02:00
2020-11-20 19:53:29 +01:00
## Navegación en el modo visual
2020-09-08 22:33:03 +02:00
2020-11-20 19:53:29 +01:00
Mientras estás en el modo visual, puedes expandir el bloque de texto resaltado con los movimientos de Vim.
2020-09-08 22:33:03 +02:00
2020-11-20 19:53:29 +01:00
Vamos a utilizar el mismo texto que hemos utilizado anteirormente:
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
dos
tres
2020-09-08 22:33:03 +02:00
```
2020-11-20 19:53:29 +01:00
Esta vez vamos a empezar desde la línea "dos". Pulsa `v` para comenzar el modo visual de selección de caracter:
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
[d]os
tres
2020-09-08 22:33:03 +02:00
```
2020-11-20 19:53:29 +01:00
Pulsa `j` y Vim altará todo el texto desde la línea "dos" hasta el primer caracter de la línea "tres".
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
[dos
t]res
2020-09-08 22:33:03 +02:00
```
2020-11-20 19:53:29 +01:00
Supongamos que nos hemos dado cuenta que también necesitamos resaltar la línea "uno", así que pulsas la tecla `k`. Para tu asombro, esto ahora excluye "tres". Al pulsar `k` esto reduce la zona resaltada, no la expande.
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
[d]os
tres
2020-09-08 22:33:03 +02:00
```
¿Hay alguna manera de expandir libremente la selección visual para ir a cualquier dirección que quieras?
2020-09-08 22:33:03 +02:00
2020-11-20 19:53:29 +01:00
La respuesta es sí. Regresemos a la situación anterior donde teníamos las líneas "dos" y "tres" resaltadas.
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
[dos
t]res <-- cursor
2020-09-08 22:33:03 +02:00
```
2020-11-20 19:59:19 +01:00
El resaltado visual sigue el movimiento del cursor. Si quiere expandirlo hacia arriba a la línea "uno", necesitas mover el cursor cuando el cursor está en la palabra "dos", no "tres". Ahora tu cursor está en la línea "tres". Para movelo, cambia la loclización del cursor tanto con `o` u `O`.
2020-09-08 22:33:03 +02:00
```text
2020-11-20 19:53:29 +01:00
uno
[dos <-- cursor
t]res
2020-09-08 22:33:03 +02:00
```
2020-11-20 19:53:29 +01:00
Ahora pulsa `k`, esto ya no reducirá la selección si no que la expandirá hacia arriba.
2020-09-08 22:33:03 +02:00
```text
2020-09-08 22:33:03 +02:00
[one
two
t]hree
```
Al pulsar `o` u `O` en el modo visual, esto hará que nuestro cursor salte del inicio que bloque resaltado, sin eliminar las partes resaltadas y podremos añadir más texto a esa selección.
2020-11-20 19:59:19 +01:00
2020-11-20 20:46:52 +01:00
## Gramática en el modo visual
2020-09-08 22:33:03 +02:00
2020-11-20 20:46:52 +01:00
El modo visual es uno de los modos de Vim. El que sea un modo significa que la misma tecla puede funcionar de manera diferente en un modo o en otro. Afortunadamente, el modo visual comparte muchas teclas en común con el modo normal.
2020-09-08 22:33:03 +02:00
2020-11-20 20:46:52 +01:00
Por ejemplo, si tenemos el siguiente texto:
2020-09-08 22:33:03 +02:00
```text
2020-11-20 20:46:52 +01:00
uno
dos
tres
2020-09-08 22:33:03 +02:00
```
Resalta las líneas "uno" y "dos" con el modo visual de selección de línea \(`V`\):
```text
2020-11-20 20:46:52 +01:00
[uno
dos]
tres
2020-09-08 22:33:03 +02:00
```
Al pulsar `d` esto eliminará la selección, de manera similar al modo normal. Cabe destacar que la regla gramatical del modo normal de verbo + sustantivo, aquí no se aplica. El mismo verbo sigue estando ahí \(`d`\), pero no existe un sustantivo en el modo visual. La regla gramática en el modo visual es sustantivo + verbo, donde el sustantivo en este caso es reemplazado por el texto resaltado. Primero selecciona el texto, después opera sobre el.
2020-09-08 22:33:03 +02:00
En el modo normal, hay algunos comandos que no requieren de una tecla de movimeinto, como por ejemplo `x` para eliminar un único caracter bajo el cursor o `rx` para reemplzar el texto bajo el cursor con la letra "x". En el modo visual, estos comandos son ahora aplicados al texto resaltado por completo en vez de a un único caracter. Regresemos al texto que hemos resaltado anteriormente:
```text
2020-11-20 20:46:52 +01:00
[uno
dos]
tres
2020-09-08 22:33:03 +02:00
```
2020-11-20 20:46:52 +01:00
Al ejecutar el comando `x` esto eliminará todo el texto resaltado.
2020-09-08 22:33:03 +02:00
2020-11-20 20:46:52 +01:00
Puedes utilizar esta funcionalidad para crear rápidamente un encabezado en un texto en formato Markdown. Supongamos que tenemos este texto en un archivo en Markdown:
```text
2020-11-20 20:46:52 +01:00
Capítulo uno
2020-09-08 22:33:03 +02:00
```
2020-11-20 20:46:52 +01:00
Y queremos convertir este texto rápidamente en un encabezado. Primero copiamos la línea con `yy`, después lo pegamos con `p`:
```text
2020-11-20 20:46:52 +01:00
Capítulo uno
Capítulo uno
2020-09-08 22:33:03 +02:00
```
2020-11-20 20:46:52 +01:00
Ahora coloquemos el cursor en la segunda línea y la seleccionamos con el modo visual de selección de línea:
```text
2020-11-20 20:46:52 +01:00
Capítulo uno
[Capítulo uno]
2020-09-08 22:33:03 +02:00
```
2020-11-20 20:46:52 +01:00
En Markdown puedes crear un encabezado añadiendo una serie de `=` debajo del texto, así que reemplacemos el texto completo resaltado mediante `r=`:
2020-09-08 22:33:03 +02:00
```text
2020-11-20 20:46:52 +01:00
Capítulo uno
============
2020-09-08 22:33:03 +02:00
```
2020-11-20 20:46:52 +01:00
Para aprender más sobre los operadores en el modo visual, echa un vistazo a la ayuda de Vim mediante: `:h visual-operators`.
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
## El modo visual y comandos Ex
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
Puedes aplicar de manera selectiva comandos Ex a un bloque de texto resaltado. Si tienes estas expresiones:
2020-09-08 22:33:03 +02:00
```text
2020-09-08 22:33:03 +02:00
const one = "one";
const two = "two";
const three = "three";
```
Y necesitas sustituir solo las primeras dos líneas de "const" con "let". Resalta las primeras dos línea con _cualquier_ modo visual y ejecuta el comando de sustituir `:s/const/let/g`:
```text
2020-09-08 22:33:03 +02:00
let one = "one";
let two = "two";
const three = "three";
```
Ten en cuenta que he dicho que puedes hacer esto con _cualquier_ modo visual. No es necesario resaltar las líneas completas para ejecutar el comando Ex en esas líneas. Con tan solo seleccionar al menos un caracter de cada línea, el comando Ex será aplicado.
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
## Editar en múltiples líneas
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
Puedes editar texto en múltiples líneas en vim utilizando el modo visual de selección de bloque. Si necesitas añadir un punto y comaal final de cada línea:
```text
2020-09-08 22:33:03 +02:00
const one = "one"
const two = "two"
const three = "three"
```
2020-11-21 19:23:16 +01:00
Con tu cursor en la primera línea:
* Ejecuta el modo visual de selección de bloque y baja dos líneas \(`Ctrl-V jj`\).
* Resalta hasta el final de la línea \(`$`\).
* Añade \(`A`\) y después escribe ";".
* Sal del modo visual \(`esc`\).
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
Deberías ver que se ha añadido ";" en cada línea. Por cierto, mientras estás en el modo visual de selección de bloque, para entrar en el modo insertar, también puedes utilizar `A` para introducir el texto después del cursor o `I` para introducir el texto antes del cursor. No los confundas con `A` o `I` del modo normal.
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
De manera alternativa, también puedes utilizar el comando `:normal`:
2020-09-08 22:33:03 +02:00
* Resalta las tras líneas \(`vjj`\).
* Escribe `:normal! A;`.
2020-09-08 22:33:03 +02:00
2020-11-21 19:23:16 +01:00
Recuerda, el comando `:normal` ejecuta comandos del modo normal. Le puedes pedir que ejecute `A;` para añadir el texto ";" al final de la línea.
2020-09-08 22:33:03 +02:00
2020-11-21 20:37:08 +01:00
## Incrementar números
2020-09-08 22:33:03 +02:00
2020-11-21 20:37:08 +01:00
Vim tiene los comandos `Ctrl-X` y `Ctrl-A` para decrementar e incrementar números. Cuando son usados en el modo visual, puedes incrementar o decrementar números en múltiples líneas.
2020-09-08 22:33:03 +02:00
2020-11-21 20:37:08 +01:00
Si tienes estos elementos HTML:
```text
2020-09-08 22:33:03 +02:00
<div id="app-1"></div>
<div id="app-1"></div>
<div id="app-1"></div>
<div id="app-1"></div>
<div id="app-1"></div>
```
Es una mala práctica el tener muchas _ids_ con el mismo número, así que vamos a incrementarlos para hacerlos únicos:
* Mueve tu cursor al número "1" de la segunda línea de las mostradas.
* Comienza el modo visual de selección de bloques y baja 3 líneas \(`Ctrl-V 3j`\). Esto resalta los números "1" siguientes.
* Ejecuta `g Ctrl-A`.
2020-09-08 22:33:03 +02:00
2020-11-21 20:37:08 +01:00
Deberías ver este resultado:
```text
2020-09-08 22:33:03 +02:00
<div id="app-1"></div>
<div id="app-2"></div>
<div id="app-3"></div>
<div id="app-4"></div>
<div id="app-5"></div>
```
2020-11-21 20:37:08 +01:00
`g Ctrl-A` incrementa los números en múltiples líneas. `Ctrl-X/Ctrl-A` también pueden incrementar letras. Si ejecutas:
2020-09-08 22:33:03 +02:00
```text
2020-09-08 22:33:03 +02:00
:set nrformats+=alpha
```
2020-11-21 20:37:08 +01:00
La opción `nrformats` le indica a Vim que bases son consideradas como "números" para `Ctrl-A` y `Ctrl-X` para incrementar y decrementar. Añadiendo `alpha`, un caracter alfanumérico es considerado ahora como un número. Si tienes los siguientes elementos HTML:
```text
2020-09-08 22:33:03 +02:00
<div id="app-a"></div>
<div id="app-a"></div>
<div id="app-a"></div>
<div id="app-a"></div>
<div id="app-a"></div>
```
Coloca tu cursor en la sugunda "app-a". Utiliza la misma técnica que en el ejemplo anterior \(`Ctrl-V 3j` después `g Ctrl-A`\) para incrementar los "ids".
```text
2020-09-08 22:33:03 +02:00
<div id="app-a"></div>
<div id="app-b"></div>
<div id="app-c"></div>
<div id="app-d"></div>
<div id="app-e"></div>
```
2020-12-05 20:25:09 +01:00
## Seleccionar la última área del modo visual
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
Ya has aprendido que con con `gv` puedes resaltar rápidamente la anterior zona marcada en el modo visual. También puedes ir a la ubicación del comienzo y final de la anterior zona del modo visual con estas marcas especiales:
2020-09-08 22:33:03 +02:00
```text
2020-12-05 20:25:09 +01:00
`< Ir a último pugar de la anterior zona resaltada del modo visual
`> Ir al comienzo de la anterior zona resaltada del modo visual
2020-09-08 22:33:03 +02:00
```
2020-12-05 20:25:09 +01:00
Quiero que te fijes en algo. Anteriormente, mencioné que puedes ejecutar de manera selectiva un comando Ex en un texto resaltado, como `:s/const/let/g`. Cuando ejecutaste ese comando, deberías haber visto esto:
```text
2020-09-08 22:33:03 +02:00
:`<,`>s/const/let/g
```
2020-12-05 20:25:09 +01:00
Estabas ejecutando `s/const/let/g` el comando utilizando las marcas como rango de ejecución. Siempre puedes editar estas marcas en cualquier momento que desees. Si necesitabas sustituir desde el comienzo del texto resaltado hasta el final del archivo, simplemente cambia el comando a este::
```text
2020-09-08 22:33:03 +02:00
:`<,$s/const/let/g
```
2020-12-05 20:25:09 +01:00
## Entrando en el modo visual desde el modo insertar
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
También puedes entrar en el modo visual desde el modo insertar. Para ir al modo visual de selección de caracter mientras en el modo insertar, ejecuta:
2020-09-08 22:33:03 +02:00
```text
2020-09-08 22:33:03 +02:00
Ctrl-O v
```
2020-12-05 20:25:09 +01:00
Volver a ejecutar `Ctrl-O` mientras estás en el modo insertar te permite ejecutar un comando en el modo normal. Mientras estás en este modo-normal-momentáneo, ejecuta `v` para entrar en el modo visual de selección de caracter. Fíjate que en la parte inferior izquierda de la pantalla se muestra `--(insert) VISUAL--`. Este truco funciona con cualquier operador de cualquier modo visual: `v`, `V`, y `Ctrl-V`.
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
## Modo selecionar
2020-09-08 22:33:03 +02:00
Vim tiene un modo similar al modo visual llamado el _modo seleccionar_. De manera similar al modo visual, también tiene tres modos diferentes::
```text
2020-12-05 20:25:09 +01:00
gh Modo seleccionar de selección de caracter
gH Modo seleccionar de selección de línea
gCtrl-h Modo seleccionar de selección de bloque
2020-09-08 22:33:03 +02:00
```
2020-12-05 20:25:09 +01:00
El modo seleccionar emula al comportamiento de un editor de texto normal al seleccionar un texto de una manera más cercana a como lo hace Vim en el modo visual.
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
En un editor normal, después de seleccionar un bloque de texto y escribir una letra, por ejemplo la letra "y", el editor borrará todo el texto resaltado e insertará la letra escrita, en nuestro ejemplo la letra "y".
2020-09-08 22:33:03 +02:00
Si resaltas una línea de texto con el modo de selección de línea \(`gH`\) y escribre "y", se borrará el texto resaltado y se insertará la letra "y", de manera similar a como se hace en un editor de texto normal.
2020-09-08 22:33:03 +02:00
Este comportamiento contrasta con el modo visual: si resaltas una línea de de texto en el modo visual de selección de línea \(`V`\) y escribres "y", el texto resaltado no será eliminado y reemplazado con la letra "y". Solo será copiado y almacenado en el registro de copia `"0`.
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
Personalmente nunca he utilizado el modo seleccionar, pero es bueno saber que existe.
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
## Aprende el modo visual de la manera más inteligente
2020-09-08 22:33:03 +02:00
2020-12-05 20:25:09 +01:00
El modo visual es la representación de Vim del procedimiento de resaltado de texto.
2020-09-08 22:33:03 +02:00
Si te encuentras a ti mismo utilizando el modo visual mucho más a menudo que operaciones en el modo normal, ten cuidado. Creo que esto es un antipatrón. Conlleva más pulsaciones de teclas el ejecutar operaciones en el modo visual que hacer la misma operación en el modo normal. Si necesitas eliminar una palabra en la que te encuentras, por qué utilizar cuatro pulsaciones de teclas, `viwd` \(resaltar visualmente una palabra y después eliminarla\), si puedes hacer eso mismo con solo tres pulsaciones de teclas \(`diw`\)? Esto último es más directo y conciso. Por supuesto, habrá ocasiones en las que el modo visual será apropiado, pero en general, es mejor un enfoque más directo.