You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
157 lines
9.6 KiB
157 lines
9.6 KiB
11 months ago
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||
|
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
||
|
|
||
|
<!-- Enable responsiveness on mobile devices-->
|
||
|
<!-- viewport-fit=cover is to support iPhone X rounded corners and notch in landscape-->
|
||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1, viewport-fit=cover">
|
||
|
|
||
|
<title>Julio Biason .Me 4.3</title>
|
||
|
|
||
|
<!-- CSS -->
|
||
|
<link rel="stylesheet" href="https://blog.juliobiason.me/print.css" media="print">
|
||
|
<link rel="stylesheet" href="https://blog.juliobiason.me/poole.css">
|
||
|
<link rel="stylesheet" href="https://blog.juliobiason.me/hyde.css">
|
||
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Sans:400,400italic,700|Abril+Fatface">
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
</head>
|
||
|
|
||
|
<body class=" ">
|
||
|
|
||
|
<div class="sidebar">
|
||
|
<div class="container sidebar-sticky">
|
||
|
<div class="sidebar-about">
|
||
|
|
||
|
<a href="https://blog.juliobiason.me"><h1>Julio Biason .Me 4.3</h1></a>
|
||
|
|
||
|
<p class="lead">Old school dev living in a 2.0 dev world</p>
|
||
|
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<ul class="sidebar-nav">
|
||
|
|
||
|
|
||
|
<li class="sidebar-nav-item"><a href="/">English</a></li>
|
||
|
|
||
|
<li class="sidebar-nav-item"><a href="/pt">Português</a></li>
|
||
|
|
||
|
<li class="sidebar-nav-item"><a href="/tags">Tags (EN)</a></li>
|
||
|
|
||
|
<li class="sidebar-nav-item"><a href="/pt/tags">Tags (PT)</a></li>
|
||
|
|
||
|
|
||
|
</ul>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
<div class="content container">
|
||
|
|
||
|
<div class="post">
|
||
|
<h1 class="post-title">14.05. Plugins - Tabular</h1>
|
||
|
<span class="post-date">
|
||
|
2015-12-22
|
||
|
|
||
|
</span>
|
||
|
<p>Essa é a parte em que deixamos as coisas alinhadas.</p>
|
||
|
<span id="continue-reading"></span>
|
||
|
<p>O quinto plugin da lista de plugins é
|
||
|
<a href="https://github.com/godlygeek/tabular">Tabular</a>, um plugin para alinhar
|
||
|
elementos baseados em expressões regulares (calma, não é tão complicado quando
|
||
|
parece.)</p>
|
||
|
<p>Mais uma vez, para instalar pelo Vundle:</p>
|
||
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span>Plugin </span><span style="color:#a3be8c;">"godlygeek/tabular"
|
||
|
</span></code></pre>
|
||
|
<p>Assim como Fugitive e Commentary, Tabular não é um plugin visual, mas adiciona
|
||
|
um novo comando <code>:{range}Tabularize {expressão regular}</code>.</p>
|
||
|
<p>(Apenas lembrando de {range}: são dois indicadores separados por vírgula,
|
||
|
números são linhas, "$" é a última linha do arquivo, "%" é igual à "1,$" (todo o
|
||
|
arquivo), "'{marcador1},'{marcador2}" vai do marcador1 até o marcador2 e, se você
|
||
|
selecionar uma região no modo visual, ao pressionar <code>:</code>, o prompt deve ficar "'<
|
||
|
,'>" que são os marcadores especiais de início e fim, respectivamente, da área
|
||
|
visual. Todos os exemplos que eu vou mostrar daqui pra frente vão usar o
|
||
|
{range} de início e fim do bloco visual, porque faz mais sentido.)</p>
|
||
|
<p>A forma mais simples de usar o Tabular é passar um único caractere, que indica
|
||
|
qual o ponto onde os elementos serão alinhados. Por exemplo, com o seguinte
|
||
|
trecho de código:</p>
|
||
|
<pre data-lang="javascript" style="background-color:#2b303b;color:#c0c5ce;" class="language-javascript "><code class="language-javascript" data-lang="javascript"><span style="color:#b48ead;">var </span><span style="color:#bf616a;">pos </span><span>= </span><span style="color:#d08770;">1</span><span>;
|
||
|
</span><span style="color:#b48ead;">var </span><span style="color:#bf616a;">element </span><span>= </span><span style="color:#8fa1b3;">$</span><span>(</span><span style="color:#bf616a;">this</span><span>);
|
||
|
</span><span style="color:#b48ead;">var </span><span style="color:#bf616a;">i </span><span>= </span><span style="color:#d08770;">0</span><span>;
|
||
|
</span></code></pre>
|
||
|
<p>Se você selecionar o mesmo visualmente e fizer <code>:'< ,'>Tabularize /=</code>, o resultado será:</p>
|
||
|
<pre data-lang="javascript" style="background-color:#2b303b;color:#c0c5ce;" class="language-javascript "><code class="language-javascript" data-lang="javascript"><span style="color:#b48ead;">var </span><span style="color:#bf616a;">pos </span><span>= </span><span style="color:#d08770;">1</span><span>;
|
||
|
</span><span style="color:#b48ead;">var </span><span style="color:#bf616a;">element </span><span>= </span><span style="color:#8fa1b3;">$</span><span>(</span><span style="color:#bf616a;">this</span><span>);
|
||
|
</span><span style="color:#b48ead;">var </span><span style="color:#bf616a;">i </span><span>= </span><span style="color:#d08770;">0</span><span>;
|
||
|
</span></code></pre>
|
||
|
<p>Ao contrário da pesquisa (e da substituição), Tabularize aceita um segundo
|
||
|
parâmetro que indica como os elementos devem ser alinhados e qual o espaçamento
|
||
|
que deve existir entre os elementos. Este parâmetro pode ser até 3 pares, no
|
||
|
formato {alinhamento}{espaços depois do elemento} que, apesar da minha péssima
|
||
|
descrição, não é tão complicado assim.</p>
|
||
|
<p>Por exemplo, imagine que eu tenho o seguinte pedaço de código em HTML:</p>
|
||
|
<pre data-lang="html" style="background-color:#2b303b;color:#c0c5ce;" class="language-html "><code class="language-html" data-lang="html"><span><</span><span style="color:#bf616a;">input </span><span style="color:#d08770;">class</span><span>='</span><span style="color:#a3be8c;">block-size disabled</span><span>'
|
||
|
</span><span> </span><span style="color:#8fa1b3;">id</span><span>='</span><span style="color:#a3be8c;">input-box</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">name</span><span>='</span><span style="color:#a3be8c;">login</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">value</span><span>=''
|
||
|
</span><span> </span><span style="color:#d08770;">placeholder</span><span>='</span><span style="color:#a3be8c;">Enter your login</span><span>'>
|
||
|
</span></code></pre>
|
||
|
<p>No caso, eu estou quebrando cada um dos elementos para diminuir o tamanho da
|
||
|
linha, já que ainda não coloquei minhas opções de templating e cada uma destas
|
||
|
linhas deve ficar bem maior. Mas, como exemplo, serve.</p>
|
||
|
<p>O que eu quero é que os "=" fiquem alinhados (mais ou menos o que o Xcode faz
|
||
|
com código Objective-C). Assim, eu posso fazer <code>:'< ,'>Tabularize /=/r0c0l0</code> para
|
||
|
obter:</p>
|
||
|
<pre data-lang="html" style="background-color:#2b303b;color:#c0c5ce;" class="language-html "><code class="language-html" data-lang="html"><span> <</span><span style="color:#bf616a;">input </span><span style="color:#d08770;">class</span><span>='</span><span style="color:#a3be8c;">block-size disabled</span><span>'
|
||
|
</span><span> </span><span style="color:#8fa1b3;">id</span><span>='</span><span style="color:#a3be8c;">input-box</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">name</span><span>='</span><span style="color:#a3be8c;">login</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">value</span><span>=''
|
||
|
</span><span> </span><span style="color:#d08770;">placeholder</span><span>='</span><span style="color:#a3be8c;">Enter your login</span><span>'>
|
||
|
</span></code></pre>
|
||
|
<p>A explicação está no parámetro: o primeiro par, "r0" siginfica que o elemento
|
||
|
antes do alinhamento deve ser alinhado à direita ("r") com 0 espaços depois do
|
||
|
elemento; "c0" significa que o elemento de alinhamento (no nosso caso, "=")
|
||
|
deve ser centralizado ("c") também com 0 espaços depois; e finalmente "l0"
|
||
|
significa que o elemento depois do alinhamento deve ficar à esquerda ("l") e
|
||
|
nenhum espaço deve ser adicionado.</p>
|
||
|
<p>Se eu quisesse que o espaço não ficasse grudado tanto na esquerda quando na
|
||
|
direita, eu teria que fazer <code>:'< ,'>Tabularize /=/r1c1l0</code> para obter:</p>
|
||
|
<pre data-lang="html" style="background-color:#2b303b;color:#c0c5ce;" class="language-html "><code class="language-html" data-lang="html"><span> <</span><span style="color:#bf616a;">input </span><span style="color:#d08770;">class </span><span>= '</span><span style="color:#a3be8c;">block-size disabled</span><span>'
|
||
|
</span><span> </span><span style="color:#8fa1b3;">id </span><span>= '</span><span style="color:#a3be8c;">input-box</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">name </span><span>= '</span><span style="color:#a3be8c;">login</span><span>'
|
||
|
</span><span> </span><span style="color:#d08770;">value </span><span>= ''
|
||
|
</span><span> </span><span style="color:#d08770;">placeholder </span><span>= '</span><span style="color:#a3be8c;">Enter your login</span><span>'>
|
||
|
</span></code></pre>
|
||
|
<div>
|
||
|
|
||
|
<div style="float:left">
|
||
|
<< <a href="./14-04-commentary">Plugins - Commentary</a>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<div style="float:right">
|
||
|
<a href="./14-06-autopairs">Plugins - Auto-pairs</a> >>
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
</div>
|
||
|
|
||
|
</body>
|
||
|
|
||
|
</html>
|