Como gerar uma lista ordenada e não ordenada a partir de algumas linhas no Sublime Text

Como gerar uma lista ordenada e não ordenada a partir de algumas linhas no Sublime Text

Como gerar listas ordenadas e não ordenadas com eficiência a partir de algumas linhas?

Digamos:

list item 1
list item 2
list item 3

em

<ul>
  <li>list item 1</li>
  <li>list item 2</li>
  <li>list item 3</li>
</ul>

Responder1

Você pode instalar o pacote Emmet via Package Control (link) ou instale-o diretamente copiando os arquivos do pacote Emmet. Então

// don't forget to choose HTML edit mode in the Sublime Text editor

// type 
ul#nav>li.item$*4>a{Item $}
// 1      2     3   4
//1- List ID
//2- class name
//3- list members number
//4- items name

Aperte o Tabbotão e você verá:

<ul id="nav">
    <li class="item1"><a href="">Item 1</a></li>
    <li class="item2"><a href="">Item 2</a></li>
    <li class="item3"><a href="">Item 3</a></li>
    <li class="item4"><a href="">Item 4</a></li>
</ul>

Logo após a criação da lista, você também pode pressionar Tabpara passar rapidamente para os itens seguintes (ou anteriores).

Responder2

Caso o plugin Emmet não seja adequado para você, você pode tentar salvar o seguinte como uma macro e usá-lo. Não recua e não tem verificação de erros, mas faz o que eu precisava. (Preferências-> Navegar pelos pacotes, abra a pasta "usuário", crie uma nova pasta chamada algo como "ulmaker" e salve-a como "ulmaker.sublime-macro" dentro dela.) Então você pode usá-la no menu suspenso (Ferramentas-> Macros) ouvincule-o a uma chave.

(Preferências->Usuário de atalhos de teclado)

{ "keys": ["alt+u", "alt+l"], "command": "run_macro_file", "args": {"file": "Packages/User/ulmaker/ulmaker.sublime-macro"} }

Isso o vincula a uma combinação onde você segura ALT e pressiona u e depois l.

[
    {
        "args": null,
        "command": "split_selection_into_lines"
    },
    {
        "args":
        {
            "extend": false,
            "to": "bol"
        },
        "command": "move_to"
    },
    {
        "args":
        {
            "characters": "<li"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": ">"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "extend": false,
            "to": "eol"
        },
        "command": "move_to"
    },
    {
        "args":
        {
            "characters": "<"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": "/li"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": ">"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "extend": true,
            "to": "bol"
        },
        "command": "move_to"
    },
    {
        "args": null,
        "command": "cut"
    },
    {
        "args": null,
        "command": "single_selection"
    },
    {
        "args":
        {
            "characters": "<ul"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": ">"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": "\n"
        },
        "command": "insert"
    },
    {
        "args": null,
        "command": "paste"
    },
    {
        "args":
        {
            "characters": "\n<"
        },
        "command": "insert"
    },
    {
        "args":
        {
            "characters": "/ul>"
        },
        "command": "insert"
    }
]

Uma pessoa mais experiente pode limpar um pouco esse código. Acabei de usar ctrl+q para gravar isso e salvei.

informação relacionada