Qual é o propósito da tag de formulário html


105

Não entendo o propósito da tag de formulário em html.

Posso facilmente usar qualquer tipo de entrada perfeitamente sem usar a tag de formulário. Quase parece redundante envolvê-lo em entradas.

Além disso, se estou usando ajax para chamar uma página do lado do servidor, posso simplesmente usar jQuery para isso. A única exceção é que percebi que você precisa envolver um script de upload em torno de uma tag de formulário por algum motivo.

Então, por que os formulários ainda são tão amplamente usados ​​para coisas simples como entradas de texto? Parece uma coisa muito arcaica e desnecessária de fazer.

Eu simplesmente não vejo o benefício ou a necessidade disso. Talvez eu esteja faltando alguma coisa.


Como você define a ação e o método para seu formulário sem a tag html <form>?
Darian

3
Se eu fosse fazer isso no jQuery, usaria a função click () no botão e dentro dela usaria a função ajax (). Muito mais simples e fácil de ler o código na minha opinião. E posso facilmente atualizar a página com javascript simples
D-Marc

23
Estou surpreso que esta questão tenha recebido votos negativos. Eu simplesmente pesquisei isso no Google.
dwjohnston

2
@dwjohnston você deve ser novo aqui ...
Stefano Borini

3
Ótima pergunta! Outros motivos pelos quais não gosto de usar formulários incluem o fato de que limita a estrutura de sua página (porque você não pode ter formulários dentro de formulários), algumas peculiaridades de serialização como o fato de que as caixas de seleção serão ignoradas se não forem marcadas (o que significa que muitas vezes eu acabo preparando manualmente os dados de envio), e porque HTML é fundamentalmente o conteúdo e a estrutura da página, enquanto JS é o dinamismo. Os elementos do formulário se sobrepõem um pouco no trabalho de JS e gosto de ter minhas páginas estruturadas.
3 de

Respostas:


90

O que está faltando é uma compreensão da marcação semântica e do DOM.

Realisticamente, você pode fazer praticamente o que quiser com a marcação HTML5, e a maioria dos navegadores irá analisá-la. Da última vez que verifiquei, o WebKit / Blink permite até pseudo-elementos dentro de <input>elementos , o que é uma violação clara das especificações - o Gecko nem tanto. No entanto, fazer o que quiser com a sua marcação irá, sem dúvida, invalidá-la no que diz respeito à semântica.

Por que colocamos <input>elementos dentro de <form>elementos? Pela mesma razão, colocamos <li>tags dentro dos elementos <ul>e <ol>- é onde eles pertencem. É semanticamente correto e ajuda a definir a marcação. Analisadores, leitores de tela e vários softwares podem entender melhor sua marcação quando ela está semanticamente correta - quando a marcação tem significado, não apenas estrutura.

O <form>elemento também permite definir os atributos methode action, que informam ao navegador o que fazer quando o formulário é enviado. O AJAX não é uma ferramenta de cobertura 100% e, como um desenvolvedor da web, você deve praticar a degradação normal - os formulários devem poder ser enviados e os dados transferidos, mesmo quando o JS está desligado.

Por fim, os formulários são todos devidamente registrados no DOM. Podemos dar uma olhada nisso com JavaScript. Se você abrir seu console nesta página e digitar:

document.forms

Você obterá uma boa coleção de todos os formulários da página. A barra de pesquisa, as caixas de comentários, a caixa de resposta - todos os formulários adequados. Essa interface pode ser útil para acessar informações e interagir com esses elementos. Por exemplo, os formulários podem ser serializados com muita facilidade.

Aqui está algum material de leitura:

Observação: os <input>elementos podem ser usados ​​fora dos formulários, mas se sua intenção for enviar dados de alguma forma, você deve usar um formulário.


Esta é a parte da resposta em que eu viro a pergunta.

Como estou dificultando minha vida evitando as formas?

Em primeiro lugar - elementos de contêiner. Quem precisa deles, certo ?!

Certamente seus elementos pequenos <input>e <button>estão aninhados dentro de algum tipo de elemento contêiner? Eles não podem simplesmente estar flutuando no meio de tudo o mais. Então, se não for um <form>, então o quê? A <div>? A <span>?

Esses elementos precisam residir em algum lugar e, a menos que sua marcação seja uma bagunça maluca, o elemento contêiner pode ser apenas um formulário.

Não? Oh.

Neste ponto, as vozes em minha cabeça estão muito curiosas para saber como você cria seus manipuladores de eventos para todas essas diferentes situações AJAX. Deve haver muitos, se você precisar reduzir sua marcação para economizar bytes. Em seguida, você deve criar funções personalizadas para cada evento AJAX que corresponda a cada 'conjunto' de elementos - que você deve ter como alvo individualmente ou com classes, certo? Não há como agrupar esses elementos genericamente, uma vez que estabelecemos que eles apenas vagam pela marcação, fazendo tudo até que sejam necessários.

Então você customiza alguns manipuladores.

$('#searchButton').on('click', function (e) {
  e.preventDefault();

  var search = $('#mySearch');

  $.ajax({
    url: 'http://example.com/text',
    type: 'GET',
    dataType: 'text',
    data: 'query=' + search.val(),
    success: function (data) {
      console.log(data);
    }
  });
});


$('#login').on('click', function (e) {
  e.preventDefault();
  var user = $('#username'),
      pass = $('#password'),
      rem = $('#remember');
  
  $.ajax({
    url: 'http://example.com/login',
    type: 'POST',
    data: user.add(pass, rem).serialize(),
    dataType: 'text',
    success: function (data) {
      console.log(data);
    }
  });
});
<!-- No containers, extra markup is silly. -->

<input type="text" id="mySearch" value="query" />
<button id="searchButton">Search</button>
<input type="text" id="username" name="username" value="user" />
<input type="password" id="password" name="password" value="pass" />
<input type="checkbox" id="remember" name="remember" checked /> stay logged in
<button id="login">Login</button>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

Esta é a parte em que você diz algo como:

'Eu uso totalmente funções reutilizáveis ​​embora. Pare de exagerar. '

É justo, mas você ainda precisa criar esses conjuntos de elementos únicos, ou conjuntos de classes de destino, certo? Você ainda precisa agrupar esses elementos de alguma forma.

Empreste-me seus olhos (ou ouvidos, se você estiver usando um leitor de tela e precisar de alguma ajuda - boa coisa que poderíamos adicionar um pouco de ARIA a toda essa marcação semântica , certo?), E observe o poder da forma genérica.

function genericAjaxForm (e) {
  e.preventDefault();
  var form = $(this);
  
  return $.ajax({
    url: form.attr('action'),
    type: form.attr('method'),
    dataType: form.data('type'),
    data: form.serialize()
  });
}

$('#login-form').on('submit', function (e) {
  genericAjaxForm.call(this, e).done(function (data) {
    console.log(data);
  });
});
<form action="http://example.com/login" method="POST" data-type="text" id="login-form">
  <input type="text" name="username" value="user" />
  <input type="password" name="password" value="mypass" />
  <label>
    <input type="checkbox" name="remember" /> Remember me
  </label>

  <button type="submit">Login</button>
</form>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

Podemos usar isso com qualquer forma comum, manter nossa degradação elegante e deixar a forma descrever completamente como deve funcionar. Podemos expandir essa funcionalidade básica, mantendo um estilo genérico - mais modular, menos dores de cabeça. O JavaScript apenas se preocupa com suas próprias coisas, como ocultar os elementos apropriados ou lidar com qualquer resposta que obtivermos.

E agora você diz:

'Mas eu envolvo minhas pseudo-formas em <div> elementos que têm IDs específicos - posso então direcionar as entradas vagamente com com .find, e .serializeeles, e ...'

Oh, o que é isso? Você realmente envolve seus <input>elementos em um contêiner?

Então, por que ainda não é um formulário?


2
Esse é um bom ponto ao dar uma olhada em todos os formulários. Posso ver por que isso seria visto como uma vantagem. Além disso, por que você diz que as entradas devem ser usadas dentro de um formulário? Não parece oferecer nenhuma vantagem real. Apenas código extra. Nunca li nada online que diga que é semanticamente incorreto colocar entradas fora dos formulários, então não acho que seja justo compará-lo com uls e ols. E, realisticamente, eu nunca gostaria que ninguém usasse meus sites se eles tivessem o javascript desligado. Além disso, isso provavelmente representaria apenas 1% dos usuários online.
D-Marc

2
Parece menos que você está procurando uma resposta para o motivo pelo qual usamos <form>elementos e mais como você está tentando afirmar suas próprias opções de marcação. Isso é bom, como eu disse, você é livre para fazer o que quer que você gosta com sua marcação, mas eu explicou as principais razões por que os desenvolvedores usam formulários.
Oka

2
Grandes pontos feitos. Eu realmente aprecio o fato de que você dedicou tempo para elaborar mais sua resposta e fornecer exemplos de código reais. Vou dar outra chance ao forms e ver se gosto mais de fazer assim. Obrigado novamente pela ajuda. No entanto, você não acha que é inútil envolver um formulário em apenas uma caixa de texto?
D-Marc

Depende do contexto. Uma entrada que nunca é enviada diretamente , como uma caixa de pesquisa que pesquisa um endpoint de API exclusivamente por AJAX em eventos diferentes submit, pode omitir ser agrupada em um formulário, pois não teria nenhuma funcionalidade sem JavaScript. Não é uma marcação inválida ter um <input>fora de a <form>, apenas uma semântica possivelmente pobre. Se houver uma maneira de enviar os dados sem AJAX, com um submitevento adequado , um formulário é provavelmente o melhor. Novamente, o elemento precisa de um contêiner e os <form>elementos estão no nível do bloco por padrão, então eles agem como um <div>.
Oka

6

As tags de formulário ainda são necessárias se você quiser enviar o formulário sem AJAX (o que pode ser útil nos estágios iniciais de desenvolvimento). Mas, embora seja possível usar javascript para enviar dados sem uma tag de formulário, alguns benefícios ainda vêm à mente:

  1. O uso de tags de formulário pode ajudar as pessoas a ler e entender seu código em alguns casos, mostrando-lhes suas intenções.
  2. O método de 'envio' está disponível em formulários. Se você tiver um formulário com uma entrada [type = submit] e não estiver desabilitado, quando alguém clicar em 'enter' enquanto preenche uma das outras entradas do formulário, o formulário será enviado. Você ainda pode fazer isso ouvindo o evento 'keydown' nos elementos de entrada, mas é um bom pedaço de ui que você obtém de graça com tags de formulário.
  3. Existem algumas outras coisas que funcionam apenas com uma tag de formulário ou são mais fáceis com uma tag de formulário. Os desenvolvedores acabarão encontrando esses casos e decidirão que é mais fácil usá-los sempre em qualquer lugar para evitar problemas. Na verdade, a verdadeira questão é: por que não usar uma tag de formulário?

Além disso, coisas como jQuery .serialize()só funcionam em elementos de formulário.
EJTH

0

O elemento HTML representa uma seção do documento que contém controles interativos para enviar informações a um servidor web.

Todos estamos familiarizados com os formulários em páginas da web html. Por diversos motivos, as pessoas ou empresas solicitam nossos endereços de e-mail, nomes e URLs de sites. Hoje, comprar produtos na Internet é muito fácil e, com o advento dos dispositivos de segurança, o método usado para enviar seus dados e dinheiro ganho com dificuldade é geralmente realizado por meio de formulários.

mais informações

link um

link dois


Sim, mas você não precisa envolver entradas de texto como endereços de e-mail ou senhas em formulários para enviar dados. Posso fazer isso facilmente com ajax. Os formulários não fornecem nenhuma segurança extra. No entanto, posso fazer isso com php se criptografar os dados.
D-Marc

0

Tive um cenário em que uma única página da web tinha 3 formulários, todos com campos de e-mail separados (com IDs diferentes). Eu os embrulhei em separado <div>primeiro. O preenchimento automático do iOS no Safari se comportou estranhamente até que eu envolvi todos eles<form> tags. Um dos formulários possuía apenas um campo de entrada, para assinatura da newsletter. Quando o usuário preencheu automaticamente essa entrada, a página da web foi rolada para o próximo campo de entrada, localizado em uma parte diferente da página.

Então, obrigado Oka pela longa postagem. Tags com significado semântico devem ser usados ​​sempre que possível, porque você nunca sabe qual navegador / dispositivo não lida bem com outras soluções.

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.