HTML5 e CSS3 001-123

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 123

Machine Translated by Google

Machine Translated by Google

GUIA VISUAL DE INÍCIO RÁPIDO

HTML5
e CSS3
Sétima Edição

Elizabeth Castro • Bruce Hyslop

Imprensa de pêssego
Machine Translated by Google

HTML5 e CSS3, sétima edição: Guia visual de início rápido

Elizabeth Castro e Bruce Hyslop

Imprensa de pêssego
Rua Oitava, 1249
Berkeley, CA 94710
510/524-2178
510/524-2221 (fax)

Encontre-nos na Web em www.peachpit.com.

Para relatar erros, envie uma nota para [email protected].


Peachpit Press é uma divisão da Pearson Education.

Copyright © 2012 por Elizabeth Castro e Bruce Hyslop

Editor: Clifford Colby


Editor de desenvolvimento: Robyn G. Thomas
Editor de produção: Cory Borman
Compositor: David Van Ness
Editor de texto: Scout Festa
Revisor: Nolan Hester
Editores técnicos: Michael Bester e Chris Casciano
Indexadora: Valerie Haynes Perry
Design da capa: RHDG/Riezebos Holzbaur Design Group, Peachpit Press
Design de interiores: Peachpit Press
Design do logotipo: MINE™ www.minesf.com

Aviso de Direitos
Todos os direitos reservados. Nenhuma parte deste livro pode ser reproduzida ou transmitida de qualquer forma, por qualquer meio, eletrônico,
mecânico, fotocópia, gravação ou outro, sem a permissão prévia por escrito do editor. Para obter informações sobre como obter permissão
para reimpressões e trechos, entre em contato com [email protected].

Capturas de tela de bart.gov cortesia do Distrito de Trânsito Rápido da Área da Baía de São Francisco (BART).
Capturas de tela de css3generator.com cortesia de Randy Jensen.
Capturas de tela do dribbble.com cortesia de Dan Cederholm.
Capturas de tela de fontsquirrel.com cortesia de Ethan Dunham.
Foodense.is capturas de tela cortesia de Julie Lamba.
capturas de tela do modernizr.com cortesia de Faruk Ates.
Capturas de tela de namecheap.com cortesia de Namecheap.

Aviso de responsabilidade
As informações contidas neste livro são distribuídas “como estão”, sem garantia. Embora todas as precauções tenham sido tomadas na preparação do
livro, nem os autores nem a Peachpit terão qualquer responsabilidade perante qualquer pessoa ou entidade com relação a qualquer perda ou
dano causado ou supostamente causado direta ou indiretamente pelas instruções contidas neste livro. ou pelos produtos de software e hardware de
computador nele descritos.

Marcas registradas

Muitas das designações utilizadas pelos fabricantes e vendedores para distinguir os seus produtos são reivindicadas como marcas comerciais.
Quando essas designações aparecem neste livro, e a Peachpit estava ciente de uma reivindicação de marca registrada, as designações aparecem
conforme solicitado pelo proprietário da marca registrada. Todos os outros nomes de produtos e serviços identificados ao longo deste livro são usados
apenas de forma editorial e para o benefício de tais empresas, sem intenção de violação da marca registrada.
Nenhum tal uso, ou o uso de qualquer nome comercial, tem a intenção de transmitir endosso ou outra afiliação a este livro.

ISBN-13: 978-0-321-71961-4
ISBN-10: 0-321-71961-1

987654321

Impresso e encadernado nos Estados Unidos da América


Machine Translated by Google

Para a família.
Machine Translated by Google

Agradecimentos Cory Borman, por supervisionar habilmente a


produção do livro e criar diagramas rapidamente, e
Escrever os agradecimentos é um dos desafios por seu bom humor.
mais assustadores de trabalhar em um livro, porque
Scout Festa, por corrigir cuidadosamente a gramática
você quer ter certeza de transmitir seu apreço por
e a pontuação, aperfeiçoar a linguagem, garantir
todos de maneira adequada. Este livro é fruto do
a precisão das referências de figuras e capítulos e,
apoio, do trabalho incansável e do bom humor
acima de tudo, fornecer um nível de polimento muito
de muita gente. Espero fazer justiça a todos eles e
importante.
espero que vocês me concedam um pouco enquanto
lhes agradeço. David Van Ness, por seu grande cuidado no layout
das páginas e por sua proficiência e atenção aos
detalhes.
Um agradecimento muito sincero vai para:
Nolan Hester, por emprestar sua experiência ao
Nancy Aldrich-Ruenzel e Nancy Davis, por me
esforço de revisar as páginas dispostas.
confiarem esta edição de um livro que tem sido
importante para a Peachpit há muitos anos. Valerie Haynes Perry, por lidar com a tarefa crítica de
criar um índice eficaz no qual os leitores confiarão
continuamente.
Cliff Colby, por me recomendar e tornar isso possível;
pela sua confiança em mim e pela sua paciência, Aos numerosos profissionais de marketing, vendas e

flexibilidade e orientação; e para inúmeras conversas outras pessoas da Peachpit por trabalharem nos
e muitas bastidores para tornar o livro um sucesso.

de risadas. À minha família e amigos, por acompanharem meu

Robyn Thomas, por seu tremendo esforço em nos progresso e proporcionarem pausas ocasionais e bem-

manter no caminho certo, discutindo incontáveis vindas na escrita. Agradeço principalmente àqueles

documentos, fazendo edições e sugestões amigos que provavelmente se cansaram de me ouvir

cuidadosas e fornecendo palavras regulares de dizer muitas vezes que eu não poderia me reunir,

encorajamento, que sempre foram um incentivo. mas que continuaram perguntando mesmo assim.

Robert Reinhardt, como sempre, por me iniciar na

Michael Bester, por todos os comentários e escrita de livros e por sua orientação enquanto eu

sugestões pontuais, detectando erros técnicos e iniciava este.

omissões e nos ajudando a transmitir a mensagem A comunidade da Web, por suas inovações e por
certa aos leitores. Foi um verdadeiro prazer compartilhar seu conhecimento para que outros
trabalhar com ele em outro livro. possam se beneficiar (citei muitos de vocês ao longo
do livro).
Chris Casciano, na mesma linha, por todo o seu A vocês, leitores, pelo interesse em aprender sobre
conhecimento técnico, sugestões e feedback crucial. HTML e CSS e por selecionarem este livro; Eu sei que
Gostei muito de você ter se juntado a nós nas últimas você tem muitos outros para escolher. Espero que o
semanas; tivemos sorte de ter você. livro lhe sirva bem.

iv Agradecimentos
Machine Translated by Google

Muito obrigado aos seguintes autores colaboradores. Seth Lemoine (capítulos 5 e 16)
Os leitores têm um livro mais valioso devido aos Seth Lemoine é desenvolvedor de software e professor
seus esforços, pelos quais sou grato. Também gostaria em Atlanta. Por mais de dez anos, ele trabalhou em
de pedir desculpas a Erik Vorhes por não termos projetos desafiadores para ver o que é possível,
conseguido encaixar os Apêndices A e B no livro. com tecnologias que vão desde HTML, JavaScript
e CSS até Objective-C e Ruby. Seja encontrando
Leitores que os veem no site do livro maneiras inovadoras de ensinar HTML5 e CSS para
certamente apreciará seu trabalho. seus alunos ou aperfeiçoando uma receita Schezuan
em seu wok ao ar livre, ser criativo é sua paixão.
Em ordem alfabética de sobrenome, os autores
colaboradores são:
Erik Vorhes (Apêndices A e B, disponíveis
Scott Boms (Capítulo 14)
no site do livro)
Scott é um premiado designer, escritor e palestrante
Erik Vorhes cria coisas para a Web com VSA Partners e
que fez parceria com organizações como PayPal,
é editor-chefe da Typedia (http://typedia.com/). Ele
HSBC, Hyundai, DHL, XM Radio, revista Toronto Life
mora e trabalha em Chicago.
e Masterfile durante seus mais de 15 anos de
trabalho na Web. Quando ele está longe do
computador, você pode encontrá-lo tirando fotos Brian Warren (Capítulo 13)
Polaroids; tocando bateria com sua banda, George; Brian Warren é designer sênior da Happy Cog na
ou aproveitando o tempo com sua maravilhosa esposa Filadélfia. Quando não está escrevendo ou desenhando,
e dois filhos. Ele é ele passa o tempo brincando com sua linda família,
ouvindo música e fazendo cerveja. Ele bloga, de forma
@scottboms no Twitter. intermitente, em http://begoodnotbad.com.

Ian Devlin (Capítulo 17)


Ian Devlin é um desenvolvedor Web, blogueiro e autor
irlandês que gosta de programar e escrever sobre
tecnologias emergentes da Web, como HTML5 e CSS3. E, por fim, gostaria de deixar um agradecimento
Além de
especial a Elizabeth Castro. Ela criou a primeira edição
desenvolvimento front-end, Ian também constrói deste livro há mais de
soluções com tecnologias back-end como .NET e PHP. 15 anos atrás e nutriu seu público a cada edição que
Ele escreveu recentemente um livro, HTML5 se seguiu. Seu estilo de ensino ressoou em
Multimedia: Develop and Design (Peachpit Press, 2011). literalmente centenas de milhares de leitores ao
longo dos
anos. Sou extremamente grato pela oportunidade de
fazer parte deste livro e tive o cuidado de fazer o
que é certo tanto para ele quanto para os leitores
enquanto trabalhava nesta edição.

—Bruce

Agradecimentos _
Machine Translated by Google

Resumo do conteúdo

agradecimentos . . . . . . . . . . . . . . . . . . . . 4
introdução . . . . . . . . . . . . . . . . . . . . . . . . xv

Capítulo 1 Blocos de construção de páginas da Web . . . . . . . . . . . . . . . 1

Capítulo 2 Trabalhando com arquivos de páginas da Web . . . . . . . . . . . . 25

Capítulo 3 Estrutura HTML básica . . . . . . . . . . . . . . . . . 41

Texto do capítulo 4 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99

Imagens do capítulo 5 . . . . . . . . . . . . . . . . . . . . . . . . . . . 147

Links do capítulo 6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165

Capítulo 7 Blocos de construção CSS . . . . . . . . . . . . . . . . . . 179

Capítulo 8 Trabalhando com folhas de estilo . . . . . . . . . . . . . . 197

Capítulo 9 Definindo seletores . . . . . . . . . . . . . . . . . . . 213

Capítulo 10 Formatando texto com estilos . . . . . . . . . . . . . 241

Capítulo 11 Layout com estilos . . . . . . . . . . . . . . . . . . . . 275

Capítulo 12 Folhas de estilo de Mobile para Desktop . . . . . . . . 327

Capítulo 13 Trabalhando com fontes da Web . . . . . . . . . . . . . . . 353

Capítulo 14 Melhorias com CSS3 . . . . . . . . . . . . . . . 371

Listas do Capítulo 15 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 397

Capítulo 16 Formulários . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417

Capítulo 17 Vídeo, áudio e outros recursos multimídia . . . . . . . 449

Capítulo 18 tabelas . . . . . . . . . . . . . . . . . . . . . . . . . . . 489

Capítulo 19 Trabalhando com scripts . . . . . . . . . . . . . . . . . . 497

Capítulo 20 Teste e depuração de páginas da Web . . . . . . . . . 505

Capítulo 21 publicando suas páginas na Web . . . . . . . . . 521


índice . . . . . . . . . . . . . . . . . . . . . . . . . . . . 529

vi Visão geral do conteúdo


Machine Translated by Google

Índice

Agradecimentos . . . . . . . . . . . . . . . . . . . . . 4

Introdução . . . . . . . . . . . . . . . . . . . . . . . . xv
HTML e CSS em resumo. . ... . . . . . . . . . . . . . . xvi
Aprimoramento progressivo: uma prática recomendada . . . . . . XVIII
Esse livro é para você? . . . . . . . . . . . . . . . . . . . . xx
Como este livro funciona. . . . . . . . . . . . . . . . . . . . XXII
Site complementar. . . ... . . . . . . . . . . . . . XXIV

Capítulo 1 Blocos de construção de páginas da Web . . . . . . . . . . . . . . . . 1


Uma página HTML básica. . . . . . .
. . . . . . . . . . . . . . .3
HTML semântico: marcação com significado. . . . . . . . . . . 6
Marcação: elementos, atributos e valores . . . . . . . . .13
Conteúdo de texto de uma página da Web. . . . . . . . . . . . . . . . 16
Links, imagens e outros conteúdos não textuais . . . . . . . .17
. . . . . . . . . . . . . . . . . . . . . . . . . 19
Nomes de arquivos .

URLs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Principais conclusões. . . . . . . . . . . . . . . . . . . . . . . . 24

Capítulo 2 Trabalhando com arquivos de páginas da Web . . . . . . . . . . . . . 25


Planejando seu site. . . . . . . . . . . . . . . . . . . . . . 26
Criando uma nova página da Web. . . . . . . . . . . . . . . . . 28
Salvando sua página da web. . . . . . . . . . . . . . . . . . . 30
Especificando uma página padrão ou página inicial. . . . . . . . . 33
Editando páginas da Web . . . . . . . . . . . . . . . . . . . . . 35
Organizando Arquivos . . . . . . . . . . . . . . . . . . . . . . . 36
Visualizando sua página em um navegador. . . . . . . . . . . . . . 37
A inspiração de outros. . . . . . . . . . . . . . . . . . 39

Capítulo 3 Estrutura HTML Básica . . . . . . . . . . . . . . . . . . 41


Iniciando sua página da Web. . . . . . . . . . . . . . . . . . 43
Criando um título. . . . . . . . . . . . . . . . . . . . . . . . 46
Criando títulos . . . . . . . . . . . . . . . . . . . . . 48
Compreendendo o esboço do documento HTML5. . . . . . . 50
Agrupando títulos. . . . . . . . . . . . . . . . . . . . . 58
Construções de páginas comuns. . . . . . . . . . . . . . . . . 60

Índice vii
Machine Translated by Google

Criando um cabeçalho. . . . . . . . . . . . . . . . . . . . . . 61
Marcação de navegação . . . . . . . . . . . . . . . . . . . . . 64
Criando um Artigo. . . . . . . . . . . . . . . . . . . . . 68
Definindo uma seção. . . . . . . . . . . . . . . . . . . . . . 72
Especificando um aparte. . . . . . . . . . . . . . . . . . . . . 75
Criando um rodapé . . . . . . . . . . . . . . . . . . . . . . 80
Criando contêineres genéricos. . . . . . . . . . . . . . . . 84
Melhorando a acessibilidade com . . . . . . . . . . . . . 88
elementos de nomenclatura ARIA com classe ou. ID.
. .. . . . . . . . 92
Adicionando o atributo Title aos elementos. . . . . . . . . . 95
Adicionando comentários . . . . . . . . . . . . . . . . . . . . . 96

Capítulo 4 Texto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
Iniciando um novo parágrafo. . . . . . . . . . . . . . . . 0,100
Adicionando informações de contato do autor. . . . . . . . . . . .102
Criando uma Figura . . . . . . . . . . . . . . . . . . . . . .104
Especificando hora. . . . . . . . . . . . . . . . . . . . . . .106
Marcando texto importante e enfatizado. . . . . . . . . 110
Indicando uma Citação ou Referência. . . . . . . . . . . . . 112
Citando Texto. . . . . . . . . . . . . . . . . . . . . . . . . 113
Destacando texto. . . . . . . . . . . . . . . . . . . . . . 116
Explicando abreviaturas . . . . . . . . . . . . . . . . . . 118
Definindo um Termo . . . . . . . . . . . . . . . . . . . . . . 0,120
Criação de sobrescritos e subscritos. . . . . . . . . . . 121
Observando edições e textos imprecisos. . . . . . . . . . . . . 124
Código de marcação. . . . . . . . . . . . . . . . . . . . . .128
Usando texto pré-formatado. . . . . . . . . . . . . . . . . 0,130
Especificação de letras miúdas . . . . . . . . . . . . . . . . . . . .132
Criando uma quebra de linha . . . . . . . . . . . . . . . . . . . .133
Criando períodos . . . . . . . ... . . . . . . . . . . . . .134
Outros Elementos. . . . . . . ... . . . . . . . . . . . . .136

Capítulo 5 Imagens . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147


Sobre Imagens para a Web . . . . . . . . . . . . . . . . .148
Obtendo imagens . . . . . . . . . . . . . . . . . . . . . . .152
Escolhendo um Editor de Imagens. . . . . . . . . . . . . . . . .153
Salvando suas imagens . . . . . . . . . . . . . . . . . . . . .154
Inserindo imagens em uma página . . . . . . . . . . . . . . . 0,156
Oferecendo texto alternativo. . . . . . . . . . . . . . . . . . . 157
. . . . . . . . . . . . . . . . . 0,158
Especificando o tamanho da imagem .

Dimensionando imagens com o navegador . . . . . . . . . . . . 0,160

viii Índice
Machine Translated by Google

Dimensionando imagens com um editor de imagens. . . . . . . . . . . 161


Adicionando ícones ao seu site. . . . . . . . . . . . . .162

Capítulo 6 Links . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165


A anatomia de um link . . . . . . . . . . . . . . . . . . 0,166
Criando um link para outra página da web. . . . . . . . . . . 167
Criando Âncoras . . . . . . . . . . . . . . . . . . . . . . 172
Vinculando a uma âncora específica. . . . . . . . . . . . . . . . 174
Criando outros tipos de links. . . . . . . . . . . . . . . 175

Capítulo 7 Blocos de Construção CSS . . . . . . . . . . . . . . . . . . . 179


Construindo uma regra de estilo. . . . . . . . . . . . . . . . . . 181
Adicionando comentários às regras de estilo. . . . . . . . . . . . .182
A cascata: quando as regras colidem. . . . . . . . . . . . .184
O valor de uma propriedade. . . . . . . . . . . . . . . . . . . . . .188

Capítulo 8 Trabalhando com folhas de estilo . . . . . . . . . . . . . . . 197


Criando uma folha de estilo externa . . . . . . . . . . . . 0,198
Vinculando a folhas de estilo externas . . . . . . . . . . . . . 200
Criando uma folha de estilo incorporada. . . . . . . . . . . 202
Aplicando estilos embutidos . . . . . . . . . . . . . . . . . . . 204
A importância da localização. . . . . . . . . . . . . . . 206
Usando folhas de estilo específicas de mídia . . . . . . . . . . . 208
Oferecendo folhas de estilo alternativas. . . . . . . . . . . . . .210
A inspiração de outros: CSS. . . . . . . . . . . . . . .212

Capítulo 9 Definindo Seletores . . . . . . . . . . . . . . . . . . . . 213


Construindo Seletores . . . . . . . . . . . . . . . . . . .214
Selecionando Elementos por Nome . . . . . . . . . . . . . . .216
Selecionando Elementos por Classe ou ID. . . . . . . . . . . . .218
Selecionando Elementos por Contexto . . . . . . . . . . . . . .221
Selecionando Parte de um Elemento . . . . . . . . . . . . . . . 227
Selecionando links com base em seu estado. . . . . . . . . . 230
Selecionando Elementos Baseados em Atributos. . . . . . . . 232
Especificando grupos de elementos . . . . . . . . . . . . . 236
Combinando Seletores . . . . . . . . . . . . . . . . . . . 238
. . . . . . . . . . . . . . . . . . . . . 240
Recapitulação dos Seletores.

Índice ix
Machine Translated by Google

Capítulo 10 Formatando texto com estilos . . . . . . . . . . . . . . 241


Escolhendo uma família de fontes. . . . . . . . . . . . . . . . . . 243
Especificando fontes alternativas . . . . . . . . . . . . . . . . 244
Criando Itálico . . . . . . . . . . . . . . . . . . . . . . . 246
Aplicando formatação em negrito . . . . . . . . . . . . . . . . 248
Configurando o tamanho da fonte . . . . . . . . . . . . . . . . . . . 250
Definir a altura da linha . . . . . . . . . . . . . . . . . . 255
Configurando todos os valores de fonte de uma só vez. . . . . . . . . . . . . 256
Configurando a cor . . . . . . . . . . . . . . . . . . . . . 258
Alterando o plano de fundo do texto. . . . . . . . . . . . 260
Controlando o espaçamento . . . . . . . . . . . . . . . . . . . . 264
Adicionando recuos . . . . . . . . . . . . . . . . . . . . . . 265
Configurando Propriedades de Espaço em Branco . . . . . . . . . . . . . 266

Alinhando Texto. . . . . . . . . . . . . . . . . . . . . . . . 268


Alterando a caixa do texto . . . . . . . . . . . . . . . . . 270
Usando Versaletes . . . . . . . . . . . . . . . . . . . . . . 271
Decorando Texto. . . . . . . . . . . . . . . . . . . . . . 272

Capítulo 11 Layout com estilos . . . . . . . . . . . . . . . . . . . 275


Considerações ao iniciar um layout. . . . . . . 276
Estruturando suas páginas. . . . . . . . . . . . . . . . . . 279
Estilizando elementos HTML5 em navegadores mais antigos. . . . . . 286
Redefinindo ou normalizando estilos padrão . . . . . . . . 290
O modelo da caixa. . . . . . . . . . . . . . . . . . . . . . . 292
Alterando o plano de fundo . . . . . . . . . . . . . . . . 294
Configurando a altura ou largura de um elemento. . . . . . 298
Configurando as margens ao redor de um elemento. . . . . . . . 302
Adicionando preenchimento ao redor de um elemento. . . . . . . . . . . 304
Fazendo os Elementos Flutuarem . . ... . . . . . . . . . . . . . 306
Controlando onde os elementos flutuam. . . . . . . . . . . . 308
Definindo a fronteira. .. . . . . . . . . . . . . . . . . . . . 311
Elementos de compensação no fluxo natural. . . . . . . . . 314
Posicionando Elementos Absolutamente. . . . . . . . . . . . .316
Posicionando Elementos em 3D. . . . . . . . . . . . . . . . .318
Determinando como tratar o transbordamento. . . . . . . . . . . 320
Alinhando Elementos Verticalmente . . . . . . . . . . . . . . . 322
Alterando o Cursor . . . . . . . . . . . . . . . . . . . 323
Exibindo e ocultando elementos . . . . . . . . . . . . . 324

x Índice
Machine Translated by Google

Capítulo 12 Folhas de estilo de dispositivos móveis para desktop . . . . . . . . 327

Estratégias e considerações móveis. . . . . . . . . 328


Compreendendo e implementando consultas de mídia. . . 333
Construindo uma página que se adapta às consultas de mídia. . . 340

Capítulo 13 Trabalhando com fontes da Web . . . . . . . . . . . . . . . 353


O que é uma fonte da Web? . . . . . . . . . . . . . . . . . . . 354
Onde encontrar fontes da web. . . . . . . . . . . . . . . . . 356
Baixando sua primeira fonte da web. . . . . . . . . . . . 358
Trabalhando com @font-face . . . . . . . . . . . . . . . . 360
Estilizando fontes da Web e gerenciando o tamanho do arquivo. . . . . . . 365

Capítulo 14 Melhorias com CSS3 . . . . . . . . . . . . . . . 371


Noções básicas sobre prefixos de fornecedores . . . . . . . . . . . . . 373
Uma rápida olhada na compatibilidade do navegador. . . . . . . . . 375
Usando Polyfills para aprimoramento progressivo. . . . . 376
Arredondando os cantos dos elementos. . . . . . . . . . . 378
Adicionando sombras projetadas ao texto. . . . . . . . . . . . . . 382
Adicionando sombras projetadas a outros elementos . . . . . . . 384
Aplicando vários fundos. . . . . . . . . . . . . 388
Usando fundos gradientes. . . . . . . . . . . . . . 390
Configurando a opacidade dos elementos. . . . . . . . . . . . . 394

Capítulo 15 Listas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 397


Criando listas ordenadas e não ordenadas. . . . . . . . . 398
Escolhendo seus marcadores. . . . . . . . . . . . . . . . . . .401
Escolhendo por onde começar a numeração da lista. . . . . . . . 403
Usando marcadores personalizados . . . . . . . . . . . . . . . . . . 404
Controlando onde os marcadores ficam pendurados . . . . . . . . . . . . 406
Configurando todas as propriedades de estilo de lista de uma só vez. . . . . . . . 407
Estilizando listas aninhadas. . . . . . . . . . . . . . . . . . . . 408
Criando Listas de Descrição . . . . . . . . . . . . . . . . . 412

Capítulo 16 Formulários . . . . . . . . . . . . . . . . . . . . . . . . . . . . 417

Criando Formulários . . . . . . . . . . . . . . . . . . . . . . . 419


Processando Formulários . . . . . . . . . . . . . . . . . . . . . . 421
Envio de dados de formulário por e-mail. . . . . . . . . . . . . . . 424
Organizando os elementos do formulário. . . . . . . . . . . . . . 426
Criando caixas de texto. . . . . . . . . . . . . . . . . . . . 428

Índice xii
Machine Translated by Google

Criando caixas de senha . . . . . . . . . . . . . . . . . 431


Criação de caixas de e-mail, telefone e URL . . . . . . 432
Rotulagem de peças de formulário . . . . . . . . . . . . . . . . . . . . 434

Criando botões de rádio . . . . . . . . . . . . . . . . . . 436


Criando caixas de seleção . . . . . . . . . . . . . . . . . . 438
Criando caixas de seleção . . . . . . . . . . . . . . . . . . . 440
Criando áreas de texto . . . . . . . . . . . . . . . . . . . . . 441
Permitindo que visitantes façam upload de arquivos. . . . . . . . . . . . 442
Criando campos ocultos . . . . . . . . . . . . . . . . . . 443
Criando um botão Enviar. . . . . . . . . . . . . . . . . 444
Usando uma imagem para enviar um formulário. . . . . . . . . . . . 446
Desativando Elementos de Formulário . . . . . . . . . . . . . . . . . 0,447
Novos recursos HTML5 e suporte ao navegador. . . . . . 448

Capítulo 17 Vídeo, Áudio e Outros Multimídias . . . . . . . 449


Plug-ins de terceiros e tornar-se nativo. . . . . . . . . . . 451
. . . . . . . . . . . . . . . . . . . 452
Formatos de arquivo de vídeo.

Adicionando um único vídeo à sua página da web. . . . . . . 453


Explorando atributos de vídeo. . . . . . . . . . . . . . . . 454
Adicionando controles e reprodução automática ao seu vídeo. . . . . 455
Loop de um vídeo e especificação de uma imagem de pôster . . . 457
Impedindo o pré-carregamento de um vídeo . . . . . . . . . . 458
Usando vídeo com múltiplas fontes. . . . . . . . . . . 459
Várias fontes de mídia e o elemento de origem. . . 460
Adicionando vídeo com substitutos de hiperlink. . . . . . . . . . 461
Adicionando Vídeo com Flash Fallbacks . . . . . . . . . . . 463
Fornecendo acessibilidade. . . . . . . . . . . . . . . . . . 467
Adicionando formatos de arquivo de áudio . . . . . . . . . . . . . . . . 468
Adicionando um único arquivo de áudio à sua página da Web. . . . . 469
Adicionando um único arquivo de áudio com controles à sua
página da Web. . . . . . . . . . . . . . . . . . . . . . . . 470
Explorando atributos de áudio. . . . . . . . . . . . . . . . . 471
Adicionando controles e reprodução automática ao áudio em um loop. . . 472
Pré-carregando um arquivo de áudio . . . . . . . . . . . . . . . . . 0,473
Fornecendo múltiplas fontes de áudio. . . . . . . . . . . . 0,474
Adicionando áudio com substitutos de hiperlink. . . . . . . . . 0,475
Adicionando Áudio com Flash Fallbacks . . . . . . . . . . . 0,476
Adicionando áudio com Flash e um substituto de hiperlink. . 0,478
Obtendo arquivos multimídia. . . . . . . . . . . . . . . . . 480
Considerando o gerenciamento de direitos digitais (DRM) . . . . 0,481
Incorporação de animação Flash. . . . . . . . . . . . . . . 482

xii Índice
Machine Translated by Google

Incorporando vídeo do YouTube 484


Usando vídeo com Canvas 485
Acoplamento de vídeo com SVG 486
Recursos adicionais 487

Capítulo 18 Tabelas 489

Estruturando Tabelas 490


Abrangendo Colunas e Linhas 494

Capítulo 19 Trabalhando com Scripts 497

Carregando um script externo 499


Adicionando um script incorporado 502
Eventos JavaScript 503

Capítulo 20 Teste e depuração de páginas da Web 505

Tentando algumas técnicas de depuração 506


Verificando o que é fácil: Geral Verificando 508
o que é fácil: HTML Verificando o que 510
é fácil: CSS Validando seu código 512
Testando sua página 514
quando as imagens 516
ainda não aparecem travadas? 519
520

Capítulo 21 Publicando suas páginas na web 521

Obtendo seu próprio nome de domínio 522


Encontrando um host para seu site 523
Transferindo arquivos para o servidor 525

Índice 529

Os capítulos bônus mencionados neste e-book estão


disponíveis após o índice.

Apêndice A A1

Apêndice B B1

Índice xiii
Machine Translated by Google

Esta página foi intencionalmente deixada em branco


Machine Translated by Google

Introdução

Se você está apenas começando sua aventura na ou em qualquer lugar intermediário, a partir de
construção de sites ou já construiu alguns antes, qualquer dispositivo habilitado para Web. Em suma,
mas deseja garantir que seu conhecimento esteja a promessa da Web reside na sua universalidade.
atualizado, você chegou em um momento muito E o alcance da Web continua a expandir-se à medida
interessante no setor. que a tecnologia chega a comunidades que antes
estavam excluídas.
Como codificamos e estilizamos as páginas, os
navegadores nos quais visualizamos as páginas e Somando-se à grandeza da Web está o fato de
os dispositivos nos quais visualizamos os navegadores que qualquer pessoa é livre para criar e lançar um site.
todos avançaram substancialmente nos últimos Este livro mostra como. É ideal para iniciantes sem
anos. Antes limitados a navegar na Web a partir de conhecimento de HTML ou CSS que desejam começar
nossos computadores desktop ou laptops, agora a criar páginas da Web. Você encontrará instruções
podemos levar a Web conosco em qualquer número claras e fáceis de seguir que o guiarão passo a
de dispositivos: telefones, tablets e, sim, laptops e passo pelo processo de criação de páginas.
desktops, e muito mais.

E é como deveria ser, porque o Por último, o livro é um guia útil para manter à mão.
Você pode procurar tópicos no índice ou índice e
A promessa da Web sempre foi a dissolução
consultar apenas aqueles assuntos sobre os quais
das fronteiras – o poder de compartilhar e
precisa de mais informações.
acessar informações livremente de qualquer
metrópole, comunidade rural,

Introdução xv
Machine Translated by Google

HTML e CSS em resumo cena, você já conhece muito HTML5.


Isso também significa que grande parte do HTML5
Na raiz do sucesso da Web está uma funciona em navegadores antigos e novos; ser compatível
linguagem de marcação simples, baseada em texto, com versões anteriores é um princípio fundamental
fácil de aprender e que qualquer dispositivo com um de design do HTML5 (consulte www.w3.org/TR/
navegador da Web básico pode ler: HTML. Cada página princípios de design html/).
da Web requer pelo menos algum HTML; não seria uma
HTML5 também adiciona uma série de novos recursos.
página da Web sem ele. Muitos são simples, como elementos
Como você aprenderá com mais detalhes à medida adicionais (artigo, seção, figura e muitos
que avança neste livro, o HTML é usado para definir o mais) que são usados para descrever o
significado do seu conteúdo, e o CSS é usado para definir conteúdo. Outros são bastante
a aparência do seu conteúdo e da página da Web. Tanto complexos e auxiliam na criação de aplicativos Web poderoso
as páginas HTML quanto os arquivos CSS (folhas de Você precisará ter um bom domínio da criação de
estilo) são arquivos de texto, o que os torna fáceis de páginas da Web antes de passar para os recursos mais
editar. Você pode ver trechos de HTML e CSS em “Como complicados que o HTML5 oferece. HTML5 também
este livro funciona”, próximo ao final desta introdução. introduz reprodução nativa de áudio e vídeo em suas
páginas da Web, que o livro também aborda.

Você mergulhará no aprendizado de uma página HTML


básica logo de cara no Capítulo 1, e começará a
O que é CSS3?
aprender como estilizar suas páginas com CSS no Capítulo
7. Consulte “O que este livro lhe ensinará” para uma A primeira versão do CSS só existiu depois que o
visão geral de tudo. os capítulos e um resumo dos temas HTML já existia há alguns anos, tornando-se oficial
abordados. em 1996. Assim como o HTML5 e sua relação
com versões anteriores do HTML, o CSS3 é uma
O que é HTML5? extensão natural das versões do CSS que o precederam.
isto.
Ajuda saber alguns princípios básicos sobre as
origens do HTML para entender o HTML5. HTML CSS3 é mais poderoso do que versões anteriores
começou no início da década de 1990 como um pequeno de CSS e introduz vários efeitos visuais, como
documento que detalhava um punhado de sombras projetadas, sombras de texto, cantos
elementos usados para construir páginas da Web. arredondados e gradientes.
Muitos desses elementos serviam para descrever o (Consulte “O que este livro irá lhe ensinar” para obter
conteúdo de páginas da Web, como títulos, detalhes sobre o que é abordado.)
parágrafos e listas. O número da versão do HTML
aumentou à medida que a linguagem evoluiu com a Padrões e especificações da Web
introdução de outros elementos e
Você deve estar se perguntando quem criou HTML
ajustes em suas regras. A versão mais atual é HTML5.
e CSS em primeiro lugar e quem continua a desenvolvê-
los. O mundo inteiro
HTML5 é uma evolução natural do anterior O Web Consortium (W3C) – dirigido pelo inventor da
versões de HTML e se esforça para refletir Web e do HTML, Tim Bern-ers-Lee – é a organização
as necessidades da Web atual e futura responsável por orientar o desenvolvimento de padrões da
sites. Ele herda a grande maioria dos recursos de seus Web. Especificações (ou especificações, abreviadamente)
antecessores, o que significa que se você codificou o são documentos que definem os parâmetros
HTML antes do HTML5 chegar ao mercado

xvi Introdução
Machine Translated by Google

de linguagens como HTML e CSS. Em outras palavras,


as especificações padronizam as regras. Acompanhe a
atividade do W3C em www.w3.org A.

Por vários motivos, outra organização – o Web


Hypertext Application Technology Working Group
(WHATWG, encontrado em www.whatwg.org) – está
desenvolvendo a especificação HTML5. O W3C incorpora
o trabalho do WHATWG em sua versão oficial das
especificações em andamento.

Com os padrões em vigor, podemos construir nossas


páginas a partir do conjunto de regras acordado, e
R O site W3C é a principal fonte de especificações
de padrões da Web do setor. navegadores – como Chrome, Firefox, Internet Explorer
(IE), Opera e Safari – podem ser criados para exibir nossas
páginas com essas regras. em mente. (No geral, os
navegadores implementam bem os padrões. Versões
mais antigas do

O IE, especialmente o IE6, tem alguns problemas.

As especificações passam por vários estágios de


desenvolvimento antes de serem consideradas finais,
momento em que são apelidadas de
Recomendação (www.w3.org/2005/10/
Processo-20051014/tr).
Partes das especificações HTML5 e CSS3 ainda estão
sendo finalizadas, mas isso não significa que você não
possa usá-las. Leva apenas tempo (literalmente anos)
para que o processo de padronização siga seu curso.
Os navegadores começam a implementar os recursos de
uma especificação muito antes de ela se tornar uma
recomendação, porque isso informa o próprio processo
de desenvolvimento da especificação. Portanto, os
navegadores já incluem uma grande variedade de
recursos em HTML5 e CSS3, embora ainda não sejam
recomendações.

No geral, os recursos abordados neste livro estão bem


arraigados em suas respectivas especificações, portanto
o risco de serem alterados antes de se tornarem uma
recomendação é mínimo. Os desenvolvedores já
usam muitos recursos HTML5 e CSS3 há algum
tempo. Então você pode.

Introdução xvii
Machine Translated by Google

Progressivo
Aprimoramento:
Uma melhor prática
Comecei a introdução falando da universalidade da
Web – a noção de que a informação na Web
deve ser acessível.
apto para todos. O aprimoramento progressivo
ajuda você a criar sites com a universalidade em
mente. Não é uma linguagem, mas sim uma
abordagem para a construção de sites que Steve A Uma página HTML básica sem CSS
personalizado aplicado a ela. Esta página pode não
Champeon criou em 2003 (http://en.wikipedia.org/wiki/ parecer ótima, mas as informações são acessíveis –
Aprimoramento_progressivo). e é isso que importa. Mesmo navegadores próximos ao
início da Web, há mais de 20 anos, podem exibir esta
A ideia é simples, mas poderosa: comece seu site página; o mesmo acontece com os telefones celulares
com conteúdo e comportamento HTML que mais antigos com navegadores da Web. E os leitores de
tela, softwares que leem páginas da Web em voz alta
é acessível a todos os visitantes A. Para o mesmo
para visitantes com deficiência visual, poderão navegar facilmente.
página, adicione seu design com CSS B e
adicione comportamento adicional com
JavaScript, normalmente carregando-os de
arquivos externos (você aprenderá como fazer isso).
O resultado é que dispositivos e navegadores

capaz de acessar páginas básicas terá a


experiência padrão simplificada; dispositivos e
navegadores capazes de visualizar sites mais
robustos verão a versão aprimorada.
A experiência no seu site não precisa ser a mesma
para todos, desde que o seu conteúdo seja
acessível. Em essência, a ideia por trás do
aprimoramento progressivo é que todos ganham.

xviii Introdução
Machine Translated by Google

Este livro ensina como construir sites


progressivamente aprimorados, mesmo que nem sempre
indique isso explicitamente ao fazê-lo. É um resultado
natural das melhores práticas transmitidas ao longo do
livro.

Contudo, os Capítulos 12 e 14 abordam de frente o


aprimoramento progressivo. Dê uma olhada neles se
estiver interessado em ver como o princípio do
aprimoramento progressivo ajuda a construir um
B A mesma página visualizada em um navegador
que suporta CSS. São as mesmas informações, site que adapta seu layout com base no tamanho da
apenas apresentadas de forma diferente. Os tela do dispositivo e nos recursos do navegador, ou
usuários com dispositivos e navegadores mais capazes
como navegadores mais antigos exibirão designs
obtêm uma experiência aprimorada ao visitar a página.
simplificados enquanto modernos. os navegadores
exibirão aqueles aprimorados com efeitos CSS3.

O aprimoramento progressivo é uma prática


recomendada fundamental que está no centro dos
canteiros de obras para todos.

Introdução xix
Machine Translated by Google

O Capítulo 19 mostra como adicionar JavaScript


Esse livro é para você? pré-escrito às suas páginas.

Este livro não pressupõe nenhum conhecimento n O Capítulo 20 explica como testar e
prévio de construção de sites. Então, nesse depure suas páginas antes de colocá-las na
sentido, é para o iniciante absoluto. Você Web.
aprenderá HTML e CSS desde o início. Ao fazer
n O Capítulo 21 explica como proteger seu próprio
isso, você também aprenderá sobre os recursos
nome de domínio e depois publicar seu site
novos em HTML5 e CSS3, com ênfase naqueles
na Web para que todos possam ver.
que designers e desenvolvedores estão usando
hoje em seu trabalho diário. Expandindo isso, alguns dos tópicos incluem:

Mas mesmo se você estiver familiarizado com n Criar, salvar e editar HTML e
Arquivos CSS.
HTML e CSS, ainda terá que aprender com este
livro, especialmente se quiser se atualizar sobre n O que significa escrever HTML semântico
muitas das novidades em HTML5, CSS3 e práticas e por que é importante.
recomendadas.
n Como separar o conteúdo da sua página (ou
seja, seu HTML) de sua apresentação (ou
O que este livro vai te ensinar seja, seu CSS) – um aspecto fundamental do
Adicionamos aproximadamente 125 páginas aprimoramento progressivo.
a este livro desde a edição anterior para trazer n Estruture seu conteúdo de maneira significativa
a você o máximo de material possível. (A usando elementos HTML que já existem há anos
primeira edição do livro, publicada em 1996, tinha e que são novos no HTML5.
um total de 176 páginas.)
Também fizemos atualizações substanciais (ou
n Melhorar a acessibilidade do seu site com
reescritas completas) em quase todas as
funções de referência ARIA e outras boas
páginas anteriores. Em suma, esta Sétima
práticas de codificação.
Edição representa uma revisão importante.
n Adicionar imagens às suas páginas e otimizá-las
Os capítulos estão organizados assim:
para a Web.
n Os capítulos 1 a 6 e 15 a 18 cobrem os princípios
n Vincular de uma página da Web para outra página
de criação de páginas HTML e a variedade de
ou de uma parte de uma página para outra
elementos HTML à sua disposição, demonstrando
parte.
claramente quando e como usar cada um deles.
n Estilizar o texto (tamanho, cor, negrito, itálico,
e mais); adicionar cores e imagens de fundo;
n Os capítulos 7 a 14 se aprofundam no CSS,
e implementar um layout fluido com várias
desde a criação de sua primeira regra de
colunas que pode encolher e expandir
estilo até a aplicação de efeitos visuais
aprimorados com CSS3. para acomodar diferentes tamanhos de tela.

xx Introdução
Machine Translated by Google

n Aproveitando novos seletores em CSS3 O que este livro não vaite ensinam
que permitem que você direcione seus estilos
Infelizmente, mesmo depois de adicionar tantas
de uma forma mais ampla do que era
páginas desde a edição anterior, há muito o que falar
possível anteriormente.
quando se trata de HTML e
n Aprender suas opções para abordar visitantes em
CSS que tivemos que deixar de fora alguns tópicos.
dispositivos móveis.
Com algumas exceções, limitamo-nos a omitir
n Construindo um único site para todos os usuários—
itens que você teria menos ocasiões de usar,
estejam eles usando um telefone celular, tablet, que ainda estão sujeitos a alterações, que não
laptop, computador desktop ou outro
possuem amplo suporte ao navegador, que
dispositivo habilitado para Web - com base em
exigem conhecimento de JavaScript ou que são
muitos dos princípios do web design assuntos avançados.
responsivo, alguns dos quais aproveitam as
Alguns dos tópicos não abordados incluem:
consultas de mídia CSS3.

n Adicionando fontes da Web personalizadas às


n Os detalhes HTML5 , resumo, menu,
suas páginas com @font-face.
comando e elementos keygen .
n O elemento canvas HTML5 , que
n Usando efeitos CSS3, como opacidade,
permite desenhar gráficos (e até criar jogos)
transparência alfa de fundo, gradientes, cantos
com JavaScript.
arredondados, sombras projetadas, sombras
dentro de elementos, sombras de texto e n As APIs HTML5 e outros recursos avançados

múltiplas imagens de fundo. recursos que exigem conhecimento de


JavaScript ou que não estão diretamente
n Construir formulários para solicitar informações de seus
relacionados ao novo HTML5 semântico
visitantes, incluindo o uso de alguns dos novos
elementos.
tipos de entrada de formulário em HTML5.
sprites CSS . Essa técnica envolve combinar mais de
n Incluir mídia em suas páginas com elementos de
áudio e vídeo HTML5 . uma imagem em uma única imagem, o que é
muito útil para minimizar o número de ativos
E mais.
que suas páginas precisam carregar. Consulte
Esses tópicos são complementados por dezenas www.bruceontheloose.com/sprites/ para obter mais
de exemplos de código que mostram como informações.
implementar os recursos com base nas práticas
recomendadas do setor. n Substituição de imagem CSS. Essas técnicas
costumam ser combinadas com sprites
CSS. Consulte www.bruceontheloose.com/
ir/ para obter mais informações.

n Transformações CSS3, animações e


transições.

n Novos módulos de layout do CSS3.

Introdução xxi
Machine Translated by Google

Como este livro funciona porque não há como saber quais navegadores seus
visitantes usarão.
Quase todas as seções do livro contêm exemplos O código e as capturas de tela são acompanhados
práticos de código que demonstram o uso no mundo por descrições dos elementos HTML ou propriedades
real (A e B). Normalmente, eles são acompanhados CSS em questão, tanto para dar contexto aos
de capturas de tela que mostram os resultados do exemplos quanto para aumentar sua compreensão
código quando você visualiza a página da Web em deles.
um navegador C.
Em muitos casos, você pode descobrir que as
A maioria das capturas de tela são da versão
descrições e exemplos de código são suficientes para
mais recente do Firefox disponível na época. No
começar a usar os recursos HTML e CSS. Mas se
entanto, isso não implica uma recomendação do você precisar de orientação explícita sobre como usá-
Firefox em detrimento de qualquer outro los, instruções passo a passo serão sempre
navegador. Os exemplos de código serão muito fornecidas.
semelhantes em qualquer uma das versões mais
Finalmente, a maioria das seções contém dicas
recentes do Chrome, Internet Explorer, Opera ou
que transmitem informações adicionais de uso,
Safari. Como você aprenderá no Capítulo 20, você
práticas recomendadas, referências a partes
deve testar suas páginas em uma ampla variedade
relacionadas do livro, links para recursos relevantes e muito mais.
de navegadores antes de colocá-las na Web,

R Você encontrará um trecho de código HTML em muitas páginas, com as seções pertinentes destacadas. Uma reticência (...)
representa código ou conteúdo adicional que foi omitido por questões de brevidade. Freqüentemente, a parte omitida é mostrada
em uma figura de código diferente.

...
<corpo>
<header role="banner">
...
<nav role="navegação">
<ul class="nav">
<li><a href="/" class="current">página inicial</a></li>
<li><a href="/about/">sobre</a></li>
<li><a href="/resources/">recursos</a></li>
<li><a href="/archives/">arquivos</a></li>
</ul>
</nenhum>

...
</header>

...

</body>
</html>

XXII Introdução
Machine Translated by Google

B Se o código CSS for relevante para o exemplo, ele Convenções utilizadas neste livro
será mostrado em uma caixa própria, com as seções
pertinentes destacadas. O livro usa as seguintes convenções:

n A palavra HTML é abrangente, representando a


/* Navegação no site */
linguagem em geral.
.nome em {
flutuar: esquerda; HTML5 é usado quando se refere a essa versão
tamanho da fonte: .75em; /* torna específica do HTML, como ao discutir um recurso
os marcadores ÿ menores */ que é novo no HTML5 e não existe nas
}
versões anteriores do HTML. A mesma
abordagem se aplica ao uso dos termos CSS (geral)
.nav li a {
tamanho da fonte: 1,5em; e CSS3 (específico para CSS3).
}

n O texto ou código que é um espaço reservado para


.nav li:primeiro filho {
estilo de lista: nenhum; um valor que você mesmo criaria está em itálico.
preenchimento à esquerda: 0; A maioria dos espaços reservados aparece nas
} instruções passo a passo. Por exemplo, “Ou digite
#rrggbb, onde rrggbb é a representação
hexadecimal da cor”.

n O código que você realmente deve digitar ou que


representa código HTML ou CSS aparece
nesta fonte.
C Capturas de tela de um ou mais navegadores
demonstram como o código afeta a página. n Uma seta ( ÿ ) em uma figura de código indica uma
continuação da linha anterior — a linha foi quebrada
para caber na coluna B do livro. A seta não
faz parte do código em si, portanto não é algo que
você digitaria. Em vez disso, digite a linha
continuamente, como se ela não tivesse passado
para outra linha.

n A primeira ocorrência de uma palavra é itálico


definido quando é definido.

n IE é frequentemente usado como uma abreviatura


popular de Internet Explorer. Por exemplo, IE9 é
sinônimo de Internet Explorer 9.

n Sempre que um sinal de mais (+) segue um


número da versão do navegador, significa a
versão listada mais as versões subsequentes.
Por exemplo, Firefox 8+ refere-se ao Firefox
8.0 e todas as versões posteriores.

Introdução xxiii
Machine Translated by Google

Site complementar Treinamento em vídeo

Os guias visuais de início rápido agora estão uniformes


O site do livro, em www.bruceontheloose .com/htmlcss/,
mais visual: Com base no sucesso dos livros Visual
contém o índice, todos os exemplos de código
QuickStart Guide mais vendidos, o Peachpit agora
completos apresentados no livro (além de alguns
oferece Video QuickStarts. Como complemento deste
adicionais que não caberiam), links para recursos citados
livro, Peachpit oferece mais de uma hora de vídeos
no livro (também como adicionais), informações sobre
curtos baseados em tarefas que ajudarão você a
referências usadas durante a escrita, uma lista de
dominar os principais recursos e técnicas do HTML5;
erratas e muito mais.
em vez de apenas ler sobre como usar HTML5, você pode
observá-lo em ação. É uma ótima maneira de aprender
O site também inclui seções de referência (Apêndices todos os conceitos básicos e alguns dos mais novos ou
A e B) que não tivemos espaço para incluir no livro.
Estes são recursos mais complexos do HTML5. Faça logon no site
útil para procurar rapidamente elementos e atributos do Peachpit em www.peachpit.com/
HTML ou propriedades e valores CSS. (Eles também registre-se para registrar seu livro e você encontrará
contêm algumas informações não abordadas no livro.) uma amostra gratuita de streaming; adquirir o restante
do material é rápido e fácil.

Você pode encontrar os exemplos de código em


www .bruceontheloose.com/htmlcss/examples/.
Você pode navegar por eles a partir daí ou abaixo

carregue-os em seu computador - todos os arquivos


HTML e CSS estão à sua disposição.

Em alguns casos, incluí comentários adicionais no


código para explicar mais sobre o que ele faz ou
como usá-lo. A
Alguns exemplos de código do livro estão truncados
por questões de espaço, mas as versões completas estão
no site do livro. Sinta-se à vontade para usar o código
como desejar, modificando-o conforme necessário para

seus próprios projetos.

Os URLs de algumas das principais páginas do site do


livro são os seguintes:

Página inicial : www.bruceontheloose.com/htmlcss/

n Exemplos de código: www.bruceontheloose .com/


htmlcss/examples/

n Apêndice A: Referência HTML:


www.bruceontheloose.com/ref/html/
n Apêndice B: Propriedades e valores CSS:
www.bruceontheloose.com/ref/css/

Espero que você ache o site útil.

xxiv Introdução
Machine Translated by Google

1
Construção de página da web
Blocos

Embora as páginas Web se tenham tornado cada vez mais


complexas, a sua estrutura subjacente permanece Neste capítulo
notavelmente simples. A primeira coisa que você
Uma página HTML básica 3
deve saber é que é impossível criar uma página Web sem
HTML. Como você aprenderá, o HTML hospeda seu HTML semântico: marcação com significado 6

conteúdo e descreve seu significado. Por sua vez, os


Marcação: Elementos, Atributos e Valores 13
navegadores da Web renderizam o conteúdo em HTML
Conteúdo de texto de uma página da web 16
para os usuários.
Links, imagens e outros itens não textuais
Uma página da Web é composta principalmente de três
Contente 17
componentes:

n Conteúdo de texto: O texto simples que Nomes de arquivos 19

aparece na página para informar os visitantes sobre URLs 20


sua empresa, férias em família, produtos ou
Principais conclusões 24
qualquer que seja o foco de sua página.

n Referências a outros arquivos: Estes carregam

itens como imagens, áudio, vídeo e arquivos


SVG, além de links para outras páginas e
recursos HTML, bem como para folhas de estilo
(que controlam o layout da sua página) e arquivos
JavaScript (que adicionam comportamento à sua
página).

n Marcação: Os elementos HTML que


descreva o conteúdo do seu texto e faça as
referências funcionarem. (O m em HTML significa
marcação.)
Machine Translated by Google

É importante observar que cada um desses sobre o idioma principal do conteúdo (inglês,
componentes de uma página Web é composto francês e assim por diante), codificação de
exclusivamente de texto. Isso significa que as páginas caracteres (normalmente UTF-8) e muito mais.
são salvas em formato somente texto e podem ser
Este capítulo guiará você por uma página HTML
visualizadas em praticamente qualquer navegador e
básica, discutirá algumas práticas recomendadas e
em qualquer plataforma, seja desktop, celular, tablet
explicará cada um dos três componentes
ou outro. Garante a universalidade da Web. Uma
importantes.
página pode parecer diferente quando visualizada
em um dispositivo versus Nota: Conforme mencionado na introdução, utilizo
HTML para me referir à linguagem em geral. Nos
outro, mas tudo bem. O importante como primeiro
casos em que estou destacando características
passo é tornar o conteúdo acessível a todos os
usuários, e o HTML permite isso. especiais exclusivas de uma versão do idioma, usarei
o nome individual. Por exemplo, “HTML5
Além dos três componentes dos quais uma página da
Web é composta principalmente, uma página também introduz vários elementos novos e
inclui HTML que fornece informações sobre a própria
redefine ou elimina outros que existiam
página, a maioria das quais seus usuários não
anteriormente no HTML 4 e XHTML 1.0.”
veem explicitamente e que se destina principalmente
Para mais detalhes, consulte “Como este livro funciona”
a navegadores e pesquisas. motores. Isto pode incluir na introdução.
informações

2 Capítulo 1
Machine Translated by Google

Uma página HTML básica


Vamos dar uma olhada em uma página HTML básica
para contextualizar o que vem a seguir neste capítulo e
além. A Figura A ilustra como um navegador de
desktop normalmente renderiza o código HTML em
B. Você aprenderá algumas noções básicas sobre o
código B, mas não se preocupe se não entender
tudo agora. Isso é apenas para lhe dar uma ideia
do HTML. Você tem o resto do livro para

aprenda mais sobre isso.

Você provavelmente pode adivinhar um pouco do


A Uma renderização padrão típica da página.
que está acontecendo no código, especialmente
Embora isso mostre a página no Firefox, a página é exibida
de forma semelhante em outros navegadores. na seção body . Primeiro vamos dar uma olhada
na parte anterior ao corpo.

B Aqui está o código para uma página HTML básica. Destaquei as partes HTML para que você possa distingui-las do conteúdo
de texto da página. Conforme demonstrado em A, o HTML que envolve o conteúdo do texto não aparece quando você visualiza a
página em um navegador. Mas, como você aprenderá, a marcação é essencial porque descreve o significado do conteúdo.
Observe também que cada linha é separada por um retorno de carro.
Isso não é obrigatório e não afeta a renderização da página.

<!DOCTYPEhtml>
<html lang="pt">
<cabeça>
<meta charset="utf-8" />
<title> Linho Azul (Linum lewisii)</title>
</head>
<corpo>
<artigo>
<h1>O Efêmero Linho Azul</h1>

<img src="blueflax.jpg" width="300" height="175" alt="Linho Azul (Linum lewisii)" />

<p>Fico continuamente <em>surpreso</em> com a beleza e a delicadeza <a href="http://


ÿ en.wikipedia.org/wiki/Linum_lewisii" rel="external" title="Saiba mais sobre o ÿ Linho
Azul"> Linho Azul</a> que de alguma forma tomou conta do meu jardim. Eles ficam cheios
de cores todas as ÿ manhãs, no entanto, nem uma única flor permanece à tarde. Elas são a
própria definição ÿ de efêmero.</p>
</artigo>
</body>
</html>

Blocos de construção de páginas da Web 3


Machine Translated by Google

Tudo acima da tag inicial <body> são as C O texto do elemento título é a única parte da
informações de instrução para navegadores área superior de um documento HTML que o usuário
vê. O resto são informações sobre a página para
e motores de busca mencionados anteriormente C.
navegadores e mecanismos de busca.
Cada página começa com a declaração DOCTYPE,
que informa ao navegador a versão HTML da página. <!DOCTYPEhtml>
<html lang="pt">
<cabeça>
Você deve sempre usar o DOCTYPE do HTML5, que <meta charset="utf-8" />
é <!DOCTYPE html>. A caixa do texto não <title>O Efêmero Linho Azul ÿ
importa, mas é mais comum usar DOCTYPE em (Linum lewisii)</title>
</head>
letras maiúsculas.
Independentemente disso, inclua sempre o
DOCTYPE em suas páginas. (Veja a barra lateral
“DOCTYPE aprimorado do HTML5” no Capítulo 3 para
obter mais informações.)
Os bits que começam em <!DOCTYPE html> e
continuam até </head> são invisíveis para os
usuários com uma exceção: o texto entre <title> e </
title>—Blue Flax (Linum lewisii)—aparece como o
título no final. bem no topo da janela do navegador e
em um navegador
guia B. Além disso, normalmente é o padrão
nome de um marcador ou favorito do navegador
e é uma informação valiosa para pesquisa

motores. O Capítulo 3 explica o que fazem as outras


partes do segmento superior de uma página.

4 Capítulo 1
Machine Translated by Google

D O conteúdo de uma página existe entre as tags inicial e final do Enquanto isso, o conteúdo da sua página – ou
elemento body . O documento termina em </html>. seja, o que é visível para os usuários – fica
entre <body> e </body>. Finalmente, o </html>
<!DOCTYPEhtml> A tag end sinaliza o final da página D.
<html lang="pt"> O recuo do código não tem absolutamente
. . . [cabeçalho do documento] . . .
nenhuma influência sobre se o código é HTML
<corpo>
válido. Também não afeta a forma como o con-
<artigo>
<h1>O Efêmero Linho Azul</h1> tenda é exibida no navegador (o elemento
pre , sobre o qual você aprenderá no Capítulo 4,
<img src="blueflax.jpg" width="300" é a única exceção). No entanto, é costume recuar
ÿ height="175" alt="Linho Azul (Linum o código aninhado em um elemento pai para
ÿ lewisii)" />
facilitar a compreensão da hierarquia dos
<p>Fico continuamente elementos à medida que você lê o código. Você
<em>maravilha</em> ÿ com a aprenderá mais sobre pais e filhos posteriormente
beleza e a delicadeza ÿ <a href="http:// neste capítulo. Você também aprenderá mais
en.wikipedia.org/ ÿ wiki/Linum_lewisii" detalhadamente sobre a renderização padrão
rel="external" ÿ title=" Saiba mais sobre
o Linho Azul"> ÿ Linho Azul</a> que do navegador.
de alguma forma tomou conta do meu Primeiro, vamos discutir o que significa
jardim. Elas ficam inundadas de ÿ escrever HTML semântico e por que ele é a base
cores todas as manhãs, mas nem de um site eficaz.
uma ÿ única flor permanece à ÿ
tarde. Eles são a própria ÿ definição de efêmero.</p>
</artigo>
</body>
</html>

Blocos de construção de páginas da Web 5


Machine Translated by Google

HTML semântico: A O conteúdo da nossa página básica mais um segundo


parágrafo adicionado no final. Os elementos HTML não
determinam como o conteúdo deve aparecer, apenas o
Marcação com significado que significam. Em vez disso, a folha de estilo integrada
de cada navegador determina como o conteúdo é
HTML é um sistema inteligente de inclusão de exibido por padrãoB.
informações sobre o conteúdo de um texto
...
documento. Essa informação, chamada de marcação,
<corpo>
descreve o significado do conteúdo, ou seja, a <artigo>
semântica. Você já viu alguns exemplos em nossa <h1>O Efêmero Linho Azul</h1>
página HTML básica, como o elemento p que
marca o conteúdo do parágrafo. <img src="blueflax.jpg" width="300" ÿ
height="175" alt="Linho Azul (Linum ÿ
lewisii)" />
HTML não define como o conteúdo
deverá aparecer em um navegador; esse é o papel <p>Fico continuamente <em>maravilha</
em> ÿ com a beleza e a delicadeza
do CSS (Cascading Style Sheets). O HTML5
ÿ <a href="http://en.wikipedia.org/ ÿ wiki/
enfatiza essa distinção mais do que qualquer
Linum_lewisii" rel="external" ÿ title=" Saiba
versão anterior do HTML. Está no cerne da linguagem. mais sobre o Linho Azul"> ÿ Linho Azul</a>
que de alguma forma tomou conta do
meu jardim. Elas ficam inundadas de ÿ cores
Você deve estar se perguntando por que, se for
todas as manhãs, mas nem uma ÿ única flor
esse o caso, algum texto na página HTML básicaA permanece à ÿ tarde. Eles são a
parece maior que outro texto ou está em negrito ou própria ÿ definição de efêmero.</p>
itálico B.

Ótima pergunta. A razão é que todo navegador da <p><small>&copy; Sociedade do Linho


Web possui um arquivo CSS integrado (uma folha de Azul. ÿ </small></p>
</artigo>
estilo) que determina como cada elemento HTML
</body>
é exibido por padrão, a menos que você crie o seu
</html>
próprio para sobrescrevê-lo. A apresentação
padrão varia um pouco de navegador para navegador,
mas no geral é bastante consistente. Mais importante
ainda, a estrutura subjacente e o significado do
conteúdo, conforme definido pelo seu HTML,
permanecem os mesmos.

6 Capítulo 1
Machine Translated by Google

Nível de bloco, inline e HTML5


Como você pode ver, alguns elementos HTML (por
exemplo, o artigo, h1 e p) são exibidos em sua
própria linha, como um parágrafo em um livro,
enquanto outros (por exemplo, o a
e em) são renderizados na mesma linha que
outro conteúdo B. Novamente, isso é uma função
das regras de estilo padrão do navegador, não dos
próprios elementos HTML. Permita-me elaborar
avaliar. Antes do HTML5, a maioria dos elementos
eram categorizados como nível de bloco (aqueles
exibidos em sua própria linha) ou inline .
(aqueles exibidos dentro de uma linha de texto).
O HTML5 elimina esses termos porque eles
B A folha de estilo padrão de um navegador renderiza títulos
(elementos h1–h6 ) de maneira diferente do texto normal, coloca o texto associam elementos à apresentação, o que
em itálico e colore e sublinha os links. Além disso, alguns elementos você aprendeu não é a função do HTML.
começam em suas próprias linhas (h1 e p, por exemplo) e outros são
exibidos no conteúdo circundante (como a e em). Este exemplo
inclui um segundo parágrafo (o aviso de direitos autorais) para Em vez disso, de modo geral, os elementos que
deixar claro que cada parágrafo ocupa sua própria linha. É simples
foram anteriormente apelidados de in-line são
substituir qualquer uma ou todas essas regras de apresentação por
suas próprias folhas de estilo. categorizados em HTML5 como conteúdo de fraseado.
isto é, elementos e o texto contido neles que
aparecem principalmente em um parágrafo.
(O Capítulo 4 concentra-se quase
exclusivamente na formulação de conteúdo.
Veja a lista completa em http://dev.w3.org/html5/
spec-author-view/content-models.html#phrasing-content-0 .)
Os antigos elementos de nível de bloco também caem agora

em novas categorias HTML5 que focam em sua


semântica. Muitos destes elementos constituem
os principais blocos estruturais e
títulos de seu conteúdo (aprofunde-se no Capítulo
3 para saber mais sobre como seccionar conteúdo
e encaminhar elementos de conteúdo).

Com tudo isso dito, os navegadores não


mudaram as regras de exibição padrão para esses
elementos, nem deveriam. Afinal, você não
gostaria, digamos, que os dois parágrafos (os
elementos p ) se chocassem, ou que o texto em
(“espantado”) quebrasse a frase aparecendo em
sua própria linha (em é o elemento você usa para
adicionar ênfase).

Blocos de construção de páginas da Web 7


Machine Translated by Google

Geralmente, títulos, parágrafos e elementos desenvolvimento. Central para esse pensamento


estruturais, como artigos , são exibidos em sua era – e ainda é – a noção de que HTML serve apenas
própria linha e o conteúdo de frases é exibido na para descrever o significado do conteúdo, não sua
mesma linha do conteúdo circundante. E mesmo exibição.
que o HTML5 não use mais os termos nível de
Os elementos HTML de apresentação quebraram essa
bloco e inline, ajuda saber o que eles significam.
prática recomendada. Como tal, o HTML 4 rejeitou
seu uso, recomendando que os autores usassem CSS
É comum que os tutoriais os utilizem desde
para estilizar texto e outros elementos da página.
eles estavam enraizados no vernáculo HTML antes do
HTML5. Eu poderia usá-los ocasionalmente no livro
HTML5 vai além; elimina alguns elementos de
para transmitir rapidamente se um elemento ocupa sua
apresentação e redefine outros para que tenham
própria linha ou compartilha uma linha por padrão.
apenas valor semântico em vez de ditar a
apresentação.
Abordaremos CSS em detalhes em capítulos
O pequeno elemento é um exemplo.
posteriores, mas por enquanto saiba que uma folha
Inicialmente, pretendia-se tornar o texto menor
de estilo, como uma página HTML, é apenas
texto, então você pode criar uma com o mesmo editor de texto queque o texto normal. No entanto, em HTML5,
pequeno representa letras miúdas, como uma
seu HTML.
isenção de responsabilidade legal. Você pode usar
CSS para torná-lo o maior texto da página, se desejar,
Foco do HTML5 na Semântica
mas isso não mudará o significado do seu pequeno
O HTML5 enfatiza a semântica do HTML, deixando todo conteúdo.
o estilo visual para o CSS. Esse nem sempre foi o
Enquanto isso, a antiga contraparte do pequeno , o
caso das versões anteriores do HTML.
grande elemento, não existe no HTML5. Existem outros
exemplos também, que você aprenderá à medida que
Não existia um meio adequado para estilizar páginas avança no livro.
nos primeiros anos da Web; O HTML já tinha
HTML5 também define novos elementos,
alguns anos quando o CSS1 foi formalmente
como cabeçalho, rodapé, navegação, artigo,
introduzido em dezembro de 1996. Para preencher
seção e muitos mais que enriquecem a
essa lacuna, entretanto, o HTML incluiu um punhado
semântica do seu conteúdo. Você aprenderá
de elementos de apresentação cujo objetivo era permitir
sobre isso mais tarde também.
o estilo básico do texto, como torná-lo em negrito,
em itálico ou em um tamanho diferente do texto ao redor. No entanto, quer você use um elemento HTML que
existe desde o início do
linguagem ou algo novo em HTML5, seu objetivo
deve ser o mesmo: escolher os elementos que melhor
Esses elementos serviram ao seu propósito na
descrevem o significado do seu conteúdo,
época, mas caíram em desuso à medida que as
independentemente de sua apresentação.
melhores práticas evoluíram para a Web.

8 Capítulo 1
Machine Translated by Google

C O corpo da nossa página básica, que contém o


A Semântica do Nosso
artigo, h1, img, p, em e elementos a para descrever Página HTML básica
o significado do conteúdo. Todo o conteúdo está
aninhado no artigo. Agora que você conhece a função do HTML, vamos
examinar um pouco mais profundamente o processo de
<corpo>
<artigo> pensamento por trás da marcação do conteúdo de

<h1>O Efêmero Linho Azul</h1> amostra. Como você verá, não há mágica em escrever HTML semântico.
É principalmente bom senso quando você estiver
<img src="blueflax.jpg" width="300" ÿ familiarizado com os elementos à sua disposição.
height="175" alt="Linho Azul (Linum ÿ lewisii)" />
Vamos revisitar o corpo da nossa página básica
para conhecer alguns dos elementos HTML C mais

<p>Fico continuamente <em>maravilha</em> usados.


ÿ com a beleza e a delicadeza ÿ <a Todo o conteúdo está contido em um artigo
href="http://en.wikipedia.org/ ÿ wiki/
elemento C. Resumindo, o artigo define um conteúdo
Linum_lewisii" rel="external" ÿ title=" Saiba mais
sobre o Linho Azul"> ÿ Linho Azul</a> que de distinto. O elemento article é a escolha apropriada para
alguma forma tomou conta do meu jardim. cercar o conteúdo da nossa página básica, mas não
Elas ficam inundadas de ÿ cores todas as necessariamente para todas as páginas que você
manhãs, mas ÿ nem uma única flor
escreverá. Você aprenderá mais sobre quando usar o
permanece ÿ à tarde. Eles são a própria ÿ
artigo no Capítulo 3.
definição de efêmero.</p>

</artigo>
O próximo é o título D. O HTML fornece seis níveis de
</body>
título, h1–h6, sendo h1 o mais importante. Um h2 é um
subtítulo de um h1, um h3 é um subtítulo de um h2 e
D Os títulos são elementos críticos na definição do assim por diante, assim como quando você digita um
esboço de uma página. Eles tornam uma página mais
documento com vários títulos em um processador de
acessível aos usuários de leitores de tela e os mecanismos
de pesquisa os utilizam para determinar o foco de uma página. texto.

Toda página HTML deveria ter um h1 (ou mais,


<h1>O Efêmero Linho Azul</h1>
dependendo do seu conteúdo), então marcar nosso
título com h1 foi a escolha óbvia. Os elementos de
E É fácil adicionar uma imagem a uma página com img. título h1–
Conforme definido pelo atributo alt , “Blue Flax (Linum lewisii)” é exibido
h6 são abordados mais detalhadamente no Capítulo 3.
se nossa imagem não for.

Em seguida, você tem uma imagem E. O elemento img


<img src="blueflax.jpg" width="300" ÿ é a escolha principal para exibir uma imagem, portanto,
height="175" alt="Linho Azul (Linum lewisii)" ÿ />
novamente, não houve debate sobre qual elemento era
apropriado. O atributo alt fornece texto que será exibido
se a imagem não carregar ou se a página for
visualizada em um navegador somente texto. Você
aprenderá mais sobre imagens no Capítulo 5.

Blocos de construção de páginas da Web 9


Machine Translated by Google

O parágrafo é marcado com – surpresa – o elemento p F O elemento p pode conter outros elementos
F. Assim como nos materiais impressos, um parágrafo que definem a semântica das frases dentro de
pode conter uma única frase ou várias frases. um parágrafo. Os elementos em e a são dois
exemplos.
Se nossa página precisasse de outro parágrafo, você
simplesmente adicionaria outro elemento p após o <p> Fico continuamente <em>surpreso</
primeiro. em> com ÿ a linda e delicada <a href="http://
ÿ en.wikipedia.org/wiki/Linum_lewisii" ÿ
Existem dois elementos aninhados em nosso rel="external" title="Saiba mais sobre ÿ
parágrafo que define o significado de pedaços de Blue Flax">Blue Flax</a> que de alguma
texto: em e F. Esses são exemplos dos numerosos forma ÿ tomou conta do meu jardim. Eles
elementos de conteúdo de frases que o HTML5
estão inundados de ÿ cores em todas as
cores manhã, mas nem uma única ÿ flor
fornece, a maioria dos quais melhora a semântica do
permanece à tarde. Elas são ÿ a própria definição de efêmero.</p>
texto do parágrafo.
Conforme mencionado, esses, juntamente com
p, são discutidos no Capítulo 4. G Este elemento define um link para a página da
Wikipedia sobre Blue Flax. O atributo opcional rel
O elemento em significa “ênfase no estresse”. aumenta a semântica, indicando que o link aponta
No caso da nossa página, destaca-se o espanto para outro site. O link funciona sem ele, no entanto.
O atributo opcional title aprimora a semântica de a ,
que as flores provocaram em F.
fornecendo informações sobre a página vinculada. Ele
Lembre-se disso porque o HTML descreve aparece no navegador quando um usuário passa o
o significado do conteúdo, em dita a ênfase semântica, mouse sobre o link.

e não visual, embora seja comum renderizar o texto


<a href="http://en.wikipedia.org/wiki/Linum_
em itálico. ÿ lewisii" rel="external" title="Saiba mais ÿ
sobre o Linho Azul"> Linho Azul</a>
Finalmente, a página básica define um link
para outra página com o elemento a
(“âncora”), que é o elemento mais poderoso em todo
o HTML porque torna o
Web, a Web: vincula uma página a outra página ou
recurso e vincula uma parte de uma página a outra
parte de uma página (a mesma página ou uma
diferente). No exemplo, significa que o texto “Blue
Flax” é um link para uma página da Wikipedia G.

10 Capítulo 1
Machine Translated by Google

Muito fácil, certo? Depois de aprender mais sobre Por que a semântica é importante
os elementos HTML disponíveis
Agora que você conhece a importância do HTML
para você, escolher os corretos para o seu conteúdo
semântico e o viu em ação, precisa saber os motivos
geralmente é uma tarefa simples.
pelos quais ele é importante.
Ocasionalmente, você encontrará um conteúdo que
poderia ser razoavelmente marcado de mais de uma
maneira, e tudo bem. Aqui estão alguns dos motivos mais importantes (esta

Nem sempre existe uma maneira certa e errada, não é uma lista exaustiva), alguns dos quais já

apenas na maioria das vezes. mencionamos:

Por último, o HTML5 não tenta fornecer um elemento n Melhor acessibilidade e interoperabilidade

para cada tipo de conteúdo imaginável, porque a habilidade (o conteúdo está disponível para

linguagem se tornaria desajeitada. Em vez disso, adota tecnologias assistivas para visitantes com

uma postura prática e real, definindo elementos que deficiência e para navegadores em desktops,

cobrem a grande maioria dos casos. celulares, tablets e outros dispositivos)

n Otimização aprimorada do mecanismo de pesquisa

Parte da beleza do HTML é que é simples para (ESSE)

qualquer pessoa aprender o básico, construir algumas n (normalmente) código mais leve e páginas mais rápidas
páginas e aumentar seu conhecimento a partir daí.
n Manutenção e estilo de código mais fáceis
Portanto, embora existam aproximadamente 100 elementos
HTML, não se deixe assustar por esse número. Há Se você não está familiarizado com acessibilidade,

alguns itens básicos que você usará repetidamente, é prática disponibilizar seu conteúdo para todos os

enquanto os restantes são reservados para casos usuários, independentemente de suas capacidades

menos comuns. Você já aprendeu o básico de vários (consulte www.w3.org/standards/

elementos comuns, então está no caminho certo. webdesign/acessibilidade). Tim Berners-Lee, inventor da
Web, disse a famosa frase: “O poder da Web está na
sua universalidade.
O acesso de todos, independentemente da deficiência, é
um aspecto essencial.”

Blocos de construção de páginas da Web 11


Machine Translated by Google

Qualquer dispositivo com navegador é capaz de


exibir HTML, já que é apenas texto. Os meios
pelos quais um usuário acessa o conteúdo podem
variar, entretanto. Por exemplo, os utilizadores
com visão visualizam o conteúdo, enquanto um
utilizador com deficiência visual pode aumentar o
tamanho da página ou da fonte ou utilizar um leitor
de ecrã, software que lê o conteúdo em voz alta
para eles (um exemplo de tecnologia de apoio). Em
alguns casos, os leitores de tela anunciam o tipo de
elemento HTML que envolve o conteúdo para
fornecer ao usuário contexto sobre o que está por vir.
Por exemplo, o usuário pode ser informado de que
uma lista foi encontrada antes do
itens individuais da lista são lidos em voz alta. Da mesma
forma, os usuários são informados quando um link é encontrado

para que eles possam decidir se devem segui-lo.

Os usuários de leitores de tela podem navegar em


uma página de várias maneiras, como pular de um
título para outro por meio de um comando de
teclado. Isso permite que eles reúnam os principais
tópicos de uma página e ouçam com mais
detalhes aqueles que lhes interessam, em vez de
do que ter que ouvir a página inteira
sequencialmente.

Então você pode ver por que uma boa


semântica faz uma diferença marcante para usuários com
deficiências.

O SEO – isto é, a classificação da sua página nos


resultados dos mecanismos de pesquisa – pode
melhorar, porque os mecanismos de pesquisa
enfatizam as partes do seu conteúdo que são
marcadas de uma maneira específica. Por
exemplo, os títulos informam ao mecanismo de
pesquisa os principais tópicos da sua página,
ajudando o mecanismo de pesquisa a determinar
como indexar o conteúdo da sua página.

À medida que avança no livro, você aprenderá por


que uma boa semântica pode tornar seu código mais
eficiente e mais fácil de manter.
e estilo.

12 Capítulo 1
Machine Translated by Google

O elemento consiste em uma tag inicial (o


Marcação: Elementos, nome do elemento e os atributos, se houver,

Atributos e Valores entre sinais de menor que e maior que), o


conteúdo e uma tag final (uma barra seguida
Agora que você já viu um pouco de HTML, vamos pelo nome do elemento, novamente entre sinais de
dar uma olhada mais de perto no que constitui
que e de maior que) A.
marcação.

HTML tem três componentes principais de Um elemento vazio (também chamado de elemento
marcação: elementos, atributos e valores. void) se parece com uma combinação de tags de
Você viu exemplos de cada um em nossa início e fim, com um sinal de menor que inicial, o
página básica. nome do elemento seguido por quaisquer atributos que
ele possa ter, um espaço opcional, uma barra opcional
Elementos e o sinal maior que final, que é obrigatório B.
Os elementos são como pequenos rótulos que descrevem

as diferentes partes de uma página da Web: “Este é um O espaço e a barra antes do final de um elemento
título, aquela coisa ali é um parágrafo e aquele vazio são opcionais em HTML5. Provavelmente é
grupo de links é a navegação”. justo dizer que aqueles de nós que anteriormente
Discutimos alguns elementos na seção anterior. codificaram em XHTML, que requer a barra para
Alguns elementos possuem um ou mais atributos, fechar um elemento vazio, tendem a usá-lo em
que descrevem melhor a finalidade e o conteúdo (se HTML5 também, embora certamente outros o tenham
houver) do elemento. abandonado.
Os elementos podem conter texto e outros elementos Eu o incluí no meu código, mas se você optar por

mentos, ou eles podem estar vazios. Um não-vazio omiti-lo no seu, a página se comportará

Contente
Dia de início Etiqueta final

estou continuamente <em>surpreso</em>

Colchetes angulares Barra

R Aqui está um elemento HTML típico. A tag inicial


e a tag final circundam o texto que o elemento
descreve. Neste caso, a palavra “espantado” é
enfatizada, graças ao elemento em . É comum
digitar as tags dos elementos em letras minúsculas.

<img src="blueflax.jpg" width="300" height="175" alt="Linho Azul (Linum lewisii)" />

Um espaço e uma barra

B Elementos vazios, como img mostrado aqui, não circundam nenhum conteúdo de texto (o texto do atributo alt faz parte
do elemento, não está rodeado por ele). Eles possuem uma única tag que serve tanto para abrir quanto para fechar o
elemento. O espaço e a barra no final são opcionais no HTML5, mas é comum incluí-los. No entanto, o >
que completa o elemento é obrigatório.

Blocos de construção de páginas da Web 13


Machine Translated by Google

exatamente o mesmo. Seja qual for o caminho que você entre aspas, mas é costume incluí-las, por isso recomendo
escolher, recomendo fazê-lo de forma consistente. que você sempre faça isso. E assim como acontece com
os nomes dos elementos, recomendo que você digite os
É comum digitar os nomes dos elementos em letras
nomes dos atributos em letras minúsculas.
minúsculas, embora o HTML5 também não seja
exigente aqui, permitindo letras maiúsculas. No
entanto, hoje em dia é raro encontrar alguém que Embora você encontre detalhes sobre valores aceitáveis
codifique em letras maiúsculas, então, a menos que o para a maioria dos atributos neste livro, deixe-me dar uma
rebelde que existe em você não consiga resistir, eu não ideia dos tipos de valores que você encontrará à
recomendo. É visto como uma prática datada. medida que avança.

Alguns atributos podem aceitar qualquer valor, outros


são mais limitados. Talvez os mais comuns sejam aqueles
Atributos e Valores que aceitam valores enumerados ou predefinidos. Em outras
Os atributos contêm informações sobre o palavras, você deve selecionar um valor de uma lista

conteúdo do documento, em vez de ser o próprio padrão de

conteúdo (C e D). Em HTML5, o valor de um atributo pode escolhas E. Certifique-se de escrever enumeradas

opcionalmente ser valores em todas as letras minúsculas.

for é um atributo do rótulo

<label for="email"> Endereço de e-mail</label>


O valor do atributo for

C Aqui está um elemento rótulo (que associa um rótulo de texto a um campo de formulário) com um par simples atributo-valor.
Os atributos estão sempre localizados dentro da tag inicial de um elemento. É costume colocá-los entre aspas.

href é um atributo de um rel também é um atributo de um


Valor para href Valor para rel

<a href="http://en.wikipedia.org/wiki/Linum_lewisii" rel="external" ÿ


title="Saiba mais sobre o Linho Azul"> Linho Azul</a>
Valor para título
título é um atributo de um

D Alguns elementos, como mostrado aqui, podem receber um ou mais atributos, cada um com seu próprio valor. A ordem
não é importante. Separe cada par atributo-valor do próximo com um espaço.

<link rel="folha de estilo" media=


Valor predefinido

E Alguns atributos aceitam apenas valores específicos. Por exemplo, o atributo media no elemento link pode ser definido como all, screen
ou print, entre outros, mas você não pode simplesmente criar um valor para ele como faz com o
Atributo do Título .

14 Capítulo 1
Machine Translated by Google

Muitos atributos exigem um número para seu valor, elemento F. Na verdade, você pode criar uma
especialmente aqueles que descrevem tamanho e árvore genealógica de uma página da Web que mostre
comprimento. Um valor numérico nunca inclui unidades, os relacionamentos hierárquicos entre cada elemento
apenas o número. Quando as unidades são da página e que identifique cada elemento
aplicáveis, como na largura e na altura de uma imagem exclusivamente.
ou vídeo, elas são entendidas como pixels.
Essa estrutura subjacente semelhante a uma árvore
genealógica é um recurso importante do código HTML.
Alguns atributos, como href e src, fazem referência a Ele facilita tanto os elementos de estilo (sobre os quais
outros arquivos e, portanto, devem conter
você começará a aprender no Capítulo 7) quanto a
valores na forma de URL, ou Uniform Resource aplicação do comportamento JavaScript a eles.
Locator, o endereço exclusivo de um arquivo na Web.
É importante observar que quando os elementos
Você aprenderá mais sobre URLs
contêm outros elementos, cada elemento deve estar
na seção “URLs” deste capítulo.
adequadamente aninhado, ou seja, totalmente contido
em seu pai. Sempre que você usar uma tag final, ela
Pais e Filhos deverá corresponder à última tag inicial não fechada.
Se um elemento contiver outro, ele será Em outras palavras, primeiro abra o elemento 1,
considerado o pai do elemento incluído ou depois abra o elemento 2, depois feche o elemento
filho. Quaisquer elementos contidos no elemento filho 2 e depois feche o elemento 1 G.
são con-
descendentes siderados do pai externo

<artigo>

<h1>O Efêmero Linho Azul</h1>


<img src="blueflax.jpg"... />
<p>... continuamente <em>espantado</em> ... delicado <a ...> Linho Azul</a> ...</p>
</artigo>

F O elemento article é pai dos elementos h1, img e p . Por outro lado, os elementos h1, img
e p são filhos (e descendentes) do artigo. O elemento p é pai dos elementos em e a . O em
e a são filhos do p e também descendentes (mas não filhos) do artigo. Por sua vez, o artigo é
seu ancestral.

Correto (sem linhas sobrepostas)

<p>... continuamente <em>espantado</em> ...</p>


<p>... continuamente <em>espantado...</p></em>

Incorreto (os conjuntos de tags se cruzam)

G Os elementos devem estar adequadamente aninhados. Se você abrir p e depois em, deverá fechá -los antes de fechar p.

Blocos de construção de páginas da Web 15


Machine Translated by Google

O conteúdo de texto de uma página (destacado) é basicamente


Uma página da Web qualquer coisa além da marcação. Neste exemplo, observe que
cada frase é separada por pelo menos um retorno de carro e
Conteúdo de texto algumas palavras são separadas por vários espaços (apenas
para enfatizar o ponto sobre o colapso de retornos e espaços).
O texto contido nos elementos talvez seja o Além disso, inclui uma referência de caractere especial
ingrediente mais básico de uma página da Web. Se (&copy;) para o símbolo de copyright para garantir que ele seja
exibido corretamente, independentemente da codificação na
você já usou um processador de texto, você digitou
qual você salvou este documento.
algum texto. O texto em uma página HTML,
entretanto, apresenta algumas diferenças importantes.
<p> Fico continuamente <em>surpreso</em> com
Primeiro, quando um navegador renderiza o ÿ lindo, ÿ que delicado Linho Azul que
HTML, ele recolhe espaços ou tabulações extras de alguma forma tomou conta do meu jardim.
em um único espaço e converte retornos e feeds
de linha em um único espaço ou os ignora Elas ficam inundadas de cores todas as ÿ
manhãs, mas nem uma única flor ÿ
completamente (A e B).
permanece à tarde.
Em seguida, o HTML costumava ser restrito a
caracteres ASCII – basicamente as letras do
idioma inglês, numerais e alguns dos
Eles são a própria definição de ÿ
símbolos mais comuns. Caracteres acentuados efêmero.</p>
(comuns a muitas línguas da Europa Ocidental) <p>&copy; Sociedade do Linho Azul.</p>
e muitos símbolos cotidianos tiveram que ser
criados com referências de caracteres
especiais como &eacute; (para é) ou &copy; (para
©). Veja a lista completa em www.eliza
bethcastro.com/html/extras/entities.html.

Unicode atenua muitos problemas com


caracteres especiais. É prática padrão codificar
páginas em UTF-8, como na página básica C, e
B Observe que quando você visualiza o documento
salvar arquivos HTML com a mesma codificação com um navegador, os retornos e espaços extras são
(veja “Salvando sua página da Web” no Capítulo ignorados e a referência do caractere é substituída
2). Eu recomendo que você faça o mesmo. pelo símbolo correspondente (©).

Como o Unicode é um superconjunto de


C Especifique a codificação de caracteres do seu documento
ASCII – é tudo o que ASCII é e muito mais –
diretamente após a tag head start. O conjunto de caracteres
documentos codificados em Unicode são atributo define o tipo de codificação.
compatível com navegadores e editores existentes,
<!DOCTYPEhtml>
exceto os mais antigos. Navegadores que não
entendem Unicode irão <html lang="pt">
<cabeça>
interpretará a parte ASCII do documento <meta charset="utf-8" />
corretamente, enquanto os navegadores que <title>Linho Azul (Linum lewisii)</title>
entendem Unicode também exibirão a parte não- </head>

ASCII. Mesmo assim, às vezes ainda é comum <corpo>


...
usar referências de caracteres, como para o
</body>
símbolo de copyright, pois é fácil lembrar e digitar </html>
&copy;A.

16 Capítulo 1
Machine Translated by Google

R Em nosso documento HTML básico, há uma referência a


um arquivo de imagem chamado blueflax.jpg, que o navegador Links, imagens e
solicitará, carregará e exibirá quando carregar o restante da página. A
página também inclui um link para outra página sobre Blue Flax.
Outro não-texto
Contente
...
<artigo> É claro que parte do que torna a Web tão vibrante
<h1>O Efêmero Linho Azul</h1> são os links de uma página para outra e as imagens,
vídeos, músicas, animações e muito mais. Em vez
<img src="blueflax.jpg" width="300"
de realmente incluir os arquivos externos, como
ÿ height="175" alt="Linho Azul (Linum
ÿ lewisii)" /> vídeos, no arquivo HTML, esses arquivos são salvos de
forma independente e são simplesmente referenciados
<p>Fico continuamente <em>surpreso</ na página A. Como a referência nada mais é do que
em> com ÿ a linda e delicada <a href= texto, o arquivo HTML permanece quase
ÿ "http://en.wikipedia.org/wiki/Linum_
universalmente acessível. .
ÿ lewisii" rel="external" title="Saiba ÿ
mais sobre o Linho Azul">Linho Azul ÿ </
a> que de alguma forma tomou conta Os navegadores podem lidar com links e imagens
do meu ÿ jardim. Eles ficam cheios de
(exceto em navegadores somente de texto) sem perder
cores todas as ÿ manhãs, mas nem
o ritmo. No entanto, eles não podem necessariamente
uma única flor ÿ permanecem à tarde. Eles
são a ÿ própria definição de efêmero.</p> lidar com qualquer outro tipo de arquivo. Se você fizer
</artigo> referência a um arquivo que o navegador do visitante
... não entende, o navegador muitas vezes tentará
encontrar um plug-in ou aplicativo auxiliar—
algum programa apropriado no computador do visitante
– que seja capaz de abrir esse tipo de arquivo.

Você também pode fornecer aos navegadores


informações extras sobre como renderizar conteúdo com um
plugin, se necessário, ou como fazer o download do
plugin, se o visitante ainda não o tiver em seu
computador.

B Imagens e outros conteúdos não textuais


são referenciados em uma página da Web e o
navegador os exibe junto com o texto.

Blocos de construção de páginas da Web 17


Machine Translated by Google

Todo esse negócio de baixar e instalar plug-


ins atrapalha a experiência do usuário em seu
site, desde que ele permaneça por aqui. Os
plug-ins também podem apresentar
problemas de desempenho porque não são
uma parte nativa do navegador.
O Flash, por exemplo, tem sido o plugin
mais difundido há anos. Sem dúvida, você
já assistiu a um vídeo on-line reproduzido em
Flash em algum momento e sentiu o
computador ficar lento ou travar
ocasionalmente o navegador (ou ambos).
O HTML5 tenta mitigar muitos desses problemas
introduzindo a reprodução de mídia nativa no
navegador por meio do áudio e
elementos de vídeo . Infelizmente, tem
havido um debate entre os fornecedores de
navegadores sobre quais formatos de mídia
suportar, então você nem sempre pode acabar
com os plug-ins ainda. Mas é um começo.
Você aprenderá mais sobre imagens
no Capítulo 5 e abordará plug-ins, elementos
de mídia do HTML5 e muito mais no Capítulo 17.

18 Capítulo 1
Machine Translated by Google

Nomes de arquivos Separe palavras com um traço


Nunca inclua espaços entre palavras nos nomes dos
Como qualquer outro documento de texto, uma página
arquivos. Em vez disso, use um travessão, por
da Web possui um nome de arquivo que se
exemplo, company-history.html e my-favorite-
identifica para você, para os visitantes e para os
movies.html. Você encontrará sites ocasionais que
navegadores da Web dos visitantes. Há algumas dicas usam sub-
que você deve ter em mente ao atribuir nomes de
pontuações (“_”), mas não são recomendadas, porque
arquivos às suas páginas da Web que ajudarão você a
os travessões são preferidos pelos motores de busca.
organizar seus arquivos, tornar mais fácil para os
visitantes encontrarem e acessarem suas páginas,
garantir que seus navegadores visualizem as páginas
Use a extensão adequada
corretamente e melhorar o SEO. (A e B).
A principal forma de um navegador saber que deve ler
Use nomes de arquivos em letras minúsculas um documento de texto como uma página da Web é
observando sua extensão. Embora .htm
Como o nome do arquivo que você escolhe para sua
também funciona, .html é o habitual, então recomendo
página da Web determina o que os visitantes terão
que você use isso como extensão. Se a página tiver
que digitar para chegar à sua página, você pode
alguma outra extensão, como .txt, o navegador irá
salvá-los de erros de digitação inadvertidos (e dores de
tratá-la como texto e mostrar todo o seu código
cabeça) usando apenas letras minúsculas nos nomes
bacana ao visitante.
dos arquivos.
Também é uma grande ajuda quando você mesmo Esteja ciente de que nem o Mac OS nem
cria links entre suas páginas. Se todos os nomes de o Windows sempre revelam a extensão real de
arquivos tiverem apenas letras minúsculas, será apenas um documento. Altere as opções de pasta, se
uma coisa a menos com que você terá que se preocupar. necessário, para poder ver as extensões.

Nome do arquivo, em Nomes de arquivos com letras maiúsculas são


letras minúsculas Extensão difíceis de digitar e comunicar

buckminster-fuller.html Buckminster_Fuller.html
Separe cada palavra com um travessão Os sublinhados não são tão bons para a
otimização de mecanismos de pesquisa quanto os traços

R Lembre-se de usar letras minúsculas nos nomes dos arquivos, separar as palavras com um travessão e adicionar a
extensão .html. A mistura de letras maiúsculas e minúsculas torna mais difícil para os visitantes digitarem o endereço
correto e encontrarem sua página.

Abordagem correta

http://www.yoursite.com/notable-architects/20th-century/buckminster-fuller.html
http://www.yoursite.com/NotableArchitects/20th_CENTURY/Buckminster_Fuller.html
Abordagem incorreta

B Use todas as letras minúsculas e travessões também para seus diretórios e pastas. A chave é a consistência. Se você
não usar letras maiúsculas, seus visitantes (e você) não precisarão perder tempo se perguntando “Agora, era B maiúsculo ou
minúsculo?”

Blocos de construção de páginas da Web 19


Machine Translated by Google

URLs Esquema Nome do servidor Caminho Nome do arquivo

Uniform Resource Locator, ou URL, é um nome "http://www.site.com/tofu/index.html"


sofisticado para endereço. Ele contém informações
sobre onde um arquivo está e o que um navegador
A Sua URL básica contém um esquema, nome do servidor,
deve fazer com ele. Cada arquivo no
caminho e nome do arquivo.
A Internet tem um URL exclusivo.

A primeira parte do URL é chamada de


Barra final
esquema. Diz ao navegador como lidar
com o arquivo que está prestes a abrir. O esquema "http://www.site.com/tofu/"
mais comum que você verá é HTTP ou Hypertext
Transfer Protocol. É usado para acessar páginas da B Um URL com uma barra final e sem nome de arquivo aponta

Web A. para o arquivo padrão no último diretório nomeado (neste caso, o


diretório tofu ). O nome de arquivo padrão mais comum é index.html.
A segunda parte da URL é o nome do servidor Portanto, esta URL e a do exemplo anterior apontam para a mesma
página.
onde o arquivo está localizado, seguido do caminho
que leva ao arquivo e do próprio nome do arquivo. Às
vezes, um URL omite um nome de arquivo e
termina com um caminho, que pode ou não incluir Esquema Nome do servidor Caminho Nome do arquivo

uma barra B. Nesse caso, o URL se refere ao arquivo


"ftp://ftp.site.com/pub/proposal.pdf"
padrão no último diretório do caminho, normalmente
chamado de índice .html.
C Quando o usuário clicar neste URL, o navegador iniciará uma
transferência FTP do arquivo proposta.pdf.
Outros esquemas comuns são https, para páginas
Web seguras; ftp (File Transfer Pro-tocol), para
Esquema Endereço de email
download de arquivos C; mailto, para envio do e-mail
D; e arquivo, para acessar arquivos em um disco "mailto:algumnome@algumdomínio.com"
rígido local ou em redes locais de compartilhamento de
arquivos (você não terá a oportunidade de usar o
D Um URL para um endereço de e-mail inclui o esquema
esquema de arquivos com muita frequência, se é que o fará) E. mailto seguido por dois pontos, mas sem barras, e depois
o próprio endereço de e-mail.
Um esquema geralmente é seguido por dois pontos e
duas barras. mailto e notícias
são exceções; estes levam apenas dois pontos. Esquema Letra da unidade Caminho e nome do arquivo

Observe que o esquema do arquivo é seguido por dois "arquivo:///c|/caminho/home.htm"


pontos e três barras. Isso é porque
Barra vertical
o host, que em outros esquemas fica entre a
segunda e a terceira barras, é considerado o
E Para referenciar um arquivo em um Windows local
computador local. Sempre digite esquemas em letras máquina, use o esquema de arquivo . Para Macintosh, use file:///
minúsculas. Harddisk/path/filename. Nenhuma barra vertical é necessária. (Isso
às vezes também funciona para Windows.)
Desses esquemas, você usará http e mailto com
mais frequência. Os demais são para casos
especializados.

20 Capítulo 1
Machine Translated by Google

URLs absolutos
URLs podem ser absolutos ou relativos. Um
URL absoluto mostra o caminho completo para o arquivo,

www.site.com www.remote.com incluindo o esquema, o nome do servidor, o caminho


completo e o próprio nome do arquivo F. Um
sobre imprensa
URL absoluto é análogo a um endereço completo,
informações notícias.html incluindo nome, rua e número, cidade, estado , código
postal e país. Não importa de onde a carta seja enviada,
dados.html inscrever-se
os correios poderão encontrar o destinatário. Em
index.html index.html termos de URLs, isso significa que a localização do
próprio URL absoluto foi
você-está-aqui.html

imagem não tem influência sobre a localização do arquivo real


referenciado - seja em uma página da Web em seu
imagem.png
servidor ou em outro servidor, um valor absoluto
URL para um arquivo específico será exatamente igual
F O documento que contém os URLs ( neste caso, você
mesmo.
está aqui.html ) é o ponto de referência para URLs relativos. Em
outras palavras, URLs relativos são relativos à localização desse Ao fazer referência a um arquivo do servidor
arquivo no servidor. URLs absolutos funcionarão
independentemente de onde estejam localizados, pois sempre contêm de outra pessoa, você sempre usará um URL absoluto.
o URL completo de um recurso. Você também precisará usar
URLs absolutos para sites FTP ou, geralmente,
qualquer tipo de URL que não use protocolo HTTP.

A Tabela 1.1 descreve como você acessaria vários


arquivos de you-are-here.html — tanto aqueles no
mesmo site (site.com) da página quanto em outro
site (remote.com) — como forma de ilustrar a diferença
entre URLs relativos e absolutos.

TABELA 1.1 URLs absolutos versus URLs relativos

URL absoluto (pode URL relativo


Nome do arquivo ser usado em qualquer lugar) (funciona apenas em you-are-here.html)

index.html http://www.site.com/about/index.html index.html

dados.html http://www.site.com/about/info/data.html /info/data.html

imagem.png http://www.site.com/img/image.png ../img/image.png

notícias.html http://www.remote.com/press/news.html (nenhum: use absoluto)

index.html http://www.remote.com/sign-up/index.html (nenhum: use absoluto)

Blocos de construção de páginas da Web 21


Machine Translated by Google

URLs relativos
Dentro da pasta atual, existe
Para lhe dar instruções sobre como chegar à um arquivo chamado “index.html”…

casa da minha vizinha, em vez de fornecer


"index.html"
o endereço completo, posso apenas dizer: “fica
três portas abaixo, à direita”. Este é um
endereço relativo – para onde ele aponta G O URL relativo para vincular a um arquivo na mesma
pasta (ver F). Apenas o nome e a extensão do arquivo são
depende da origem da informação. Com a mesma obrigatórios no URL, em vez de precedê-los com http://
informação em uma cidade diferente, você www.site.com/about/ (a pasta na qual ambos os
nunca encontraria meu vizinho. arquivos residem).

Da mesma forma, um URL relativo descreve a


localização do arquivo desejado com referência Dentro da pasta atual, há
uma pasta chamada “info”…
ence para o local do arquivo que contém
a própria referência do URL. Portanto, você "info/dados.html"
pode fazer com que o URL diga algo como
…Isso contém… …um arquivo chamado “data.html”.
“link para a página xyz que está no mesmo diretório
desta página”.
H Para referenciar um arquivo (data.html, neste exemplo)
O URL relativo de um arquivo que está no que está dentro de uma pasta dentro da pasta atual
mesmo diretório da página atual (ou seja, aquele (veja F), adicione o nome da subpasta e um encaminhamento
barra na frente do nome do arquivo.
que contém o URL em questão) é simplesmente
o nome do arquivo e a extensão G. Você cria o
URL para um arquivo em um subdiretório do A pasta que contém a pasta atual…
diretório atual digitando o nome do subdiretório …contém… …uma pasta chamada “img”
seguido por uma barra e, em seguida, o nome
e a extensão de "../img/image.png"
o arquivo desejado H. …Isso contém… …um arquivo chamado “image.png”…

Para fazer referência a um arquivo em um diretório


em um nível superior da hierarquia de arquivos, I Este arquivo, como você pode ver em F, está em uma
use dois pontos e uma barra I. Você pode pasta (img) que fica ao lado da pasta atual (about) no
diretório raiz do site. Nesse caso, você usa dois pontos e
combinar e repetir os dois pontos e a barra
uma barra para subir de nível e, em seguida, anota o
para fazer referência a qualquer arquivo no subdiretório, seguido por uma barra, seguida pelo nome
mesmo servidor ou unidade que o arquivo atual . do arquivo. (Na prática normal, você escolheria um nome de
arquivo de imagem mais descritivo do que image.png, que
é deliberadamente genérico para o exemplo.)

22 Capítulo 1
Machine Translated by Google

Alternativamente, se seus arquivos estiverem


em um servidor Web, você pode evitar
caminhos de arquivo complicados, como ../../img/
family/vacation .jpg, primeiro indo direto para a
raiz do seu site e, em seguida, detalhando a partir
daí até o arquivo de destino . Uma única barra no
início consegue isso, então o URL relativo da
raiz neste caso seria /img/
family/vacation.jpg (assumindo a img
fica na pasta raiz do site, o que é habitual).
Novamente, isso só funciona em um servidor
Web, como no provedor de hospedagem que
atende seu site ou em um que você esteja
executando localmente em sua máquina
(Apache é a escolha mais popular para isso).

Se você não estiver desenvolvendo seu site


localmente em um servidor, geralmente você
desejará usar URLs relativos (exceto quando apontar
para arquivos no servidor de outra pessoa, é claro).
Eles facilitarão a movimentação de suas páginas
de um sistema local para um servidor. Contanto
que a posição relativa de cada arquivo permaneça
constante, você não precisará alterar nenhum dos
caminhos, para que os links funcionem corretamente.

Blocos de construção de páginas da Web 23


Machine Translated by Google

Principais conclusões
Os conceitos básicos de HTML e algumas práticas
recomendadas importantes fornecem a base para a
construção de sites eficazes. Vamos revisitar as principais
conclusões:

n Uma página da Web é composta principalmente de


três componentes: conteúdo de texto, referências
a outros arquivos e marcação.

n A marcação HTML é composta de elementos,


atributos e valores.

n É comum escrever seu HTML em letras minúsculas


(DOCTYPE é uma exceção), colocar os valores dos
atributos entre aspas e fechar os elementos
vazios com um espaço e uma barra ( /).

n Sempre comece seus documentos HTML


com a declaração DOCTYPE:

<!DOCTYPEhtml>
n O conteúdo de uma página vai para o elemento body .
As instruções destinadas principalmente ao
navegador e aos mecanismos de pesquisa estão
antes disso, principalmente na cabeça.

n Marque seu conteúdo com HTML semântico e sem


se preocupar com como ele deve aparecer em
um navegador.

n O HTML semântico melhora a acessibilidade e pode


tornar seu site mais eficiente e mais fácil de manter
e estilizar.

n CSS controla a apresentação do HTML


contente.

n A folha de estilo de cada navegador determina a


apresentação padrão do HTML. Você pode substituir
essas regras pelo seu próprio CSS.

n Crie nomes de arquivos e pastas em todos os

ercase e separe as palavras com um travessão em


vez de um espaço ou sublinhado.

A seguir, você aprenderá como trabalhar com arquivos


de páginas da Web.

24 Capítulo 1
Machine Translated by Google

2
Trabalhando com Web
Arquivos de página

Antes de começar a escrever elementos e


atributos HTML, é importante saber como criar Neste capítulo
os arquivos nos quais usará esse código.
Planejando seu site 26
Neste capítulo, você aprenderá como criar,
editar e salvar arquivos de páginas da Web. Criando uma nova página da web 28
Também abordarei algumas considerações de 30
Salvando sua página da web
planejamento e organizacionais.
Especificando uma página padrão ou página inicial 33
Se você não aguenta mais esperar e já sabe
Editando páginas da web 35
como criar os arquivos reais, vá para o Capítulo
3, onde começo a explicar o código HTML em Organizando arquivos 36
si.
Visualizando sua página em um navegador 37

A inspiração de outros 39
Machine Translated by Google

Planejando seu site


Embora você possa começar a escrever páginas lar
da Web imediatamente, é uma boa ideia primeiro
pensar e planejar seu site A. Dessa forma,
você terá uma direção e precisará fazer menos
reorganizações. mais tarde.

produtos sobre nós notícias

Para planejar seu site:


n Descubra por que você está criando este site.
O que você quer transmitir?

n Pense no seu público. Como pode para história da arquivo


você adapta seu conteúdo para atrair esse público? lar empresa

n Quantas páginas serão necessárias? Que tipo de


estrutura você gostaria que tivesse?
empregos
para negócios
Você deseja que os visitantes percorram seu site
em uma sequência específica ou deseja que
seja mais fácil para eles explorarem em qualquer
direção? R Esboçar seu site e pensar no que ele
n Esboce seu site no papel. pode conter pode ajudá-lo a decidir que
tipo de estrutura ele precisa.
n Elabore uma nomenclatura simples e consistente
convenção para suas páginas, imagens e outros
arquivos externos (consulte “Nomes de arquivos”
no Capítulo 1).

26 Capítulo 2
Machine Translated by Google

Não exagere na fase de planejamento do seu


site. Em algum momento, você terá que se aprofundar e
começar a escrever conteúdo e código.

Se você não está muito familiarizado com a Web,


navegue primeiro para ter uma ideia das possibilidades.
Você pode começar com os sites de alguns de seus
concorrentes.

É comum, mas não obrigatório, mapear a estrutura


de pastas do seu site de acordo com a forma como ela
está organizada no papel A. Consulte “Organização de arquivos”.

Veja o artigo de Erin Kissane “Uma lista de verificação para


Content Work” (www.alistapart.com/articles/a-checklist-for-
content-work/ ) para ideias sobre como você pode abordar
a elaboração do conteúdo do seu site. É uma amostra do
livro dela, que aborda o tema estratégia de conteúdo.

Os Princípios da Beleza, de Jason Beaird


ful Web Design (SitePoint, 2010) pode interessá-lo se
você não for um designer ou um designer novato e
estiver procurando orientação sobre como criar um
site atraente e eficaz.

Trabalhando com arquivos de páginas da Web 27


Machine Translated by Google

Criando um novo
Página da Internet

Você não precisa de nenhuma ferramenta especial para criar


uma página da Web. Você pode usar qualquer editor
de texto, até mesmo o Notepad (A e C), que está incluído
no Windows, ou o TextWrangler (A e B), que pode ser
baixado gratuitamente para OS X (www.barebones.com/
products/textwrangler ) . (Macs incluem um editor
chamado TextEdit, mas há um bug em algumas
versões do OS X que torna difícil A Abra seu editor de texto. Digite seu HTML no
documento em branco que aparece ou escolha Arquivo
> Novo. A opção exata do menu pode variar ligeiramente.
para trabalhar com arquivos HTML.) Se você estiver usando TextWrangler (Mac), é Arquivo >
Novo > Documento de Texto, conforme mostrado (parte
superior). A outra imagem é o Bloco de Notas (Windows) (parte inferior).
Para criar uma nova página da Web:

1. Abra qualquer editor de texto.

2. Escolha Arquivo > Novo para criar um novo,


documento em branco A.

3. Crie o conteúdo HTML conforme explicado no restante


deste livro, começando pelo Capítulo 3.

4. Certifique-se de salvar seu arquivo conforme indicado em


“Salvar sua página da web”.

B Em um Mac, você pode usar o TextWrangler para escrever


o código HTML da sua página. Veja nas dicas uma lista de
editores para Mac com recursos mais robustos para escrever
código.

28 Capítulo 2
Machine Translated by Google

Existem vários editores de texto para OS X


e Windows que são especificamente adaptados
para codificação de HTML (e CSS). Eles têm recursos
de dicas de código e conclusão de código para ajudá-
lo a codificar com mais precisão e rapidez, realçam o
código para facilitar a distinção entre os elementos
HTML e o conteúdo de texto que você escreveu neles e
possuem diversos outros recursos úteis; O bloco
de notas não possui nenhum deles. Alguns
editores de HTML gratuitos estão disponíveis, mas
outros geralmente valem o investimento e geralmente
incluem uma versão de teste gratuita que você pode
testar antes de fazer uma compra.

Alguns editores populares para OS X são


C Este é o Bloco de Notas, o programa mais básico que
BBEdit (www.barebones.com/products/
os usuários do Windows podem usar para criar páginas HTML.
bbedit/), Coda (www.panic.com/coda/), Espresso
Vários outros estão disponíveis (veja as dicas).
(http://macrabbit.com/espresso/), Sublime Text
(www.sublimetext.com) e TextMate (http://
macromates.com ).
(TextWrangler é comumente conhecido como
“BBEdit Lite”.) TextMate é o mais popular deles,
embora tenha visto a concorrência invadir sua
base de usuários. O Sublime Text também está
disponível no Windows, assim como o E Text Editor
(www.e-texteditor.com), o Notepad++ (http://notepad-
plus-plus.org) e muitos outros. Pesquise online
por “editor HTML” para saber mais.

Se você usar um editor como um men-


mencionado na dica anterior, o processo é
semelhante para a criação de uma nova página. E para
editar uma página existente, basta escolher Arquivo
> Abrir no editor de texto de sua preferência e abrir
o arquivo (consulte “Editando páginas da Web”). Use o
restante deste livro para adicionar seu próprio HTML
e CSS para criar a página desejada.

Não use processadores de texto, como o Microsoft


Word, para codificar suas páginas HTML. Eles podem
adicionar código desnecessário ou inválido aos seus arquivos.

Trabalhando com arquivos de páginas da Web 29


Machine Translated by Google

Salvando sua página da web


Você cria páginas da Web com um editor de
texto, mas elas devem ser visualizadas em vários
navegadores e em diversas plataformas.
Para ser acessível a todos esses diferentes
A Uma planilha do Excel possui a extensão .xlsx e é
programas, você salva páginas da Web em um formato identificada com o ícone do Excel (parte superior). Se
você clicar duas vezes nele, ele será exibido no Excel. Um
universal “somente texto” – sem qualquer formatação
arquivo de página da Web, independentemente do editor de
proprietária que um processador de texto possa aplicar. texto com o qual você o criou, possui a extensão .html
ou .htm e é identificado com o ícone do navegador padrão
(Firefox, neste caso). Se você clicar duas vezes nele, ele
Para que os navegadores (e servidores) será exibido no navegador padrão (não no editor de texto).
reconheçam as páginas da Web e saibam
interpretar a marcação que elas contêm, os arquivos
de páginas da Web têm a extensão .html ou .htm em seus arquivos.
nomes de arquivos; isso também distingue esses
arquivos de arquivos de texto simples que não são
páginas da Web. Embora ambos funcionem, é comum
usar a extensão .html, por isso recomendo que você a
utilize para seus arquivos.

Por causa dessa extensão, o ícone de uma página da


Web corresponde ao navegador padrão do
sistema – não ao editor com o qual o arquivo foi
escrito A. Na verdade, quando você clica duas
vezes em um arquivo de página da Web, ele é aberto
em um navegador, não em um editor de texto. Isso pode
ser ótimo para testar uma página em um navegador,
mas acrescenta uma etapa extra à edição de páginas
da Web (consulte “Editando páginas da Web”).

Para resumir, ao salvar sua página da Web, você


deve salvá-la em formato somente texto com a
extensão .html ou.htm.

30 Capítulo 2
Machine Translated by Google

Para salvar sua página da Web:

1. Depois de criar sua página da Web, escolha


Arquivo > Salvar como em seu editor de texto B.

B Escolha Arquivo > Salvar


2. Na caixa de diálogo que aparece, escolha Texto
como no seu editor de texto.
Simples ou Documento de Texto (ou qualquer que
seja a palavra do seu programa) para o formato.

3. Dê ao documento a extensão .html (de


preferência) ou .htm. (Isto é muito importante!)

4. Escolha a pasta na qual deseja salvar o


C No Bloco de notas, dê um nome ao seu arquivo com a
extensão .html ou .htm, escolha Documentos de texto no Página da Internet.

menu suspenso “Salvar como tipo”, certifique-se de que a


5. Clique em Salvar (C e D).
codificação esteja definida como UTF-8 (veja a última dica) e
clique em Salvar. As opções podem ser diferentes (mas
semelhantes) em outro editor de texto.
Não importa se você usa .html
ou .htm, embora .html seja recomendado
porque é a escolha comum. Seja qual for o
uso, seja consistente, pois usar a mesma
extensão tornará mais fácil lembrar seus
URLs posteriormente.
continua na próxima página

D No TextWrangler, dê um nome ao seu arquivo e


escolha um local para salvá-lo. O padrão do TextWrangler é
UTF-8 (que é o que você deseja, exceto em casos
especiais), mas você pode fazer uma escolha diferente no
menu suspenso Codificação (veja a última dica). Clique em
Salvar para salvar o arquivo.

Trabalhando com arquivos de páginas da Web 31


Machine Translated by Google

Alguns editores de texto no Windows


podem adicionar sua extensão padrão ao nome do
arquivo, mesmo se você já tiver
especificado .html ou .htm. (Observe que isso não
deve ser um problema com a maioria dos
editores projetados especificamente para editar
páginas HTML.) Seu arquivo, agora denominado
webpage.html.txt, não será visualizado corretamente
em um navegador. Para piorar a situação, o
Windows muitas vezes oculta extensões para
que o problema não seja completamente óbvio,
especialmente para os não iniciados. Existem duas
soluções. A primeira é colocar o nome do arquivo entre aspas duplas ao salvar o documento pela primeira vez.
Isso deve evitar que a extensão extra seja
adicionada. Em seguida, você pode dizer ao
Windows para exibir as extensões de arquivo
E, para que você possa ver a extensão ofensiva
e removê-la do nome do arquivo.

Quando você escolhe um formato somente


texto, seu arquivo geralmente é salvo com a
codificação de caracteres padrão do sistema. Se
você quiser criar páginas da Web em outra E No Windows Explorer, escolha Organizar >
codificação (talvez para incluir símbolos Opções de pasta e pesquisa ou Ferramentas > Opções
especiais ou texto em outros idiomas), você terá de pasta (dependendo da sua versão do Windows)
que usar um editor de texto que permita escolher para visualizar esta caixa de diálogo. Pode parecer
a codificação. Normalmente, UTF-8 é a melhor diferente dependendo da sua versão do Windows.
opção de codificação. Se o seu editor tiver a opção Clique na guia Exibir e role para baixo até ver “Ocultar
de salvar arquivos codificados como “UTF-8, sem as extensões dos tipos de arquivo conhecidos”.
Certifique-se de que esteja desmarcado se quiser ver
BOM”, “UTF-8, sem BOM” ou algo semelhante,
a extensão de um arquivo (como .html) na área de trabalho.
escolha essa opção. Caso contrário, escolha UTF-8
F. Em alguns casos, o modo UTF-8 de um editor não
inclui a lista técnica, mesmo que não anote
explicitamente esse fato em seu menu de codificação. (Veja http://en.wikipedia.org/wiki/Byte_
order_mark se você estiver curioso sobre o
significado do BOM. Esteja preparado para se encantar!)

F Muitos editores de texto permitem escolher a codificação


do seu arquivo, para que você possa salvar símbolos
e caracteres de diferentes idiomas no mesmo
documento. UTF-8 é a codificação recomendada na maioria
dos casos. Escolha a opção UTF-8 sem BOM se estiver
disponível em seu editor. Caso contrário, escolha
UTF-8. Alguns editores (como o TextWrangler,
mostrado aqui) usam-no como padrão.

32 Capítulo 2
Machine Translated by Google

Especificando um padrão
A Salve o arquivo como index.html para designar
o arquivo como a página padrão que deve ser aberta
Página ou página inicial
naquele diretório.
A maioria dos servidores Web possui um sistema para
reconhecer uma página padrão em cada pasta, com
base no nome do arquivo. Em quase todos os casos,
index.html é reconhecido como a página padrão A,
embora os servidores normalmente
procure nomes de arquivos como index.htm e
default.htm se index.html não existir. Se
seus visitantes digitam uma URL com um diretório, mas
não especificam um nome de arquivo, o arquivo padrão
é usado B.

A página padrão (normalmente index.html) que


você cria no nível superior do seu diretório da
Web (geralmente chamada de raiz) é a página
B Quando o visitante digita o caminho para o
inicial do seu site. Esta é a página que aparecerá quando
diretório, mas omite o próprio nome do arquivo, o
arquivo com o nome padrão é usado. Eu digitei http:// os visitantes digitarem seu domínio sem informações
bruceontheloose.com/htmlcss/examples/ adicionais de caminho: www.seudominio.com.
antoni-gaudi/ neste exemplo. Se eu tivesse digitado
http://bruceontheloose.com/htmlcss/examples/
antoni-gaudi/index.html em vez disso, a mesma página Da mesma forma, você pode criar uma página
teria carregado.
padrão para todo e qualquer diretório do seu site.
Por exemplo, a página de destino (ou seja, a página
principal) de /produtos/ ou /sobre-nós/
O diretório em seu site também seria chamado de
index.html, mas existiria em sua pasta específica. (Um
diretório é apenas uma pasta, como as que você vê
na unidade do seu computador.)
Os visitantes normalmente acessam essas seções do
seu site a partir da sua página inicial ou por meio da
navegação principal que existe em cada página.

continua na próxima página

Trabalhando com arquivos de páginas da Web 33


Machine Translated by Google

Para especificar uma página


inicial para seu site ou uma
página inicial para um diretório dentro dele:
Salve seu arquivo como index.html (veja “Salvando
sua página da Web”) na pasta desejada. (Se
index.html não funcionar como padrão
página no servidor do seu site ao carregá-la
conforme o Capítulo 21, consulte seu provedor de
hospedagem na Web.)

Se você não tiver uma página padrão em


cada diretório, alguns servidores poderão mostrar
uma lista do conteúdo do diretório (que você
pode ou não querer revelar aos visitantes). Para
manter esses olhares curiosos afastados, crie
uma página padrão para cada diretório do seu
site que contenha páginas HTML.
Alternativamente, você pode alterar a configuração
do servidor para que a lista de arquivos fique oculta (você também pode mostrá-la se já estiver oculta).
Ocultar a lista é aconselhável para pastas que
contêm ativos, como imagens, arquivos de
mídia, folhas de estilo e arquivos JavaScript.
Peça instruções ao seu provedor de hospedagem
na Web sobre como fazer isso.

34 Capítulo 2
Machine Translated by Google

Editando páginas da web


Como as páginas da Web são visualizadas com
mais frequência com um navegador da Web, quando
você clica duas vezes nelas na área de trabalho, o
navegador padrão abre e as exibe alegremente. Se
quiser editar a página da Web, você terá que abri-la
manualmente em seu editor de texto.

Para editar páginas da Web:

1. Abra seu editor de texto.


R Alguns editores de texto no Windows, como o Bloco de Notas, não
conseguem ver arquivos HTML automaticamente. Escolha Todos 2. Escolha Arquivo > Abrir.
os arquivos (ou uma opção semelhante), se necessário, para visualizar
arquivos com qualquer extensão. 3. Navegue até o diretório que contém o arquivo desejado.

4. Se você não vir seu arquivo listado, escolha a opção


Todos os Arquivos (ou descrição semelhante)
(A e B). O nome e a localização podem variar
ligeiramente de programa para programa e de
plataforma para plataforma.

5. Clique em Abrir. Seu arquivo está pronto para edição.

Depois de fazer alterações em um já


documento salvo, geralmente você pode
simplesmente escolher Arquivo > Salvar
para salvar as alterações, sem se preocupar com
B Assim que os arquivos com qualquer extensão forem exibidos, você
o formato (conforme descrito em “Salvar sua página da Web”).
pode escolher o arquivo HTML desejado e clicar em Abrir.

C No Windows, você também pode clicar com o botão direito


ícone do documento ou nome do arquivo e escolha Editar ou Abrir
com no menu pop-up que aparece. Em um Mac, clique com o
botão direito no ícone, selecione Abrir com no menu pop-up e
escolha o editor de texto desejado.

Trabalhando com arquivos de páginas da Web 35


Machine Translated by Google

Organizando arquivos
Antes de ter muitos arquivos, é uma boa ideia descobrir
onde colocá-los. É habitual (mas não obrigatório)
criar uma pasta para cada seção principal

dentro do seu site, permitindo agrupar páginas


HTML relacionadas.

Para organizar seus arquivos:

1. Crie uma pasta ou diretório central para armazenar


A Em um Mac, escolha Nova pasta e dê um nome à pasta.
todo o material que estará disponível
Crie uma pasta separada para cada seção do seu site.
disponível em seu site. No Mac, escolha
Arquivo > Nova pasta no Finder
A. No Windows, na área de trabalho (ou em
uma pasta de sua escolha), clique com o botão
direito e escolha Novo > Pasta B. Dê
um nome para a pasta.

2. Crie subpastas de uma forma que reflita a organização


do seu site (A
e C). Por exemplo, você pode decidir criar uma
pasta separada para cada seção do seu site,
juntamente com subpastas individuais dentro
delas, conforme necessário.

3. É comum criar uma pasta de nível superior para as B No Windows, na área de trabalho ou no Windows
imagens do seu site e, opcionalmente, Explorer, clique com o botão direito e escolha Novo > Pasta.
adicionar subpastas para ajudá-lo a organizar
suas imagens por seção ou outros critérios.
Outra abordagem é criar uma pasta de nível
superior chamada Assets (ou algo semelhante)
e colocar sua pasta de imagens nela , junto com
pastas para outros ativos, como vídeo, folhas
de estilo e assim por diante. (Você aprenderá
sobre folhas de estilo a partir do Capítulo 7.)

Use nomes curtos e descritivos para seus


arquivos e pastas, de preferência separando as
palavras em um nome com um traço (não um C Você pode dividir a pasta em subpastas se
espaço). Use todas as letras minúsculas para que seus necessário.

URLs sejam mais fáceis de digitar e, assim, suas


páginas sejam mais fáceis de acessar. Para obter mais
detalhes sobre como criar bons nomes de arquivos, consulte “Nomes de Arquivos” no Capítulo 1.

36 Capítulo 2
Machine Translated by Google

Visualizando sua página


em um navegador
Depois de criar uma página, você desejará ver como ela
fica em um navegador. Na verdade, como você não
sabe qual navegador seus visitantes usarão (e os
A No navegador
desejado (este é o Firefox), navegadores nem sempre renderizam as páginas
escolha Arquivo > Abrir Arquivo. exatamente da mesma maneira), é recomendável
No Internet Explorer, visualizar a página em vários navegadores.
chama-se Arquivo > Abrir.

Para visualizar sua página em um navegador:

1. Abra um navegador.

2. Escolha Arquivo > Abrir, > Abrir arquivo ou > Abrir


página (mas não Abrir local), dependendo do
navegador A.

3. Na nova caixa de diálogo exibida, navegue até a pasta


em seu computador que contém a página da
Web desejada, selecione a página e clique em
Abrir B. A página é exibida no navegador C
exatamente como aparecerá quando você realmente
B Escolha o arquivo que deseja abrir e clique em
a publicar em seu servidor Web (consulte o
o botão Abrir.
Capítulo 21).
Estas etapas podem variar ligeiramente em
diferentes navegadores.

Você também pode (normalmente) clicar duas vezes em um Web


ícone da página para visualizá-la em um navegador. Ou, se já
tiver um navegador aberto, você pode arrastar o ícone ou o nome do
arquivo e soltá-lo na janela do navegador. Geralmente, essa é a
maneira mais fácil de visualizar uma página em um navegador,
depois que você pega o jeito.

continua na próxima página

C A página aparece no navegador. Verifique com


atenção para ver se está saindo do jeito que você
planejou.

Trabalhando com arquivos de páginas da Web 37


Machine Translated by Google

Alguns navegadores modernos não possuem


uma opção de menu equivalente a Arquivo > Abrir
para abrir uma página. Experimente o método de arrastar e
soltar descrito na dica anterior.

Se a sua página da Web não aparecer na caixa de


diálogo Abrir, certifique-se de salvá-la como somente
texto e de ter fornecido a extensão .html ou .htm
(consulte “Salvar sua página da Web”).

Você não precisa fechar o documento


no editor de texto antes de visualizá-lo em um
navegador, mas é necessário salvá-lo. Se você fizer
uma alteração na página em seu editor de texto depois
de abri-la em um navegador, salve o arquivo novamente
e use o botão recarregar do navegador para atualizar
a página. (Você poderia seguir inicialmente as etapas
usadas para visualizar a página no navegador, mas
isso levaria mais tempo.)

Seus visitantes não poderão visualizar seu


Web site até publicá-lo em seu servidor Web
(consulte o Capítulo 21).

38 Capítulo 2
Machine Translated by Google

A inspiração
de outros
Uma das maneiras mais fáceis de expandir sua fluência
em HTML é observar como outros desenvolvedores e
designers criaram suas páginas. Felizmente, o código
HTML é fácil de visualizar e aprender. No entanto, o
conteúdo de texto, gráficos, sons, vídeos, folhas de estilo
R Todos os navegadores de desktop possuem um comando de
e outros arquivos externos podem estar protegidos por direitos
menu que permite visualizar o código HTML de uma página.
O nome varia de View Source para Page Source (no Firefox,
autorais. Como regra geral, use páginas de outras
mostrado) para nomes semelhantes. (No Chrome, é Ferramentas pessoas como inspiração para o seu HTML e, a seguir, crie
> Exibir código-fonte da página.)
seu próprio conteúdo.

Para visualizar o código HTML de outros


designers com View Source:

1. Abra uma página da Web com qualquer navegador.

2. Escolha Exibir código-fonte (ou a escolha apropriada


para um navegador específico)
(A e B). O código HTML será exibido C.

B A maioria dos navegadores também permite que você clique


com o botão direito na página e escolha o comando Exibir código- 3. Se desejar, salve o arquivo para estudo posterior.
fonte (seja qual for o nome) no menu que aparece.
O Chrome é mostrado. Geralmente, essa é a maneira mais fácil de
visualizar a fonte, pois pode ser difícil encontrar a opção no menu Para visualizar o código HTML de outros
principal ou submenu. designers com ferramentas de desenvolvedor:

Outra maneira de visualizar o código-fonte de uma


página é com as ferramentas de desenvolvedor do navegador.
As ferramentas são diferentes para cada fornecedor de
navegador, mas todas possuem alguns recursos que se sobrepõem.

Essas ferramentas mostram uma visão mais interativa

do código-fonte. Você pode inspecionar o HTML e CSS


de partes específicas de uma página, editá-lo no navegador e
ver as alterações refletidas na página imediatamente. E você
pode usá-los em qualquer site, não apenas no seu. As
C Os navegadores modernos exibem o código em sua própria alterações são temporárias – elas não sobrescrevem o HTML
guia ou janela (conforme mostrado), enquanto os navegadores
e CSS reais
mais antigos podem exibi-lo em um editor de texto específico.
As cores distinguem o conteúdo da página dos elementos
HTML, atributos e valores de atributos. Isso é chamado de realce de arquiva a página carregada. Isso é valioso para o
sintaxe. Os números das linhas à esquerda não fazem parte do
aprendizado, porque você pode ver como um determinado
código HTML e nem todos os navegadores os mostram nos modos
Visualizar código-fonte.
efeito foi alcançado ou mexer nele.

Eles são apenas um indicador que o Chrome inclui em sua janela Exibir
código-fonte.

Trabalhando com arquivos de páginas da Web 39


Machine Translated by Google

o código para ver o que acontece sem medo de


danificar nada.
Consulte a barra lateral “Ferramentas de desenvolvedor de
navegador” no Capítulo 20 para obter informações sobre
as ferramentas de desenvolvedor de navegador para
navegadores modernos e mais antigos.

Não há regra sobre quem pode colocar


um site na Web. Isso é o que há de tão bom
nisso: é um meio aberto com uma barreira de
entrada relativamente baixa. Você pode ser um
novato, um especialista ou qualquer coisa entre
os dois. Tenha isso em mente ao revisar o
código de outros sites. Se parte do código
parecer suspeito, não presuma que o autor sabe
melhor do que você só porque o site dele está na Web. Há
muitos sites que servem como ótimos exemplos de
melhores práticas de codificação, e há muitos
outros que são, digamos, menos que ideais.
Portanto, mantenha um olhar crítico e verifique
este livro e outros recursos quando tiver dúvidas
sobre a adequação de uma técnica específica.

Você também pode salvar o código-fonte


copiando-o da janela Exibir código-fonte e colando-
o em seu editor de texto. Então você pode salvar
o arquivo.

Você também pode salvar o código-fonte e


normalmente muitos de seus ativos (como
imagens) selecionando Arquivo > Salvar como (ou
Arquivo > Salvar página como) na maioria dos
navegadores. No entanto, o navegador pode
reescrever partes do código ao salvar a página,
portanto não será exatamente como se você o tivesse salvo usando a dica anterior.

Para visualizar o CSS em uma página da


Web, consulte “A inspiração de outros: CSS” no Capítulo 8.

40 Capítulo 2
Machine Translated by Google

3
HTML básico
Estrutura
Este capítulo aborda os elementos HTML necessários
para estabelecer a base e a estrutura de seus Neste capítulo
documentos. Ou seja, o esboço e os recipientes
Iniciando sua página da web 43
semânticos primários do seu conteúdo.
Criando um título 46

Você aprenderá sobre: Criando títulos 48

n Iniciando uma página da Web Compreendendo o documento HTML5


n O esboço do documento HTML5 Contorno 50

n O h1–h6, hgroup, cabeçalho, nav, Agrupando títulos 58

elementos de artigo, seção, aparte, Construções de páginas comuns 60


rodapé e div (a maioria dos quais são
Criando um cabeçalho 61
novos em HTML5)
Marcação de navegação 64
n Como os atributos de função ARIA podem melhorar a
Criando um Artigo 68
acessibilidade da sua página

Definindo uma seção 72


n Aplicando uma classe ou id aos elementos

Especificando um aparte 75
n Aplicando o atributo title a
elementos 80
Criando um rodapé

n Adicionando comentários ao seu código Criando contêineres genéricos 84

Melhorando a acessibilidade com ARIA 88

Nomeando Elementos com uma Classe ou ID 92

Adicionando o atributo Title aos elementos 95

Adicionando comentários 96
Machine Translated by Google

Criar uma estrutura clara e consistente não


apenas estabelece uma boa base semântica
para sua página, mas também torna muito
mais fácil aplicar estilos ao seu documento
com Cascading Style Sheets (CSS) (a
cobertura começa no Capítulo 7).
Se ainda não o fez, sugiro fortemente que
leia o Capítulo 1 antes de continuar. Mostra
uma página HTML simples e explica alguns
dos conceitos básicos. Como esta é sua
primeira visão de uma página da Web, repetirei
algumas informações (mas não todas) aqui e
presumirei que você esteja familiarizado
com o restante para poder desenvolver essas ideias.
Além disso, se você leu meu livro The
HTML Pocket Guide, parte deste material lhe
será familiar.

42 Capítulo 3
Machine Translated by Google

R : Aqui está a base de toda página HTML.


O recuo não importa, mas a estrutura é crucial. Neste
Iniciando seu
exemplo, o idioma padrão (de acordo com o atributo
lang ) é definido como en para inglês. A codificação de Página da Internet
caracteres está definida como UTF-8.
No seu nível mais básico, cada um dos seus
<!DOCTYPEhtml> documentos HTML deve conter os seguintes
<html lang="pt"> componentes, conforme mostrado em A:
<cabeça>
<meta charset="UTF-8" /> n O DOCTYPE
<título></título>
n O elemento html (com o lang
</head>
atributo, que é opcional, mas
<corpo>
recomendado)

n O elemento principal
</body>
</html> n A codificação de caracteres em um meta
elemento

n O elemento title (você adicionará seu conteúdo


em breve)

n O elemento corpo

Este é o equivalente HTML de uma folha de papel


em branco, pois não possui nenhum conteúdo no
corpo B.

Portanto, antes de adicionar qualquer conteúdo ou


outra informação, você precisa configurar a base da
sua página:

Para iniciar uma página HTML5:


1. Digite <!DOCTYPE html> para declarar sua página
B O código básico HTML mínimo conforme visualizado
como um documento HTML5. (Consulte a barra
no Firefox. Como você pode ver, não há nada para ver!
lateral “DOCTYPE aprimorado do HTML5” para
No entanto, você começará a adicionar conteúdo em breve.
obter informações relativas às versões anteriores
do HTML.)

2. Digite <html lang="idioma-código"> para iniciar a


parte HTML real do seu documento, onde código
do idioma é o código do idioma que corresponde
ao idioma padrão do conteúdo da sua página. Por
exemplo, <html lang="es"> para inglês ou
<html lang="fr"> para francês. Veja
www.bruceontheloose.com/references/

language-codes.html para obter uma lista de


códigos de idiomas disponíveis.

continua na próxima página

Estrutura HTML Básica 43


Machine Translated by Google

3. Digite <head> para iniciar o documento As duas seções de uma


cabeçalho da sua página. página: cabeça e corpo
4. Digite <meta charset="UTF-8" /> para Apenas como uma rápida recapitulação do que você
declare a codificação de caracteres do seu documento aprendeu no Capítulo 1, as páginas HTML são divididas
como UTF-8. Se preferir, você também pode digitá- em duas seções: a cabeça e o corpoA.
lo como utf-8 em seu HTML. O DOCTYPE, que inicia cada página, é uma espécie de
Além disso, o espaço e a barra são opcionais, preâmbulo.
então <meta charset="UTF-8">
O cabeçalho do documento é onde você define o
funciona da mesma forma. (As codificações de
título da sua página, inclui informações sobre sua
caracteres além do UTF-8 também são válidas,
página para mecanismos de pesquisa como o Google,
mas o UTF-8 é o mais versátil, por isso é raro que
carrega folhas de estilo e ocasionalmente carrega
você precise desviar-se.)
arquivos JavaScript (embora, por motivos de
5. Digite <título></título>. Isso conterá o título da sua desempenho, seja preferível na maioria das vezes para
página. Você adicionará o texto do título na seção carregar o JavaScript logo antes da tag final </body>
“Criando um título”. na parte inferior da sua página). Você verá exemplos
6. Digite </head> para finalizar o documento disso à medida que avança no livro. Exceto pelo título,

cabeçalho da sua página. que você abordará mais adiante, o conteúdo do


cabeçalho não fica visível para os usuários quando
7. Digite <body> para iniciar o corpo do seu
eles visitam sua página.
página. É para onde o seu conteúdo irá (eventualmente).

O elemento body inclui o conteúdo da sua página,


8. Deixe algumas linhas em branco para criar o
incluindo texto, imagens, formulários, áudio, vídeo
conteúdo da sua página, o que você fará no
e outros conteúdos interativos.
restante deste livro.
Em outras palavras, o que seus visitantes veem.
9. Digite </body> para finalizar o corpo. Existem vários capítulos dedicados aos elementos

10. Digite </html> para finalizar sua página. relacionados ao conteúdo do HTML, alguns dos quais
você verá antecipadamente neste capítulo.
Esse é um número bastante saudável de etapas, mas
como todas as suas páginas começarão dessa maneira,
você pode usar uma única página HTML como
modelo para iniciar cada página, evitando digitar. Na
verdade, a maioria dos editores de código permite
especificar o código inicial para cada nova página,
tornando isso ainda mais fácil. Se você não encontrar o
menu Configurações ou Preferências em seu editor,
pesquise na seção Ajuda.

44 Capítulo 3
Machine Translated by Google

O HTML5 DOCTYPE garante Certifique-se de que seu editor de código esteja configurado
os navegadores são renderizados em um modo para salvar arquivos como UTF-8 para corresponder
confiável e instruem os validadores HTML a à codificação de caracteres especificada no código por <meta
julgar seu código em relação aos elementos e à sintaxe permitidos charset="UTF-8"
pelo HTML5. /> A. (Ou se você especificou um
Validadores HTML são discutidos no Capítulo 20. conjunto de caracteres diferente, salve seus arquivos
nele.) Nem todos os editores salvarão suas páginas
O DOCTYPE do HTML5 não faz distinção entre maiúsculas e minúsculas
como UTF-8 por padrão, mas a maioria permite que
positivo. Por exemplo, alguns optam por digitá-lo você para escolher a codificação em um menu ou
como <!doctype html>, mas provavelmente é mais comum painel (veja “Salvar suas páginas da Web” no
usar <!DOCTYPE html> A. Capítulo 2). Sem a configuração UTF-8 em vigor, você
poderá ocasionalmente ver caracteres engraçados em
O elemento html , que segue o DOCTYPE, seu conteúdo, em vez de uma letra pretendida, como um i
deve incluir todos os outros elementos da sua página A. acentuado ou um n com um til (~).

Você não precisa recuar o código que


está aninhado no elemento head A. No entanto, a
vantagem de fazer isso é que você pode ver rapidamente
onde o head começa, o que há nele e onde termina.
Não é incomum que o cabeçalho fique muito longo em
algumas páginas.

DOCTYPE aprimorado do HTML5


Ah, como é mais simples iniciar sua página da Web agora que o HTML5 está aqui. O DOCTYPE do HTML5 é
refrescantemente curto, especialmente quando comparado aos DOCTYPEs de antigamente.

Na época do HTML 4 e do XHTML 1.0, havia vários DOCTYPEs para escolher, cada um significando a versão do
HTML e se estava no modo Transicional ou Estrito. Você invariavelmente tinha que copiá-los de algum outro lugar
porque eles eram complicados demais para serem lembrados.
Por exemplo, aqui está o DOCTYPE para documentos XHTML Strict.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/


ÿ TR/xhtml1/DTD/xhtml1-strict.dtd">
Gobbledygook.

Felizmente, todos os navegadores - antigos e novos - entendem o DOCTYPE do HTML5, então você pode segui-lo
em todas as suas páginas e esquecer que as outras existiram. (A única ocasião em que eles podem ser relevantes é
se você herdar um site antigo e o proprietário não permitir que você altere o DOCTYPE para a versão HTML5.)

Estrutura HTML Básica 45


Machine Translated by Google

Criando um título A O elemento title deve ser colocado na seção


head . Coloque-o após o metaelemento que
especifica a codificação de caracteres.
O código HTML básico na seção anterior tinha <title></
title> como espaço reservado até a hora de discutir <!DOCTYPEhtml>
o título <html lang="pt">
avançar. Agora é a hora! <cabeça>
<meta charset="UTF-8" />
Cada página HTML deve ter um título <title>Antoni Gaudí - Introdução
elemento. Um título deve ser curto, descritivo e ÿ </title>
</head>
exclusivo para cada página A. Na maioria dos
<corpo>
navegadores, o título aparece na barra de título da
janela (o Chrome é uma exceção)
B. Ele também aparece na aba da página em </body>
navegadores que suportam navegação por </html>

abas – em outras palavras, todos os principais


navegadores lançados nos últimos anos. O título
também aparece nas listas de histórico do navegador
e nos favoritos dos visitantes C.

Talvez ainda mais importante, o título é usado por


mecanismos de busca como Google, Bing e Yahoo!
tanto para ter uma ideia do conteúdo da sua
página quanto, normalmente, como o link que aparece
nos resultados da pesquisa D. B Na maioria dos navegadores, como o Firefox, o título
de uma página da Web é exibido na barra de título da janela
Resumindo, torne seu título exclusivo para cada
e na guia. No entanto, o Chrome (parte inferior) exibe o título
página para melhorar os resultados dos mecanismos apenas na guia.
de pesquisa e melhorar a experiência dos visitantes.

C O título também
aparece no painel
Histórico do
visitante
(mostrado), na lista
de Favoritos e na lista de Favoritos.

D Talvez o mais importante seja que o título normalmente é


usado como o texto do link que aponta para sua página
nos resultados de pesquisa do Google e de outros. É
também um fator importante para determinar a
relevância de uma página nos resultados de pesquisa. Aqui
você vê um título e uma cópia parcial do corpo aparecendo no Google.

46 Capítulo 3
Machine Translated by Google

Para criar um título:


Uma análise mais aprofundada dos títulos das páginas
1. Coloque o cursor entre <título> e
Muitos desenvolvedores – mesmo os bem-intencionados </title> no cabeçalho do documento.
e bastante experientes – dão pouca consideração
ao elemento do título .
2. Digite o título da sua página da Web.

Eles simplesmente inserirão o nome do site e o copiarão


em todas as páginas HTML. O elemento title é obrigatório.
Ou pior ainda, eles vão deixar o título
texto que seu editor de código pode inserir por padrão. Um título não pode conter qualquer formatação,
HTML, imagens ou links para outras páginas.
Se um de seus objetivos é direcionar tráfego para
seu site, você estaria prestando um enorme desserviço
Alguns editores de código preenchem
a si mesmo e a seus leitores em potencial ao seguir
previamente o título com texto padrão quando você
o exemplo. inicia uma nova página, a menos que você tenha
Os motores de busca possuem diferentes algoritmos que instruído a usar um código inicial específico,
conforme descrito em “Iniciando sua página da
determinam a classificação de uma página e como seu
Web”. Portanto, fique atento a isso e certifique-se de
conteúdo é indexado. Universalmente, porém, o título
substituir qualquer texto padrão por um título de sua própria criação.
desempenha um papel fundamental. Os mecanismos
de pesquisa podem olhar para o título em busca de Se o seu título contém caracteres especiais
uma indicação do assunto de uma página e como acentos ou alguns símbolos, você terá que torná-
indexar o conteúdo de uma página em busca de texto relacionado. los parte da sua codificação (o que normalmente
Um título eficaz concentra-se em alguns não será um problema se você estiver usando
de palavras-chave que são centrais para o conteúdo de uma página UTF-8) ou escrevê-los com referências ( veja a lista
contente. de referências de entidades de personagem
disponíveis em www.elizabethcastro.com/html/
Como prática recomendada, escolha um texto de extras/entidades.html). Além disso, não se esqueça
título que resuma brevemente o conteúdo de um de configurar seu editor de código para salvar suas
documento para beneficiar tanto o leitor de tela páginas com a codificação adequada, como UTF-8, para
usuários e as classificações do seu mecanismo de pesquisa. que os caracteres especiais sejam salvos
Secundariamente, e opcionalmente, indique o nome do corretamente (veja “Salvando suas páginas da Web” no Capítulo 2).
seu site no título. É comum

veja o nome de um site no início do título, mas é melhor


colocar o texto do título exclusivo e específico da
página no início.

Eu recomendo que você coloque a mensagem


central do seu título nos primeiros 60 caracteres,
incluindo espaços, porque os mecanismos de pesquisa
geralmente os cortam em seus resultados em torno desse
número (como linha de base).
Os navegadores exibem um número variável de
caracteres, mas não mais que 60, na barra de título
na parte superior do navegador antes de cortar o texto.
As guias do navegador cortam o título ainda mais cedo
porque há
menos imóveis.

Estrutura HTML Básica 47


Machine Translated by Google

Criando títulos R Use títulos para definir a estrutura do seu


documento, assim como um esboço. Aqui, “La
Casa Milà” e “La Sagrada Família” – marcados
HTML fornece seis níveis de títulos para
como elementos h2 – são subtítulos do título de
estabelecer a hierarquia de informações em suas nível superior, “Antoni Gaudí”, porque é um h1. (A
páginas. Marque cada título com um dos elementos parte lang="es" indica que o conteúdo está em
h1–h6 , onde h1 é um título de nível superior, h2 espanhol; não afeta o contorno.) Se "La Sagrada
Família" fosse um h3 , então seria um subtítulo
é um subtítulo de h1, h3 é um subtítulo de um h2 e de "La Casa Milà" (e um sub-subtítulo de "Antoni
assim por diante. Gaudí"). A linha em branco entre cada título é
totalmente opcional e não afeta a exibição do
Os títulos estão entre os elementos HTML mais
conteúdo. Se eu estivesse codificando o resto da
importantes em qualquer página, como você página agora, o conteúdo relacionado (parágrafos,
aprenderá. imagens, vídeo e assim por diante) seguiria cada
título. Você verá exemplos disso nas páginas
Pense nos títulos h1–h6 como semelhantes aos subsequentes.
títulos de um documento não HTML que você
<!DOCTYPEhtml>
pode escrever, como um relatório de vendas,
<html lang="pt">
trabalho de conclusão de curso, manual de <cabeça>
produto, artigo de notícias – essa é a ideia. Ao <meta charset="UTF-8" />
escrever esses tipos de documentos, você <title>Antoni Gaudí - Introdução

identifica cada seção principal do conteúdo ÿ </title>


</head>
com um título e qualquer número de subtítulos
<corpo>
(e subsubtítulos , e assim por diante), conforme apropriado.
Coletivamente, esses títulos representam o <h1>Antoni Gaudí</h1>
esboço do documento. O mesmo se aplica às
suas páginas da Web A. Discuto isso com mais <h2 lang="es">La Casa Milà</h2>
profundidade na próxima seção, “Compreendendo
<h2 lang="es">A Sagrada Família</h2>
o esboço do documento HTML5”.
</body>
Para organizar sua </html>

página da Web com títulos:


1. Na seção corporal do seu documento HTML,
digite <hn>, onde n é um número de 1 a 6,
dependendo do nível de importância do título
que você deseja criar. h1 é o mais
importante e h6 é o menos importante.

2. Digite o conteúdo do cabeçalho.

3. Digite </hn> onde n é o mesmo número


usado na etapa 1.

48 Capítulo 3
Machine Translated by Google

Seus títulos h1–h6 são especialmente


importantes devido ao seu impacto na definição do
contorno da sua página. Por padrão, os navegadores
exibem títulos progressivamente menores, passando
de h1 para h6B. Mas não se esqueça de escolher os
níveis de título apenas com base na hierarquia
apropriada para o seu conteúdo, e não no tamanho que
você deseja que o texto apareça. Isso torna sua
página semanticamente mais forte, o que, por sua
vez, melhora o SEO e a acessibilidade. Você pode estilizar
os títulos como desejar com uma fonte, tamanho, cor
específicos e muito mais. Para obter detalhes sobre como
conseguir isso com CSS, consulte o Capítulo 10.

Os mecanismos de pesquisa pesam muito em


seus títulos, especialmente aqueles como h1 (o que
não quer dizer que carregue sua página com h1s; os
mecanismos de pesquisa são sábios quanto a isso).
Enquanto isso, os usuários de leitores de tela
geralmente navegam em uma página pelos títulos por
meio do teclado, pois isso lhes permite avaliar
rapidamente o conteúdo de uma página e encontrar o
que mais lhes interessa sem ter que ouvir a página
inteira. Mais uma razão para ter uma hierarquia lógica de títulos.

B Embora todos os títulos sejam exibidos em Use os níveis de título de forma consistente
negrito por padrão, h1 está em uma fonte maior em todo o site para uma melhor experiência
que h2, que é maior que h3, e assim por diante. do usuário.
Mas como você sabe, a aparência não é relevante
ao decidir qual nível de título usar. Você pode alterar
Você pode adicionar um id a um título se
a apresentação com CSS.
quiser criar um link diretamente para ele (veja
“Criando Âncoras” no Capítulo 6).

Como observação lateral, em A usei a linguagem


atributo em cada h2 para indicar que seu
conteúdo está em um idioma diferente
(espanhol, representado pelo código de
idioma es) do padrão da página (inglês)
conforme declarado por <html lang="en">.

Estrutura HTML Básica 49


Machine Translated by Google

Entendimento
Documento HTML5
Contorno
Na seção anterior, você aprendeu que os
elementos de títulos, h1–h6, contribuem
para o esboço da sua página HTML. Você
vai se aprofundar mais nesta seção para
aprender como alguns elementos exclusivos do
HTML5 também afetam o contorno.
Uma nota sintática antes de continuar.
Na discussão e nas páginas a seguir, usarei
frequentemente “seção” como um termo
genérico para significar uma parte distinta de
uma página, em oposição ao elemento de
seção (sobre o qual você aprenderá)
especificamente. Quando me refiro ao
elemento de seção , a palavra terá o estilo
de código, assim como nesta frase.

OK, continuando.
Então, você sabe que cada documento HTML
tem um esboço subjacente, que é como um
índice analítico, conforme definido pelos
elementos do título. Agora, o esboço não é
algo exibido explicitamente em sua página
- embora os navegadores possam um dia
fornecer um meio de vê-lo - mas, como
acontece com toda semântica, é significativo
para mecanismos de pesquisa e leitores de tela,
que usam o esboço para colete a estrutura
da sua página e forneça as informações
aos usuários.

50 Capítulo 3
Machine Translated by Google

Um esboço do documento da Versão 1 Nas versões de HTML e XHTML que


precedeu o HTML5, os elementos de título h1–
...
h6 eram tudo o que você precisava para
<corpo> estruturar o esboço. O HTML5, por outro lado,
<h1>Guia do usuário do produto</h1>
inclui quatro elementos de conteúdo de seção
<h2>Configurando</h2>
<h2>Recursos básicos</h2> – artigo, aparte, navegação e seção – que
<h3>Reprodução de vídeo</h3> demarcam seções distintas.
<h2>Recursos Avançados</h2> dentro de um documento e defina o escopo dos
</body>
elementos h1–h6 (bem como cabeçalho e rodapé)
</html>
dentro deles.

Isso significa que cada elemento de seccionamento


Esboço do documento B Versão 2 (mesmo esboço do
tem sua própria hierarquia h1–h6 , o que é uma
Versão 1, mas com marcação mais significativa)
grande mudança em relação às versões
... anteriores da linguagem. Além disso, não só há mais de um h1
<corpo> em uma página OK, geralmente é recomendado
<h1>Guia do usuário do produto</h1>
pela especificação HTML5 (no entanto, mantenha
<seção>
esse pensamento; em breve explicarei por que
<h1>Configurando</h1>
</seção> você deve limitar seus h1s).

Tudo isso afeta o contorno. Vamos comparar dois


<seção>
esboços equivalentes para ver como isso
<h1>Recursos básicos</h1>
<section> <!-- aninhado, então é um funciona. Para ambos, imagine que cada título é
ÿ subseção de seu pai -> seguido por uma série de parágrafos e outros
<h1>Reprodução de vídeo</h1> conteúdos que representam as informações da
</seção>
seção.
</seção>
O primeiro esboço, que é HTML5 perfeitamente
<seção>
válido e será familiar para aqueles com experiência
<h1>Recursos avançados</h1>
em HTML e XHTML, usa apenas elementos de
</seção>
título A.
</body>
</html> A segunda versão B usa títulos e elementos de seção
do HTML5 , incluindo uma seção aninhada.
(Observação: o recuo do código não é importante e
não afeta o contorno, mas deixa claro quais
elementos estão contidos em outros.)

Estrutura HTML Básica 51


Machine Translated by Google

Anteriormente, mencionei que os navegadores ainda Esboço do documento C Versão 3 (não o


não expõem o esboço para você. No entanto, você mesmo esboço das Versões 1 e 2)
pode verificar isso com o HTML 5 Outliner de Geoffrey
...
Sneddon (http://gsnedders.html5.
<corpo>
org/outliner/), uma ferramenta simples, mas excelente, <h1>Guia do usuário do produto</h1>
que apresenta uma representação visual do esboço <h1>Configurando</h1>
do seu documento. Usando-o para gerar contornos <h1>Recursos básicos</h1>

para as versões 1 e 2 (A e B) <h1>Reprodução de vídeo</h1>


<h1>Recursos avançados</h1>
mostra que, embora seus níveis de cabeçalho h1–h6
</body>
sejam diferentes, ambos resultam neste esboço: </html>

1. Guia do usuário do produto

1. Configurando

2. Recursos básicos

1. Reprodução de vídeo

3. Recursos avançados

Como você pode ver, cada elemento de seção na


Versão 2 B se torna uma subseção de seu h1–h6 mais
próximo ou ancestral de conteúdo de seção (que
também é seção, neste caso). O mesmo
comportamento se aplica a todos os quatro
elementos de conteúdo de seccionamento HTML5 que
mencionei anteriormente (artigo, aparte, navegação e
seção), mesmo quando eles estão misturados.

Em comparação, se a Versão 2 B não tivesse


seções – vamos chamá-la de Versão 3 C – seu
esboço seria muito diferente.

Ou seja, cada título estaria no mesmo nível de


importância, h1, o que significa que não haveria
subtítulos (ou subtítulos):

1. Guia do usuário do produto

2. Configurando

3. Recursos básicos

4. Reprodução de vídeo

5. Recursos avançados

52 Capítulo 3
Machine Translated by Google

D Exemplo de esboço com semântica explícita Dos esboços com o mesmo significado (ou
seja, Versões 1 e 2), ambos são válidos
...
HTML5, mas o segundo é preferível porque
<corpo> os elementos da seção são mais
<artigo>
<h1>Guia do usuário do produto</h1> explícito semanticamente. Na prática, você poderia
<seção> envolver um elemento de artigo em todo o
<h1>Configurando</h1> conteúdo da Versão 2, já que isso é ainda mais
</seção>
apropriado neste contexto (embora o esboço

<seção>
resultante seja um pouco diferente).
<h1>Recursos básicos</h1> A Figura D mostra um exemplo.
<seção>
Não se esqueça também de que cada título será
<h1>Reprodução de vídeo</h1>
</seção>
seguido por textos, imagens e outros conteúdos
</seção> relacionados, sobre os quais você aprenderá à
medida que avança. Mas, por enquanto, deixei
<seção> tudo isso de fora para que você possa se concentrar
<h1>Recursos avançados</h1>
em aprender sobre títulos e contornos.
</seção>
</artigo>
</body> Fazendo o que puder
</html>
no ecossistema atual
Mas espere! Há outro ajuste que você deve fazer
no código. Lembre-se de quando
Eu disse para “manter esse pensamento; em breve
vou explicar porque você deve limitar seus h1s”?
Embora seja verdade que cada elemento de
conteúdo da seção (artigo, aparte, navegação e
seção) possa começar sua hierarquia de títulos
com h1, isso não é obrigatório. Na verdade, em
um futuro próximo, é melhor começar cada um
com um h2 ou menos se eles representarem
um subtítulo de um h1 já existente para um
pedaço de conteúdo relacionado.

Aqui está o porquê.

Existem muitas partes móveis no mundo em


constante evolução da Web. Novas especificações
como HTML5 mudam diariamente até serem
finais (o que leva anos e ainda não aconteceu com
HTML5). Novas versões de navegadores são
lançadas. Novas versões da tela
leitores e outras tecnologias assistivas são
desenvolvidas e lançadas. Nada disso acontece
em perfeita sincronicidade.

Estrutura HTML Básica 53


Machine Translated by Google

Em vez disso, cada navegador tende a adicionar


recursos de forma incremental (em geral, uma
coisa muito boa), e não necessariamente os
mesmos que seus concorrentes (não tão bons),
e certamente não no mesmo cronograma que seus
concorrentes. O mesmo vale para leitores de
tela. Portanto, embora os navegadores modernos
suportem muitos recursos do HTML5, nenhum
deles, no momento em que este livro foi escrito,
expunha o esboço do documento HTML5 aos
leitores de tela, e os leitores de tela não o expunham aos usuários.

Resumindo, isso significa que os leitores de tela


e outras tecnologias assistivas ainda não distinguem
entre um h1 que está diretamente no corpo e um
h1 que fica dentro de um artigo, à parte,
navegação ou seção. Eles são todos h1s de
nível superior em sua perspectiva. Bruce Lawson,
notável evangelista da Web do Opera, foi a primeira
pessoa que conheço a apontar isso
(www.brucelawson.co.uk/2009/
títulos-em-html-5-e-acessibilidade/; esteja
ciente de que algumas outras informações em
este URL está desatualizado porque as
especificações mudaram desde então. Veja
também seu mais recente Introducing HTML5, que
ele escreveu com Remy Sharp).

Enquanto isso, os usuários de leitores de tela não


podem se dar ao luxo de esperar que a Web
atenda às suas necessidades. Eles continuarão a
aproveitar os títulos para obter uma visão geral do
conteúdo de uma página e para navegar nas
páginas como fazem regularmente. Uma hierarquia
significativa de títulos torna isso mais fácil e
proporciona uma melhor experiência para eles em
seu site.

54 Capítulo 3
Machine Translated by Google

E Versão 4 (a abordagem recomendada para Portanto, até que o ecossistema se atualize um


títulos de todas as quatro versões) pouco, você e seus usuários estarão em melhor
situação se usarem títulos que indiquem
...
explicitamente a hierarquia com h1–h6, assim
<corpo>
<artigo> como fariam se os elementos de seccionamento
<h1>Guia do usuário do produto</h1> não estivessem presentes. Law-son e outros na área recomendam isso
<seção>
abordagem, inclusive eu.
<h2>Configurando </h2>
</seção> Vamos ver como fazer E.
O que costumava ser h1s no primeiro nível
<seção>
<h2>Recursos básicos</h2>
dos elementos da seção agora são h2s, e o
<seção> cabeçalho de reprodução de vídeo que está em
<h3>Reprodução de vídeo</h3> uma seção aninhada em outra seção é
</seção> agora um h3 em vez de um h1. O esboço do
</seção>
documento não mudou, apenas os níveis de título.
<seção>
<h2>Recursos Avançados</h2>
Este exemplo demonstra apenas h1–h3, mas use
</seção>
h4–h6 também em suas páginas se seu
</artigo>
conteúdo exigir isso. Por exemplo, um subtítulo
</body>
</html> de Reprodução de Vídeo seria um h4 (com ou
sem um elemento de seccionamento pai, conforme
achar adequado) e assim por diante.

E lembre-se, esta recomendação vale para todos os


elementos de seccionamento – artigo, aparte,
navegação e seção – não apenas aqueles mostrados
no exemplo.

Estrutura HTML Básica 55


Machine Translated by Google

Embrulhando-o
Sugiro reler esta discussão sobre o esboço do
documento HTML5 se alguma coisa não for bem
compreendida. Não é tão complicado quanto
pode parecer. Eu recomendo fortemente que
você crie uma variedade de páginas de teste e
compare os resultados no HTML5 Outliner para
ter uma ideia melhor de como o algoritmo de
estrutura de tópicos funciona. Use o Outliner
também durante o trabalho do projeto, para
garantir que sua estrutura esteja conforme
planejado. Primeiro, certifique-se de validar suas
páginas HTML5 em http://validator.nu/ ou http://
validator.w3.org/ para verificar se há erros de
codificação (consulte “Validando seu código” no Capítulo 20).

Por favor, não fique com a impressão de que você


sempre deve usar um artigo, ou que uma seção
deve sempre (e somente pode) ser aninhada em um
artigo. O exemplo que discutimos era apenas uma
forma de usar esses elementos e, na verdade,
esse mesmo conteúdo poderia ser marcado de
algumas maneiras diferentes e ainda seria HTML5
válido. Explicarei o artigo e a seção mais adiante
neste capítulo e, como você verá, eles têm
algumas aplicações, dependendo do seu
contente.

56 Capítulo 3
Machine Translated by Google

Como o algoritmo Outline do HTML5 ajuda no conteúdo distribuído


Se você acompanhou até agora, viu que - em virtude de estar seccionando o conteúdo e as regras
do algoritmo de esboço do HTML5 - cada artigo, aparte, navegação e seção tem seu próprio
esboço que pode começar com h1 e continue até h6.
Além de permitir muita flexibilidade com os títulos do seu documento, isso tem um benefício não tão óbvio: permite que seu
conteúdo apareça em outras páginas, até mesmo em outros sites, sem causar estragos no esboço do documento pai. E o seu
contorno também permanece intacto.

Hoje em dia, o conteúdo é compartilhado entre sites mais do que nunca. Você tem sites de agregação de notícias, blogs com
feeds RSS, feeds do Twitter e assim por diante. Como você aprenderá em “Criando um Artigo”, o artigo
O elemento representa uma composição independente que pode ser distribuída (não deve ser, apenas que seria apropriado fazê-
lo).

Imagine que o seguinte artigo de um site seja exibido em outro site:

...
<h2>Notícias de toda a Web</h2>

<artigo>
<h1>Adolescente local prefere vinil ao digital</h1>

<p>Uma adolescente local substituiu todas as suas faixas digitais por vinil. “É ÿ legal”, disse
ela, oficialmente.</p>

<h2>Fisgado pelo primeiro álbum</h2>


...
</artigo>
...
Verificando o código com o HTML5 Outliner, você verá isto:

1. Notícias de toda a web

1. Adolescente local prefere vinil em vez de digital


1. Viciado após o primeiro álbum

Portanto, mesmo que o título Local Teen tenha uma classificação mais alta (h1) do que o h2 abaixo, é um subtítulo do h2
porque está contido em um artigo sob esse título. E o Hooked h2 é um sub-subtítulo do News h2, não em pé de igualdade.

O título Notícias pode ser h3, h4 ou qualquer nível de título, e o contorno seria exatamente o mesmo. O mesmo se aplica a Local
Teen e Hooked, desde que Local Teen tenha a classificação mais alta.

Estrutura HTML Básica 57


Machine Translated by Google

Agrupando títulos A Dois títulos relacionados são agrupados.


Neste exemplo, o h2 é um subtítulo do título h1
do artigo . Por estar marcado com o título de
Às vezes, um título tem vários níveis consecutivos,
classificação mais alta, apenas “Giraffe Escapes from
como subtítulos, títulos alternativos ou slogans. Zoo” aparece no esboço do documento, mas ambos
são exibidos no navegador, como esperado B.
Da mesma forma, se um segundo h1 aparecesse
Agrupá-los em um elemento hgroup indica
depois dele no hgroup, ele seria omitido do
que eles estão relacionadosA. Cada hgroup pode contorno, assim como h2. Além disso, como h2 não
conter apenas dois ou mais títulos h1–h6 ; aparece no esboço, o próximo título do artigo poderia ser h2
nenhum outro elemento é permitido. (em vez de h3) e deve ser entendido como um
subtítulo direto de h1, “Girafa escapa do zoológico”.
Apenas a primeira instância do título com
...
classificação mais alta em um hgroup
<corpo>
aparece no esboço do documento (consulte
“Compreendendo o esboço do documento <artigo>
HTML5”). Então esse pode ser outro fator <hgrupo>
decisivo para você ao escolher usar o hgroup. <h1>Girafa escapa do zoológico</h1>
<h2>Animais em todo o mundo se alegram</h2>
Para ficar claro, porém, todos os títulos em um
</hgrupo>
hgroup são exibidos no navegador B.
<p>... [conteúdo do artigo] ...</p>
</artigo>

</body>
</html>

B Ambos os títulos são exibidos no navegador


exatamente como seriam se não estivessem contidos
em um hgroup.

58 Capítulo 3
Machine Translated by Google

Para agrupar dois ou mais títulos:


1. Digite <hgrupo>.
2. Digite <hn>, onde n é um número de
1 a 6, dependendo do nível de importância
do título que se deseja criar.

3. Digite o conteúdo do cabeçalho.


4. Digite </hn> onde n é o mesmo número
usado na etapa 2.
5. Repita as etapas 2 a 4 para quantos
títulos desejar que façam parte do
hgroup. Normalmente, o nível de título
para cada título subsequente aumentaria
em um (por exemplo, de h1 para h2 e
assim por diante).
6. Digite </hgroup>.

Não use hgroup em torno de apenas um título.


Destina-se a pelo menos dois.

Como mencionado, apenas a primeira instância de


o título de classificação mais alta em um hgroup
aparece no esboço do documento. A ordem dos
títulos é irrelevante. Então, se o seu hgroup
tivesse um h3 seguido por um h2, o h2 estaria no
contorno. Normalmente, você ordenará os títulos por
nível de prioridade, portanto, um de classificação
inferior (como h3) não precederia um de classificação
mais alta (como h2). Você pode encontrar exceções
ocasionais.

Estrutura HTML Básica 59


Machine Translated by Google

Página Comum
Construções
Sem dúvida você já visitou dezenas de sites
organizados como o mostrado em A. Retirando o
conteúdo, você pode ver que existem quatro
componentes principais: um cabeçalho com
navegação, um artigo na área de conteúdo principal,
um barra lateral com informações tangenciais e
rodapé B.

Agora, você não pode estilizar uma página como esta


A ou organizá-la conforme mostrado (A e B) sem
CSS. Você começará a aprender CSS no Capítulo 7,
verá como formatar texto e adicionar cores
começando no Capítulo 10, e faça um layout de
múltiplas colunas no Capítulo 11. A Um layout comum com navegação principal na
parte superior, conteúdo principal à esquerda, uma
No entanto, a semântica que se aplica a barra lateral à direita e rodapé na parte inferior. CSS é
essas construções de páginas comuns é necessário para deixar a página assim.
bastante semelhante, independentemente do
layout. Você os explorará na maior parte das
páginas restantes deste capítulo. Trabalhando
do topo da página para baixo, você verá
como usar os elementos de cabeçalho,
navegação, artigo, seção, lado e rodapé para definir a estrutura
de suas páginas e como usar div como um contêiner
genérico para estilos adicionais e outros fins. Exceto
o div, nenhum desses elementos existia até o HTML5.

Você já teve uma ideia de alguns deles em exemplos


de código e discussões anteriores.
B Os tipos de informações comumente encontrados
em uma página. Este é apenas um tipo de arranjo, embora
um comum.
À medida que você aprende sobre esses elementos,
não se apegue muito ao local onde eles são exibidos
nos layouts de amostra e, em vez disso, concentre-
se em seu significado semântico.

Nas páginas seguintes, você também verá alguns


outros elementos, como ul (lista não ordenada) e a
(para links). Isso será explicado adequadamente em
capítulos posteriores.

60 Capítulo 3
Machine Translated by Google

A Este cabeçalho representa o cabeçalho de toda a


página. Ele contém uma lista de links em um navegador
Criando um cabeçalho
elemento para indicar que é um conjunto primário de
Se uma seção da sua página tiver um grupo de
navegação na página. ConsulteC para obter um exemplo
de aplicação do opcional role="banner" a um conteúdo introdutório ou de navegação, marque-o com
cabeçalho de nível de página para fins de acessibilidade. o elemento de cabeçalho .
(Consulte “Marcando Navegação” para obter o valor da
função específico do elemento nav .) Uma página pode ter qualquer número de cabeçalhos
elementos, e seu significado pode variar
...
dependendo do contexto. Por exemplo, um cabeçalho
<corpo>
no topo de uma página ou próximo a ele pode representar
<cabeçalho>
<nenhum> o cabeçalho (às vezes chamado de masthead) de toda
<ul> a página A. Muitas vezes, o cabeçalho da página
<li><a href="#gaudi"> Arquiteto ÿ de inclui o logotipo do site, a navegação principal B, outros
Barcelona </a></li>
links globais e até mesmo uma caixa de pesquisa. Sem
<li lang="es"> <a href="#sagrada- ÿ
familia"> A Sagrada Família</a> ÿ </li>
dúvida, este é o uso mais comum do elemento de
cabeçalho , mas não o confunda com o único.
<li><a href="#park-guell">Parque ÿ
Guell</a></li>
</ul> Um cabeçalho também seria apropriado para marcar
</nenhum> um grupo de conteúdo introdutório ou de
</header> navegação mais profundamente em uma página.
</body> Um exemplo é o índice da seção C (na próxima
</html>
página).

O elemento de cabeçalho é um dos quatro

seccionando os elementos de conteúdo que mencionei


em “Compreendendo o esboço do documento
HTML5”. Isso significa que qualquer cabeçalho h1–h6
dentro de um cabeçalho é considerado dentro do
contexto do cabeçalho – e não da página como um
todo – no que diz respeito ao esboço do documento.
B O cabeçalho no nível da página que contém Portanto, um cabeçalho geralmente inclui o título de sua
a navegação.
seção ( h1–h6 ou hgroup), mas isso não é obrigatório.
Por exemplo, você vê títulos em C , mas não em A.

Estrutura HTML Básica 61


Machine Translated by Google

Para criar um cabeçalho:


1. Coloque o cursor dentro do elemento para
qual você deseja criar um cabeçalho.

2. Digite <cabeçalho>.

3. Digite o conteúdo do cabeçalho, que pode incluir uma


variedade de tipos de conteúdo marcados com
seus respectivos elementos HTML (a maioria dos
quais você aprenderá

C Esta página tem dois cabeçalhos: um que serve como cabeçalho de toda a página e outro como cabeçalho
para o elemento principal do artigo Perguntas frequentes . Observe que o primeiro não tem títulos h1–h6 , mas o
segundo tem. Consulte a última dica desta seção para obter informações sobre o atributo role opcional mostrado
no primeiro cabeçalho.

...
<body>
<header role="banner"> ...
[logotipo do site, navegação, etc.] ... </header>

<artigo>
<cabeçalho>

<h1>Perguntas frequentes</h1> <nav>

<ul>
<li><a href="#answer1">Qual é a sua política de devolução?</
a><li> <li><a href="#answer2">Como encontro um local?</a ><li>
...
</ul>
</nav>
</header>

<!-- os links do cabeçalho apontam para estes


--> <article id="answer1">
<h2>Qual é a sua política de devolução?
</h2> <p> ... [resposta] ...
</p> </artigo>

<article id="answer2">
<h2>Como encontro um local?</h2>
<p> ... [resposta] ... </p> </
article>
...
</article> <!-- fim do artigo pai -->

</body>
</html>

62 Capítulo 3
Machine Translated by Google

sobre no resto do livro). Por exemplo, um


cabeçalho pode conter h1–h6
títulos, um logotipo ou série de logotipos,
navegação, uma caixa de pesquisa e muito mais.

4. Digite </header>.

Não use o cabeçalho desnecessariamente.


Se tudo o que você tem é um h1–h6 ou um hgroup e
nenhum conteúdo complementar digno de ser agrupado
com ele, não há necessidade de envolvê-lo em um cabeçalho na maioria
casos.

Um cabeçalho não é intercambiável com um


título, como nos elementos h1–h6 (consulte “Criando
Títulos”). Cada um tem seu próprio propósito
semântico.

Você não pode aninhar um elemento de


rodapé ou outro cabeçalho dentro de um cabeçalho,
nem pode aninhar um cabeçalho dentro de um rodapé ou endereço
elemento.

Um cabeçalho nem sempre precisa conter um


elemento nav como os exemplos (A
e C), mas na maioria dos casos, provavelmente
acontecerá se o cabeçalho contiver links de
navegação. No caso de C, nav é apropriado em torno
da lista de links de Perguntas Frequentes, já que é um
grupo importante de navegação dentro da página,
conforme discutido em “Marcando Navegação”.

Consulte “Criando contêineres genéricos”


para saber como o cabeçalho substituiu uma das
funções do elemento div desde seus dias anteriores
ao HTML5.

Consulte “Melhorando a acessibilidade com ARIA”


para saber como você pode usar role="banner"
com cabeçalho.

Estrutura HTML Básica 63


Machine Translated by Google

Marcação de navegação R Esses links (os elementos a ) representam um


conjunto importante de navegação, então aninhei-os em
Versões anteriores do HTML não tinham um um elemento nav . Normalmente, você marcará uma lista
de links com o elemento ul (lista não ordenada), a menos
elemento que representa explicitamente uma seção que seus links sejam links de localização atual. Nesse
dos principais links de navegação, mas o HTML5 caso, use uma ol (lista ordenada). Consulte o Capítulo 15
para obter mais informações sobre listas. O atributo
representa: o elemento nav . Os links em uma
role não é obrigatório, mas pode melhorar a acessibilidade.
navegação podem apontar para o conteúdo da Veja a última dica desta seção para obter informações
página A, para outras páginas ou recursos, ou sobre como aplicar role="navigation" à navegação.
ambos. Seja qual for o caso, use navegação
...
apenas para os grupos de links mais importantes do
<corpo>
seu documento, não para todos eles. <cabeçalho>

Se você examinou atentamente o código da <nav role="navegação">


<ul>
seção anterior, deu uma olhada na navegação
<li><a href="#gaudi"> Arquiteto ÿ de
elemento em ação. Eu carreguei esse código Barcelona </a></li>
amostra para esta página, destacando nav A. O <li lang="es"> <a href="#sagrada- ÿ
elemento nav não impõe nenhuma formatação familia"> A Sagrada Família</a> ÿ </li>

padrão em seu conteúdo B.


<li><a href="#park-guell">Parque ÿ
Guell</a></li>
</ul>
</nenhum>

</header>
</body>
</html>

64 Capítulo 3
Machine Translated by Google

Para designar um grupo de


links como navegação importante:
1. Digite <nav>.

2. Digite sua lista de links estruturados como


ul (lista não ordenada), a menos que a
B Nossa navegação parece bastante simples por padrão. ordem dos links seja significativa (como
Os marcadores não são um produto do elemento nav , navegação estrutural); nesse caso, você
que não possui nenhum estilo padrão além de começar em deve estruturá-los como uma ol (lista ordenada).
sua própria linha. Os marcadores são exibidos porque cada
link está em um elemento li (um item de lista). Com CSS,
(Veja os Capítulos 6 e 15 para aprender
você pode desativar os marcadores ou mostrar outros sobre links e listas, respectivamente.)
diferentes, bem como dispor os links horizontalmente, alterar
sua cor, torná-los parecidos com botões e muito mais. 3. Digite </nav>.
Você começará a aprender sobre CSS no Capítulo 7.

Se você tem alguma experiência com HTML


ou XHTML, você provavelmente está acostumado a
estruturar seus links em um elemento ul ou ol , conforme
apropriado. No HTML5, nav não substitui essa prática
recomendada; continue a usar esses elementos e
simplesmente envolva-os com uma navegação A.

Embora os leitores de tela em geral ainda estejam


se atualizando com a nova semântica do HTML5, o elemento
nav pode ajudá-los a identificar a navegação importante da
sua página e permitir que os usuários acessem-na por meio
do teclado.
Isso torna sua página mais acessível, melhorando a
experiência dos visitantes.

A especificação HTML5 recomenda não agrupar


Faça ping de links de rodapé de páginas auxiliares,
como “Termos de Uso” e “Política de Privacidade”
em uma navegação, o que faz sentido. Às vezes, porém,
o rodapé da sua página reitera a navegação global de
nível superior ou inclui outros links importantes
como “Localizador de lojas” e “Carreiras”. Na maioria
dos casos, recomendo colocar esses tipos de links de
rodapé em um arquivo de navegação.

HTML5 não permite aninhar uma navegação


dentro de um elemento de endereço .

Consulte “Melhorando a acessibilidade com ARIA”


para aprender como usar role="navigation"
com navegação A.

Estrutura HTML Básica 65


Machine Translated by Google

Uma análise mais aprofundada da navegação

Como mencionei anteriormente, só porque você tem um grupo de links em sua página não significa que ele deva estar
contido em uma navegação.

O exemplo de página de notícias a seguir inclui quatro listas de links, dos quais apenas dois são considerados
importantes o suficiente para justificar serem agrupados em uma navegação. (Como você verá, abreviei partes do
código.)

...

<corpo>
<cabeçalho>

<!-- o logotipo do site pode ir aqui --> <!--

navegação global do site -->

<nenhum>

<ul> ... </ul>

</nenhum>

</header>

<div id="principal">

<h1>Artes e artes Entretenimento</h1>


<artigo>

<h1>A abertura da galeria apresenta o inspirado, inspirador</h1> <p>...

[conteúdo da história] ... </p>

<à parte>

<h1>Outras histórias</h1>

<!-- não incluído em navegação -->

<ul> ... [links de histórias] ... </ul>


</aside>

</artigo>

</div>

66 Capítulo 3
Machine Translated by Google

Uma análise mais aprofundada da navegação (continuação)

<aside id="barra lateral">

<nav><!-- navegação secundária -->


<ul>
<li><a href="/arts/movies/">Filmes</a></li>
<li><a href="/arts/music/">Música</a></li>
...
</ul>
</nenhum>

</aside>

<rodapé>

<!-- Links auxiliares não agrupados em navegação. -->


<ul> ... </ul>
</footer>

</body>
</html>
A navegação secundária no aparte (veja “Especificando um aparte”) permite ao usuário navegar para outras páginas
no diretório Arts & Entertainment, constituindo assim uma importante seção de navegação da página. Porém, as Outras
Histórias além dos links não.

Então, como você decide quando um grupo de links merece navegação? Em última análise, é um julgamento baseado
na organização do seu conteúdo. No mínimo, marque a navegação global do seu site (ou seja, o que permite aos
usuários acessar as seções do site) com nav. Freqüentemente, mas nem sempre, essa navegação específica
aparece dentro de um elemento de cabeçalho no nível da página (consulte “Criando um cabeçalho”).

Estrutura HTML Básica 67


Machine Translated by Google

Criando um Artigo A Abreviei o conteúdo do artigo e a navegação


código da seção anterior para mantê-lo simples.
Outro elemento novo graças ao HTML5 é o artigo A. Você pode ver a versão completa do código da página
no site do livro em www.bruceontheloose .com/htmlcss/
Você já viu alguns exemplos dele em jogo. Agora examples/. Embora este exemplo inclua apenas
vamos aprender mais sobre o que o motiva. parágrafos e imagens, um artigo
pode conter uma variedade de tipos de conteúdo,
como vídeo, figuras, listas e muito mais.
Com base no nome, você adivinharia, com razão, que
...
pode usar artigo para conter conteúdo como um
<corpo>
artigo de jornal. No entanto, não se limita a isso. No <cabeçalho>
HTML5, “artigo” é mais parecido com “item”. <nav role="navegação">
... [ul com links] ...
</nenhum>
Veja como o HTML5 o define: </header>
<artigo>
O elemento article representa uma
<h1 id="gaudi">Arquiteto de Barcelona</h1>
composição independente em um
documento, página, aplicativo ou site e é, em <p>Os incríveis edifícios de Antoni Gaudí ÿ
princípio, distribuível ou reutilizável de forma trazem milhões de turistas para ÿ
independente, por exemplo, em distribuição. Barcelona todos os anos.</p>
Pode ser uma postagem em um fórum, um
<p>O inconformismo de Gaudí, já ÿ
artigo de revista ou jornal, uma entrada
visível na sua adolescência, aliado ÿ à sua
de blog, um comentário enviado por um usuário, devoção silenciosa mas firme à ÿ igreja,
um widget ou gadget interativo ou qualquer constituiu uma base única ÿ para os seus
outro item de conteúdo independente. pensamentos e ideias. Sua ÿ busca
pela simplicidade, baseada em suas ÿ
observações cuidadosas da natureza, são
Outros exemplos de artigos podem incluir uma ÿ bastante evidentes em seu trabalho, desde
crítica de filme ou música, um estudo de caso, uma o ÿ <a href="#park-guell">Parque Guell</
descrição de produto e muito mais. Você pode ter a> ÿ e suas incríveis esculturas e ÿ
mosaicos, à Igreja da <a href= ÿ "#sagrada-
ficado surpreso ao saber que também pode ser um
familia"> Sagrada Família</a> ÿ e suas
widget ou gadget interativo, mas esses também são itens torres orgânicas e bulbosas.</p>
de conteúdo independentes e redistribuíveis.
<h2 id="sagrada-familia" lang="es">A ÿ
Sagrada Família</h2>

... [imagem e parágrafos] ...

<h2 id="park-guell">Parque Guell</h2>

... [imagem e parágrafos] ...


</artigo>

</body>
</html>

68 Capítulo 3
Machine Translated by Google

Para criar um artigo:

1. Digite <artigo>.
2. Digite o conteúdo do artigo, que
pode incluir qualquer número de elementos,
como parágrafos, listas, áudio, vídeo,
imagens, figuras e muito mais.
3. Digite </artigo>.

Como você aprendeu em


“Compreendendo o esboço do documento
HTML5”, o artigo é um dos quatro elementos de
conteúdo de seção, juntamente com cabeçalho, seção e lado.

Você pode aninhar um artigo dentro de outro,


desde que o artigo interno esteja relacionado ao artigo
como um todo. Porém , você não pode aninhar um
artigo dentro de um elemento de endereço .

Uma página pode conter vários artigos


elementos (ou nenhum). Por exemplo, a página
inicial de um blog normalmente inclui
B Agora a página tem cabeçalho, navegação e artigo algumas das postagens mais recentes; cada
elementos, bem como seu conteúdo. O artigo um poderia ser seu próprio artigo.
os títulos podem ter um tamanho diferente por
padrão, dependendo do navegador. Você pode padronizar Não é obrigatório que um artigo tenha um ou
sua aparência nos navegadores com CSS (veja mais elementos de seção . É perfeitamente válido
o Capítulo 10). deixar que os elementos h1–h6 dentro de um
artigo sejam independentes, embora ao definir
seções você esteja tornando a semântica do artigo
mais explícita. E cada seção
pode ter sua própria hierarquia de níveis de títulos,
conforme discutido em “Compreendendo o
esboço do documento HTML5”.

Os elementos do artigo e da seção são


facilmente (e com razão) confundidos entre si,
e é por isso que citei diretamente as definições
do HTML5; Eu não queria que você aprendesse
sobre eles através de um filtro. Eu discuto a seção
e escolher entre os dois em “Definindo uma Seção”.

Consulte “Melhorando a acessibilidade com ARIA”


para saber como você pode usar role="main"
com o artigo sob uma determinada circunstância.
Seria apropriado incluí-lo no artigo em A porque é
o contêiner do conteúdo principal da página, mas o
omiti para evitar dar a impressão de que role="main"

é adequado para todos os elementos do artigo .

Estrutura HTML Básica 69


Machine Translated by Google

Mais exemplos de artigos


O exemplo anterior A é apenas uma maneira de usar o artigo. Vamos dar uma olhada em mais algumas
possibilidades.

Exemplo 1 (artigo básico):

<artigo>

<h1>A Diversidade de Papua Nova Guiné</h1>

<p>Papua Nova Guiné é o lar de mais de 800 tribos e línguas...</p>

... [resto do conteúdo da história] ...

<footer> <!-- o rodapé do artigo, não o da página -->

<p>Leandra Allen é jornalista freelancer formada em ÿ antropologia pela Universidade de


Copenhague.</p>

<endereço>

Você pode contatá-la em <a href="mailto:[email protected]"> ÿ


[email protected]</ a>.

</endereço>

</footer>

</artigo>

Observe o uso dos elementos rodapé e endereço (veja as discussões sobre eles neste capítulo e no Capítulo 4,
respectivamente). Aqui, o endereço se aplica apenas ao artigo pai (aquele mostrado), não à página ou a quaisquer
artigos aninhados nesse artigo, como os comentários do leitor no Exemplo 2.

O Exemplo 2 demonstra elementos de artigo aninhados na forma de comentários enviados pelo usuário ao
artigo pai, exatamente como você vê na seção de comentários de blogs ou sites de notícias. Também mostra um
uso para o elemento de seção (veja “Definindo uma Seção”) e o elemento de tempo , abordado no Capítulo 4.

70 Capítulo 3
Machine Translated by Google

Mais exemplos de artigos (continuação)


Exemplo 2 (artigos aninhados):
<artigo>

<h1>A Diversidade de Papua Nova Guiné</h1>

... [conteúdo do artigo principal] ...

<rodapé>

... [rodapé do artigo principal] ...

</footer>

<seção>

<h2>Comentários do leitor</h2>
<artigo>

<footer>travelgal escreveu em <time datetime="2011-11-17" ÿ pubdate>17 de


novembro de 2011</time>:</footer>

<p>Ótimo artigo! Sempre tive curiosidade sobre Papua Nova ÿ Guiné.</p>

</artigo>

<artigo>

... [próximo comentário do leitor] ...

</artigo>

</seção>

</artigo>

Estas são apenas algumas maneiras mais comuns de aproveitar o artigo e seus elementos complementares.

Estrutura HTML Básica 71


Machine Translated by Google

Definindo uma seção R O código é o mesmo de antes, exceto que


envolvi uma seção em torno de cada uma das
duas seções do artigo que segue a introdução.
O elemento article tem um primo menos
Simplifiquei o código novamente por questões de
semanticamente específico, a seção, que brevidade.
é outro dos elementos exclusivos do HTML5.
...
Em parte, o HTML5 define a seção da seguinte forma:
<corpo>
<cabeçalho>
O elemento de seção representa uma
<nav role="navegação">
seção genérica de um documento ou
... [ul com links] ...
aplicativo. Uma seção, neste contexto, é </nenhum>

um agrupamento temático de </header>


conteúdo, normalmente com o título A.
<artigo>
Exemplos de seções seriam os capítulos, <h1 id="gaudi">Arquiteto de Barcelona</h1>
as diversas páginas com guias em uma
caixa de diálogo com guias ou as seções <p>Os incríveis edifícios de Antoni Gaudí ÿ
numeradas de uma tese. Um site trazem milhões de turistas para ÿ
Barcelona todos os anos.</p>
a página inicial pode ser dividida em
seções para introdução, notícias e ... [outro parágrafo introdutório] ...
informações de contato. <seção>

Os elementos do artigo e da seção são <h2 id="sagrada-familia" lang="es">A ÿ


Sagrada Família</h2>
bastante semelhantes. Se você não tiver
certeza de como diferenciar os dois, consulte <p><img src="img/towers.jpg"
a barra lateral “Como você decide entre o artigo ÿ width="75" height="100" alt= ÿ
e seção?” "Torres da Sagrada Família" /> A ÿ
obra-prima inacabada e de nome
complicado e curiosamente ÿ que é ÿ
Para definir uma seção: o Templo Expiatório da ÿ Sagrada
Família é o edifício ÿ mais visitado de
1. Digite <seção>.
Barcelona. Nele, Gaudí ÿ combina a sua
2. Digite o conteúdo da seção, que visão da natureza e ÿ da arquitetura com
pode incluir qualquer número de elementos, a sua devoção ÿ à sua fé. A Sagrada
Família ÿ atrai até mesmo os não
como parágrafos, listas, áudio, vídeo,
religiosos para ÿ suas portas, em grande
imagens, figuras e muito mais.
parte devido à sua ÿ história trágica e ao
3. Digite </seção>. seu estado ainda ÿ inacabado,
dos quais os ÿ sempre presentes
andaimes e guindastes ÿ são lembranças
permanentes.</p>
</seção>

<seção>

<h2 id="park-guell">Parque Guell</h2>

... [outra imagem e parágrafos] ...


</seção>
</artigo>
</body>
</html>

72 Capítulo 3
Machine Translated by Google

Como você aprendeu em


“Compreendendo o esboço do documento
HTML5”, seção é um dos quatro elementos de
conteúdo de seção junto com navegação, artigo e lateral.

Por padrão, você pode não ver diferença


ao visualizar uma página com seções (ou artigos,
nesse caso), mas o importante é que você
fortaleça a semântica do seu documento usando-
as . seção de estilo e elementos de artigo como
você quiser com CSS.

Tenha em mente que a seção não é um


contêiner genérico como div, porque a seção
transmite significado e div não tem absolutamente
nenhum significado semântico (veja “Criando
Containers Genéricos”).

Há vários exemplos ao longo deste capítulo


para ajudá-lo a ter uma ideia de como usar o artigo
e a seção (de diversas maneiras).

B Agora a página possui elementos de cabeçalho, Consulte “Melhorando a acessibilidade com


navegação, artigo e seção , bem como seus ARIA” para saber como você pode usar role="main"
conteúdos. A renderização padrão é a mesma de antes com a seção sob uma determinada circunstância.
de você adicionar os elementos da seção .

Como você decide entre artigo e seção?


Citei deliberadamente as definições de seção e artigo do HTML5 (consulte “Criando um artigo”) para ajudá-lo a entender
a distinção, porque às vezes ela é sutil. Pense neles desta forma. O seu conteúdo é um conteúdo independente ou um
widget que seria apropriado para distribuição? Se sim, use o artigo. (Caso contrário, na maioria dos casos, use a seção,
mas consulte “Criando contêineres genéricos” para saber quando usar div .) Isso não significa que você precisa distribuir
ou distribuir o conteúdo do artigo , apenas que o conteúdo é adequado para isto.

Se você ainda acha que o artigo e a seção às vezes parecem muito semelhantes, não se preocupe, você não está
sozinho. Mesmo desenvolvedores experientes às vezes aplicam esses dois elementos de maneira diferente.

Conforme mencionado no Capítulo 1, nem sempre há uma escolha certa e uma escolha errada quando se trata de
marcar seu conteúdo, apenas na maioria das vezes. As outras vezes se resumem a decisões pessoais sobre quais
elementos HTML você acha que melhor descrevem seu conteúdo.

Portanto, pense cuidadosamente ao decidir entre artigo e seção, mas não se preocupe se você acertará sempre. Às
vezes é um pouco subjetivo e, de qualquer forma, sua página continuará funcionando. Além disso, ninguém vai bater à sua
porta no meio da noite.

Bem, eu poderia, mas isso é só porque está escuro e assustador lá fora.

Estrutura HTML Básica 73


Machine Translated by Google

Um exemplo de seção sem artigo Até agora você viu


exemplos de seção aninhada em um artigo A. Esse é apenas um uso do
elemento.

No seguinte exemplo ligeiramente modificado da especificação HTML5, você vê a seção usada sem artigo.
(Você também terá uma visão antecipada das listas ordenadas em ação. Saiba mais sobre ol e outros
elementos da lista no Capítulo 15.)
...
<body>

<h1>Programa de Pós-Graduação</h1>

<seção>

<h2>Cerimônia</h2>
<ol>
<li>Procissão de Abertura</li>
<li>Discurso do orador da turma</li>
<li>Discurso do Presidente da Turma</
li> <li>Apresentação dos Diplomas</li>
<li>Discurso de encerramento do Diretor</li>
</ol>
</seção>

<seção>

<h2>Graduados (em ordem alfabética)</h2>


<ol>
<li>Molly Carpenter</li>
<li>Anastasia Lúcio</li>
<li>Ebenezar McCoy</li>
<li>Adição de Murphy</li>
<li>Thomas Raith</li>
<li>Susan Rodríguez</li>
</ol>
</seção>

</body>
</html>

74 Capítulo 3
Machine Translated by Google

R Este aparte, que apresenta informações sobre


as maravilhas arquitetônicas de Barcelona, está
Especificando um aparte
tangencialmente relacionado ao conteúdo de Antoni
Às vezes, você tem uma seção de conteúdo
Gaudí que é o foco da página, mas também pode ser
independente. Eu poderia ter aninhado dentro do artigo que está tangencialmente relacionada ao
já que estão relacionados, mas resolvi colocá-lo depois conteúdo principal da sua página, mas que
do artigo para tratá-lo visualmente posteriormente
poderia ser independente A. Como você indicaria
como uma barra lateral C. O role="complementar" ao
lado é opcional, mas pode melhorar a acessibilidade. isso semanticamente?
Veja a última dica para mais informações.

...
<corpo>

<cabeçalho>

<nav role="navegação">
... [ul com links] ...
</nenhum>

</header>

<artigo>
<h1 id="gaudi">Arquiteto de Barcelona</h1>
... [parágrafos introdutórios] ...

<seção>
<h2 id="sagrada-familia" lang="es">A Sagrada Família</h2>
... [imagem e parágrafo] ...
</seção>

<seção>
<h2 id="park-guell">Parque Guell</h2>
... [outra imagem e parágrafos] ...
</seção>
</artigo>

<aside role="complementar">
<h1>Maravilhas Arquitetônicas de Barcelona</h1>

<p>Barcelona é o lar de muitas maravilhas arquitetônicas além da obra de Gaudí. Alguns deles ÿ incluem:</p>

<ul>
<li lang="es">Arco do Triunfo</li>
<li>A catedral <span lang="es">(La Seu)</li>
<li lang="es">Grande Teatro do Liceu</li>
<li lang="es">Pavilhão Mies van der Rohe</li>
<li lang="es">Santa Maria do Mar</li>
</ul>

<p>Crédito: <a href="http://www.barcelona.de/en/barcelona-architecture-buildings.html" ÿ rel="external">


<cite>Barcelona.de</cite></a >.</p>
</aside>

</body>
</html>

Estrutura HTML Básica 75


Machine Translated by Google

Até o HTML5, não havia como fazer isso


explicitamente. Agora, você tem o elemento
lateral B.
É comum pensar em um aparte como um

barra lateral C, mas você pode colocar um lado


elemento em vários locais da sua página, dependendo
do contexto. Pode ser uma caixa (conceitual ou
literalmente) dentro do próprio conteúdo principal,
na mesma coluna, mas não aninhada no conteúdo
principal, ou em (ou como) uma coluna secundária
como uma barra lateral. Exemplos de aparte incluem
uma citação, uma barra lateral, uma caixa de links
para artigos relacionados em uma notícia
site, publicidade, grupos de elementos de
navegação (por exemplo, um blog roll), um feed
do Twitter e uma lista de produtos relacionados
em um site de comércio.

B O aparte aparece abaixo do artigo porque o segue


no próprio HTML A. Como você pode ver, os
navegadores não aplicam nenhuma formatação
especial a um aparte por padrão (exceto iniciá-los
em sua própria linha). No entanto, você tem
controle total sobre sua aparência com CSS C.

76 Capítulo 3
Machine Translated by Google

Para especificar um aparte:

1. Digite <à parte>.


2. Digite o conteúdo do aparte , que pode
incluir qualquer número de elementos,
como parágrafos, listas, áudio,
vídeo, imagens, figuras e muito mais.
3. Digite </aside>.

Embora um modo de lado seja usado


para marcar o conteúdo em uma barra lateral C, o lado
o elemento em si não afeta o layout da página B.

Se você usar um ou mais apartes na


barra lateral ou como barra lateral, coloque o
conteúdo da barra lateral após o conteúdo
C Ao aplicar CSS à página finalizada, você pode fazer principal da sua página no HTML A. É melhor
com que o lado (que começa com “Maravilhas para fins de SEO e acessibilidade colocar o
Arquitetônicas de Barcelona”) apareça ao lado do conteúdo mais importante primeiro. Você pode
conteúdo principal, em vez de abaixo dele. alterar a ordem em que eles são exibidos no navegador com CSS.
Portanto, neste caso, você tratou o lado como uma barra
lateral. (Você aprenderá como fazer um layout CSS de duas Use o elemento figura (consulte o Capítulo 4),
colunas no Capítulo 11.)
sem deixar de lado, para marcar figuras
relacionadas ao seu conteúdo, como um quadro,
um gráfico ou uma foto inserida com uma legenda.

HTML5 não permite aninhar um aparte


dentro de um elemento de endereço .

Consulte “Melhorando a
acessibilidade com ARIA” para saber
como você pode usar role="complementary" com aparte.

Estrutura HTML Básica 77


Machine Translated by Google

Outros exemplos à parte


Conforme mencionado, o lado pode aparecer na mesma coluna do conteúdo principal, aninhado no conteúdo
principal ou em uma barra lateral.

O exemplo 1 mostra um aparte aninhado em seu conteúdo relacionado.

Exemplo 1 (aninhado no conteúdo principal):

...

<corpo>
<artigo>

<h1>A Diversidade de Papua Nova Guiné</h1>


... [conteúdo do artigo] ...
<à parte>

<h1>Fatos rápidos sobre Papua Nova Guiné</h1>


<ul>
<li>O país tem 38 das 43 aves do paraíso conhecidas</li>
<li>Embora bastante tropical em algumas regiões, outras ocasionalmente
ÿ experimente nevascas.</li>
...
</ul>
</aside>
... [mais conteúdo do artigo] ...
</artigo>

</body>
</html>
Esse mesmo artigo pode incluir uma citação extraída do texto do artigo. Isso também seria um aparte. Ou poderia
ter à parte “Histórias Relacionadas” contendo uma lista de links para outros ensaios sobre o país ou região circundante
(Indonésia, Austrália e assim por diante). Alternativamente, esse lado poderia estar em uma coluna de página diferente,
em vez de aninhado no artigo.

Você já viu um exemplo de aparte em uma barra lateral (A e C). Agora, vamos considerar um exemplo de portfólio
de design ou conjunto de estudos de caso, em que cada página HTML se concentra em um único projeto e você fornece
links (aninhados em uma navegação) para as outras páginas do projeto em uma coluna adjacente (controlada por CSS). ,
não simplesmente em virtude de organizar o código conforme mostrado no Exemplo 2).

78 Capítulo 3
Machine Translated by Google

Outros exemplos à parte (continuação)


Exemplo 2 (além de não aninhado no conteúdo principal e contendo uma navegação):

...

<corpo>
<!-- conteúdo principal da página -->
<artigo>

<h1>... [nome do projeto] ...</h1>


<figure>... [foto do projeto] ...</figure> <p>...
[redação do projeto] ... </p>
</artigo>

<!-- este aparte não está aninhado no artigo -->

<à parte>

<h1>Outros Projetos</h1>
<nenhum>

<ul>

<li><a href="habitat-for-humanity.html">Habitat para a Humanidade ÿ


folheto</a></li>

<li><a href="royal-philharmonic.html">Royal Philharmonic Orchestra ÿ site</a></li>

...

</ul>
</nenhum>

</aside>

</body>
</html>
Seria perfeitamente adequado aninhar isso também no artigo do projeto , uma vez que eles estão relacionados.

Estrutura HTML Básica 79


Machine Translated by Google

Criando um rodapé A Este rodapé representa o rodapé de toda a


página, já que seu ancestral mais próximo é o corpo
Quando você pensa em rodapé, provavelmente pensa elemento. Nossa página agora possui elementos de cabeçalho,
navegação, artigo, seção, lado e rodapé . Nem todas as
em rodapé de página. Rodapé do HTML5
páginas exigem todos eles, mas eles representam as construções
O elemento é apropriado para isso, mas como o de páginas primárias disponíveis em HTML.
cabeçalho, você também pode usá-lo em outro lugar.
...
O elemento footer representa um rodapé <corpo>
<cabeçalho>
para o artigo mais próximo, aparte,
<nav role="navegação">
blockquote, corpo, detalhes, fieldset, figura,
... [ul com links] ...
nav, seção ou elemento td no qual está </nenhum>
aninhado. É o rodapé do </header>
página inteira somente quando seu ancestral mais
<artigo>
próximo for o corpo (A e B). E se um rodapé
<h1 id="gaudi">Arquiteto de Barcelona</h1>
envolve todo o conteúdo de sua seção (um artigo,
... [parágrafos introdutórios] ...
por exemplo), representa algo como um apêndice,
índice, colofão longo ou contrato de licença longo, <seção>
dependendo de seu conteúdo. <h2 id="sagrada-familia" lang="es">A ÿ Sagrada
Família</h2>
... [imagem e parágrafo] ...
</seção>

<seção>
<h2 id="park-guell">Parque Guell</h2>
... [outra imagem e parágrafos] ...
</seção>
</artigo>

<aside role="complementar">
<h1>Maravilhas arquitetônicas de Barcelona ÿ </
h1>
... [resto à parte] ...
</aside>

<rodapé>
<p><small>&copy; Direitos autorais 2011</small>
ÿ </p>
</footer>

</body>
</html>

80 Capítulo 3
Machine Translated by Google

Para criar um rodapé:


1. Coloque o cursor dentro do elemento para
qual você deseja criar um rodapé.

2. Digite <rodapé>.

3. Digite o conteúdo do rodapé.

4. Digite </footer>.

Um rodapé normalmente inclui


informações sobre sua seção, como links para
documentos relacionados, informações sobre
direitos autorais, seu autor e itens semelhantes.
Consulte os Exemplos 1 e 2 na barra lateral “Outros exemplos de rodap

B O próprio elemento de rodapé não impõe nenhuma Um rodapé não precisa estar no final do
formatação ao texto por padrão. Aqui, o aviso de elemento que o contém, embora geralmente esteja.
copyright é menor que o texto normal porque está
aninhado em um pequeno elemento para representar
É inválido aninhar um cabeçalho ou outro
semanticamente a impressão legal (consulte o Capítulo 4).
rodapé dentro de um rodapé. Além disso, você
Como tudo mais, você pode alterar o tamanho da fonte
com CSS. não pode aninhar um rodapé em um cabeçalho ou endereço
elemento.

Consulte “Criando contêineres genéricos”


para saber como o rodapé substituiu um dos div
funções do elemento desde seus dias pré-HTML5.

Consulte “Melhorando a
acessibilidade com ARIA” para saber
como você pode usar role="contentinfo" com
rodapé em uma determinada circunstância. Seria
apropriado incluí-lo no rodapé em A porque
representa o rodapé de toda a página, mas omiti
para evitar dar a impressão de que role="contentinfo"
é adequado para todos os rodapés
elementos. Consulte “Outros exemplos de rodapé ”
para obter um exemplo que mostra a distinção e
usa a função corretamente.

Estrutura HTML Básica 81


Machine Translated by Google

Outros exemplos de rodapé Você viu

um pequeno exemplo de rodapé para a página inteira (A e B). Aqui está outro rodapé de página, mas com mais conteúdo.

Exemplo 1 (como rodapé da página):

...

<corpo>
... [cabeçalho e conteúdo da página] ...

<!-- este é um rodapé de página porque body é seu ancestral mais próximo -->
<footer role="contentinfo">
<p><small>&copy; Copyright 2011 The Corporation, Inc.</small></p>

<ul>
<li><a href="terms-of-use.html">Termos de Uso</a></li>
<li><a href="privacy-policy.html">Política de Privacidade</a></li>
</ul>
</footer>
</body>
</html>
O próximo exemplo demonstra um rodapé no contexto de uma seção de página (neste caso, um artigo) e um segundo
rodapé para toda a página. (Veja “Mais exemplos de artigos ” para uma explicação do escopo do elemento de endereço aqui.)

Exemplo 2 (como rodapé de uma seção da página e de toda a página):


...

<corpo>
...
<artigo>

<h1>... [cabeçalho do artigo] ...</


h1> <p>... [conteúdo do artigo] ...</p>

82 Capítulo 3
Machine Translated by Google

Outros exemplos de rodapé (continuação)


<!-- o rodapé do artigo -->

<rodapé>

<p>Leandra Allen é jornalista freelance e se formou ÿ em antropologia pela Universidade de


Copenhague.</p>

<endereço>

Você pode contatá-la em <a href="mailto: leandra@therunningwriter. ÿ com">


[email protected]</a>.

</endereço>

</footer>

</artigo>

<!-- o rodapé da página -->

<footer id="footer-page" role="contentinfo">

... [direitos autorais, termos de uso, política de privacidade] ...

</footer>

</body>

</html>

O id="footer-page" (você pode especificar qualquer id válido) no rodapé da página é opcional e serve
apenas para diferenciá-lo do outro rodapé para controle de estilo. Observe que apenas o rodapé da página
recebe o opcional role="contentinfo". Consulte “Melhorando a acessibilidade com ARIA” para saber mais
sobre esta função.

Estrutura HTML Básica 83


Machine Translated by Google

B Agora um div envolve todo o conteúdo. A


Criando Genérico semântica da página permanece inalterada, mas agora

Containers tenho um contêiner genérico ao qual posso conectar


alguns estilos com CSS C.

Às vezes você precisa envolver um contêiner ...


em torno de um segmento de conteúdo porque <corpo>
deseja aplicar algum estilo com CSS ou
talvez um efeito com JavaScript. Sua página <div>
<cabeçalho>
simplesmente não seria a mesma sem ele A.
<nav role="navegação">
Mas, ao avaliar o conteúdo, você ... [ul com links] ...
determina que usar artigos como artigo, </nenhum>

seção, aparte, navegação ou outros </header>

elementos não seria semanticamente apropriado.


<artigo>
O que você realmente precisa é de um
<h1 id="gaudi">Arquiteto de Barcelona ÿ </h1>
contêiner genérico, sem nenhum significado
semântico. Esse contêiner é o elemento div
... [parágrafos introdutórios] ...
(pense em uma “divisão”) B. Com uma div
instalada, você pode aplicar o estilo desejado C <seção>
... [título, imagem e ÿ
ou efeito JavaScript para ele. Não deixe de ler
parágrafo] ...
a barra lateral para saber mais sobre quando
</seção>
use div em suas páginas.
<seção>
... [título, outra imagem e ÿ parágrafos] ...

</seção>
</artigo>

<aside role="complementar">
<h1>Maravilhas arquitetônicas de ÿ
Barcelona</h1>
... [resto à parte] ...
</aside>

<rodapé>
... [direito autoral] ...
</footer>
</div>

</body>
</html>

A Consegui esse design sem nenhum div


elementos da página. Mas ao adicionar uma div ao redor
de todo o conteúdoB da página, agora tenho um
contêiner genérico ao qual posso aplicar mais alguns
estilos (veja os resultados emC).

84 Capítulo 3
Machine Translated by Google

Para criar um contêiner genérico:


1. Digite <div>.

2. Crie o conteúdo do contêiner, que pode incluir


qualquer número de elementos.

3. No final do contêiner, digite </div>.

Assim como cabeçalho, rodapé,


artigo, seção, aparte, nav, h1–h6, p e muitos
outros, div é exibido automaticamente em uma
nova linha por padrão.

div também é útil ao implementar certas


interações ou efeitos com JavaScript.
Por exemplo, exibir uma foto ou caixa de diálogo
em uma sobreposição semitransparente que
cubra a página (a sobreposição normalmente é um div).
C Um elemento div não tem nenhum estilo próprio
por padrão, exceto que ele começa em uma nova
linha D. No entanto, você pode aplicar estilos a div Apesar de enfatizar que o HTML descreve
para implementar seus designs. Aqui, adicionei o o significado do seu conteúdo, div não é o único
fundo azul claro e uma sombra de caixa ao div. elemento que não tem valor semântico. O elemento
Isso me permitiu alterar o plano de fundo do span é a contraparte do div . Enquanto div é um
elemento body para roxo para que o conteúdo contêiner sem semântica para blocos de conteúdo,
aparecesse. Também adicionei uma borda fina ao lado.
span (escrito como <span>o conteúdo vai aqui) é um
Você pode ver como consegui isso no HTML e CSS da página (www.
contêiner para frases, como dentro de um elemento p
bruceontheloose.com/htmlcss/examples/).
para parágrafos. Veja mais sobre span no Capítulo
4.

Consulte “Melhorando a acessibilidade com ARIA”


para saber como você pode usar funções de
referência com div.

D A mesma página sem CSS aplicado ao div, aos


títulos, aos parágrafos ou a qualquer outro elemento.
Como você pode ver, o div não faz nada parecer
sofisticado por si só.

Estrutura HTML Básica 85


Machine Translated by Google

Um pouco da história sobre div e quando usá-lo em HTML5


Dos elementos estruturais apresentados neste capítulo, div é o único além de h1–h6 que é anterior ao HTML5. Até
o HTML5, div era a escolha de fato para agrupar partes de conteúdo, como cabeçalho, rodapé, conteúdo principal,
inserções e barras laterais de uma página, para que você pudesse estilizá-los com CSS. Mas div não tinha significado
semântico naquela época, e ainda não tem hoje.

É por isso que o HTML5 introduziu cabeçalho, rodapé, artigo, seção, lado e navegação. Esses tipos de blocos de
construção eram tão predominantes nas páginas da Web que mereciam seus próprios elementos com
significado. div não desaparece no HTML5, você terá menos ocasiões para usá-lo do que no passado.

Vejamos alguns casos comuns em que div é a escolha certa.

Você já viu um: envolver uma página inteira com um contêiner para fins de estilo (B e C).

Como consegui o layout de duas colunas com div? Apliquei um pouco de CSS ao elemento article para exibi-lo
como coluna um e ao elemento side para exibi-lo como coluna dois. (Veja o Capítulo 7 para começar a aprender CSS,
e veja o Capítulo 11 para layouts com CSS.)

Entretanto, na maior parte (se não na maior parte) do tempo, cada uma de suas colunas tem mais de uma seção de
conteúdo. Por exemplo, talvez você queira outro artigo (ou seção, ou à parte, e assim por diante) na área de conteúdo
principal abaixo do primeiro artigo. E talvez você queira um aparte adicional na segunda coluna, digamos, com uma
lista de links para outros sites sobre Gaudí. Ou talvez você queira outro tipo de elemento nessa coluna.

Você precisaria agrupar o conteúdo que deseja representar cada coluna em um div E e depois estilizar esse div de
acordo. (Se você estava pensando que a seção seria uma opção, ela não se destina a ser um contêiner genérico para
estilo.) Forneci um diagrama F para ajudá-lo a visualizar a relação entre o código E e um possível layout CSS. Tenha
em mente que é apenas uma possibilidade de layout para este HTML; CSS é bastante poderoso.

Portanto, é muito comum ter uma div em torno de cada grupo de conteúdo que você deseja estilizar como uma
coluna (claro, você pode fazer mais de duas). Em termos do que há neles , isso pode variar muito, com base no
conteúdo que você deseja em suas páginas. Não se esqueça disso, pois seus contêineres semânticos primários para
seções de conteúdo, artigo, seção, aparte e navegação podem ir a praticamente qualquer lugar. Assim como o
cabeçalho e o rodapé, como você aprendeu neste capítulo. Não dê muita importância ao fato de que o exemplo (E e F)
mostra apenas artigos na área de conteúdo principal e apartes na barra lateral.

Porém, para ter certeza, div deve ser seu último recurso como contêiner porque não tem valor semântico.
Na maioria das vezes, será correto usar cabeçalho , rodapé, artigo, seção, lado e, possivelmente, navegação . No
entanto, não use um desses apenas para evitar div se não for semanticamente apropriado fazê-lo. div tem seu
lugar, você só quer limitar seu uso.

Dito isto, há uma situação válida em que não há problema em usar div para todos (ou a maioria, depende de você)
contêineres em uma página, em vez dos novos elementos HTML 5. Consulte “Estilizando elementos HTML5 em
navegadores mais antigos” no Capítulo 11 para obter mais informações.

86 Capítulo 3
Machine Translated by Google

E Esta página possui a div que contém a página inteira,


mais duas novas. Uma div com id="content" agrupa o
conteúdo principal para que possa ser estilizado como a
coluna um. Outra div com id="sidebar" envolve o conteúdo
que você deseja exibir na coluna dois. Então você pode usar o
id em seu CSS para direcionar cada div específico para estilo.

...
<corpo>

<!-- Contêiner da página inicial -->


<div id="contêiner">
<cabeçalho>
...
</header> F Este diagrama ilustra como o código em E
poderia mapear conceitualmente para um layout CSS. É
<!-- Coluna Um quando CSS aplicado --> um arranjo muito comum, mas apenas uma das muitas
<div id="conteúdo"> possibilidades que o CSS oferece com o mesmo HTML.
<artigo> Não deixe de ler a próxima seção, “Melhorando a
acessibilidade com ARIA”, para aprender como aprimorar a
...
semântica e a acessibilidade de suas páginas
</artigo>
ainda mais.

<artigo>
...
</artigo>

... [mais seções conforme desejado] ...


</div>
<!-- fim da coluna um -->

<!-- Coluna dois quando CSS aplicado -->


<div id="barra lateral">
<à parte>
...
</aside>

<à parte>
...
</aside>

... [mais seções conforme desejado] ...


</div>
<!-- fim da coluna dois -->

<rodapé>
...
</footer>
</div>
<!-- contêiner da página final -->

</body>
</html>

Estrutura HTML Básica 87


Machine Translated by Google

Melhorando A O exemplo de “Criando contêineres genéricos” com a


adição de um elemento de navegação e cinco funções de
referência diferentes.
Acessibilidade com ARIA
...
Como você aprendeu na seção “Por que
<corpo>
Semantics Matter” no Capítulo 1, a acessibilidade
melhora simplesmente marcando seu conteúdo <!-- Contêiner da página inicial -->
com o HTML que melhor descreve <div id="contêiner">
<header role="banner">
isto. Então, se você já está fazendo isso, está
...
indo muito bem. Nesta seção, direi como adicionar
<nav role="navegação">
alguns atributos simples ao seu HTML pode ... [ul com links] ...
ajudar ainda mais seus visitantes. </nenhum>

</header>
WAI-ARIA (Web Accessibility Initiative's
Accessible Rich Internet Applications), ou <!-- Coluna Um quando CSS aplicado -->
ARIA, é uma especificação que se declara <div id="content" role="main">
“uma tecnologia de ponte”. Ou seja, preenche <artigo>
...
lacunas semânticas com atributos até que
</artigo>
linguagens como HTML forneçam sua própria
semântica equivalente. <artigo>
...
Por exemplo, qual marcação HTML você usaria
</artigo>
para permitir que um leitor de tela soubesse como
ir (ou passar) do conteúdo principal da sua ... [mais seções conforme desejado] ...
página? Ou para uma caixa de pesquisa? Como </div>
você aprenderá, há alguma sobreposição entre <!-- fim da coluna um -->

ARIA e HTML5 (que também tentou preencher


<!-- Coluna dois quando CSS aplicado -->
algumas lacunas), mas nem mesmo o HTML5
<div id="barra lateral">
tem soluções para esses dois. Os papéis marcantes da ARIA <aside role="complementar">
fazer; eles identificam um conjunto de regiões ...
de página parcialmente para esse propósito: </aside>
aplicativo, banner, complementar,
<aside role="complementar">
contentinfo, formulário, principal, navegação e pesquisa. ...
Onde há sobreposição entre funções de referência </aside>
e elementos HTML5, o suporte ao leitor de tela
... [mais seções conforme desejado] ...
atualmente está mais avançado para ARIA.
</div>
Assim, você pode continuar a criar HTML como <!-- fim da coluna dois -->
sempre fez e adicionar funções ARIA para
melhorar a acessibilidade de suas páginas. <footer role="contentinfo">
...
Em A, adicionei funções de referência ARIA e um </footer>
elemento de navegação ao exemplo de </div>
“Criando contêineres genéricos”. Embora eu <!-- contêiner da página final -->
tenha colocado um papel complementar
</body>
em cada elemento lateral , seria apenas
</html>

88 Capítulo 3
Machine Translated by Google

como válido para o código <div id="sidebar"

role="complementary">, marcando toda a barra


lateral. Antes de fazer isso em suas páginas, certifique-
se de que todo o seu conteúdo div seja qualificado como
conteúdo complementar .

Abaixo estão alguns dos papéis de referência definidos


nições encontradas na especificação ARIA, seguidas
pelo meu uso recomendado. Eles são demonstrados
em A e em um diagrama B
semelhante ao de “Criando contêineres genéricos”.

n papel = "banner"

Uma região que contém principalmente


conteúdo orientado ao site, em vez de
B Este é o diagrama de layout de “Criando
conteúdo específico da página.
Generic Containers”, mas agora inclui as funções
ARIA. Conforme observado, a div da barra lateral O conteúdo orientado ao site normalmente inclui
poderia ter role="complementary" em vez do aparte itens como o logotipo ou a identidade do patrocinador
elementos.
do site e uma ferramenta de pesquisa específica do
site. Um banner geralmente aparece na parte
superior da página e normalmente ocupa toda a
largura.

Uso: adicione-o ao cabeçalho do nível da página


(normalmente um elemento de cabeçalho ) e use-
o apenas uma vez em cada página.

n role="navegação"

Uma coleção de elementos de navegação


(geralmente links) para navegar no documento ou
documentos relacionados.

Uso: Isso espelha o elemento nav do HTML5 ,


então adicione-o a cada elemento nav ou, se nenhum
estiver presente, adicione-o ao contêiner ao
redor dos seus links. Você pode usar essa função
mais de uma vez em cada página.

n papel = "principal"

O conteúdo principal de um documento.

Uso: Adicione-o ao contêiner da sua seção principal


de conteúdo. Muitas vezes isso irá
ser um elemento div , mas também pode ser
um artigo ou seção . Exceto em raras circunstâncias,
sua página deve ter apenas uma área marcada com
main.

Estrutura HTML Básica 89


Machine Translated by Google

n role="complementar"
Uma seção de apoio do documento,
concebida para complementar o conteúdo
principal. . . mas isso continua significando
útil quando separado do principal
contente.

O papel complementar indica que o conteúdo


contido é relevante para o
conteúdo principal.

Uso: Isso reflete o lado do HTML5


elemento, então adicione-o a um aparte ou div

que contém todo o conteúdo complementar.


Você pode incluir mais de um
função complementar em cada página.

n role="contentinfo"

Uma grande região perceptível que contém


informações sobre o documento pai.

Exemplos de informações incluídas nesta


região da página são direitos autorais e
links para declarações de privacidade.
Uso: adicione-o uma vez em uma página ao
rodapé no nível da página (normalmente um rodapé
elemento).

Em resumo, geralmente é uma boa ideia


adicionar funções de referência ARIA ao seu HTML.
Eu os incluí em alguns outros exemplos ao longo
do livro, bem como no site do livro. Para ser
claro, suas páginas funcionarão sem eles,
mas incluí-los pode melhorar a experiência
de alguns usuários. Você pode achar os
resultados do teste do leitor de tela listados nas
dicas úteis para decidir se deve usá-los você
mesmo (o suporte é sólido fora do leitor de
tela Window-Eyes 7.5).

90 Capítulo 3
Machine Translated by Google

A função de formulário é semanticamente


redundante com o elemento de formulário , a pesquisa
marca um formulário de pesquisa (BBC, Yahoo! e
Google usam isso, bem como algumas outras funções de referência
em alguns casos), e o aplicativo é para uso
avançado.

As funções de referência são apenas um


dos muitos recursos da especificação ARIA (www.w3.org/TR/
wai-aria/). Você também pode estar interessado neste
guia de implementação: www.w3.org/WAI/PF/
práticas de ária/.

Defensores da acessibilidade Steve Faulkner


e Jason Kiss publicaram testes separados de
suporte à função de referência do leitor de tela em
www .html5accessibility.com/tests/landmarks.html e
www.accessibleculture.org/research/
html5-aria-2011/, respectivamente. Veja as discussões
relacionadas de Faulkner em www.paciellogroup.com/
blog/2011/11/latest-aria-landmark-support-data/
e em www.paciellogroup.com/
blog/2011/07/html5-accessibility-chops-aria-
markter-support/.

NVDA (Windows, download gratuito em www.


nvda-project.org/), VoiceOver (gratuito como parte do
Mac OSX e iOS 4+) e JAWS (Windows, teste gratuito
disponível em www.freedomscientific .com/) estão
entre os leitores de tela mais avançados disponíveis.
Não posso recomendar fortemente que você experimente
pelo menos um deles para avaliar melhor como suas
escolhas semânticas de HTML influenciam a
experiência do usuário do leitor de tela. Melhor ainda,
teste suas páginas em um leitor de tela como parte do
seu desenvolvimento normal
processo.

Você pode usar atributos de função ARIA


em seus seletores CSS. Na verdade, usando os
papéis de referência adequados, você poderia
omitir os atributos id="content" e id="sidebar" do
exemplo de código A. Consulte o Capítulo 11
para obter detalhes.

Estrutura HTML Básica 91


Machine Translated by Google

Nomeando Elementos com


O atributo da classe e
uma Classe ou ID Microformatos
Há um equívoco comum de que o atributo
Embora não seja obrigatório, você pode dar
class foi criado exclusivamente para aplicar
aos seus elementos HTML um identificador
CSS a grupos de elementos.
exclusivo, atribuir-lhes uma classe (ou classes)
Esse não é o caso. Também foi projetado para
específica, ou ambos. Depois de fazer isso, enriquecer a semântica do HTML sem
você pode aplicar estilos a todos os elementos adicionando mais elementos à linguagem
com um determinado ID ou nome de classe . de marcação.
Esse é certamente o uso mais popular, mas não o
Os microformatos fazem exatamente
único (veja as dicas nesta seção).
isso. Eles usam nomes de classe acordados
para identificar uma parte do HTML como,
Para nomear um digamos, um evento ou entrada de calendário
elemento com um ID exclusivo: (o microformato hCalendar ); identificar
pessoas, organizações e empresas (hCard);
Na tag inicial do elemento, digite id="nome",
ou para descrever a relação entre as pessoas (XFN).
onde nome identifica exclusivamente o Esses são apenas alguns dos muitos
elemento A. nome pode ser quase qualquer microformatos definidos hoje, e mais estão
coisa, desde que não comece com um número sempre em desenvolvimento.
ou contenha espaços.
Aplicativos, bots de pesquisa e outros
softwares podem ler e fazer uso do
Para atribuir uma classe a um elemento: microformatos em seu HTML. Por exemplo,
Operator, um complemento do Firefox, expõe
Dentro da tag inicial do elemento, digite
os microformatos em qualquer página.
class="nome", onde nome é o nome
Você pode aprender mais sobre a implementação
identificador da classe A. Caso queira atribuir
de microformatos em http://microformats.org.
mais de uma classe, separe cada uma
delas com um espaço, como em class="nome
outronome ". (Você pode atribuir mais de
dois nomes de classe.)

Cada id em um documento HTML deve ser


exclusivo. Em outras palavras, dois elementos
na mesma página não podem ser nomeados
com o mesmo id e cada elemento pode ter apenas um id.
O mesmo id pode aparecer em múltiplas páginas
e não precisa ser atribuído ao mesmo elemento
todas as vezes, embora seja habitual fazê-lo.

Por outro lado, um nome de classe específico pode


ser atribuído a qualquer número de elementos
em uma página e um elemento pode ter mais
de uma classe.

continua na página 94

92 Capítulo 3
Machine Translated by Google

A Adicione um atributo id exclusivo a um elemento para identificá-lo para formatação, links ou comportamento
JavaScript posterior. Adicione um atributo de classe a um ou mais elementos para poder formatá-los todos de uma só vez.
Por exemplo, as classes arquiteto e projeto poderiam ser aplicadas ao conteúdo sobre outros arquitetos para uma
formatação consistente. Os links na navegação apontam para os ids em h1 e h2s (veja o Capítulo 6 para obter mais
informações sobre links). Os outros ids são para formatação. Consulte “Criando Containers Genéricos” para obter mais
informações sobre ids, bem como outro exemplo que os utiliza. Os atributos id e class não afetam a aparência de um
elemento, a menos que o CSS faça referência a eles.

...
<corpo>

<div id="container">
<header>
<nav role="navigation">
<ul id="toc">
<li><a href="#gaudi">Arquiteto de Barcelona</a></li>
<li><a href="#sagrada-familia " lang="es">A Sagrada Família</a></li>
<li><a href="#park-guell">Parque Guell</a></li>
</ul>
</
nav> </header>

<artigo class="arquiteto" role="principal">


<h1 id="gaudi">Arquiteto de Barcelona</h1>

<p>Os incríveis edifícios de Antoni Gaudí trazem milhões de turistas a Barcelona todos os anos.</p>
...

<section class="project">
<h2 id="sagrada-familia" lang="es">A Sagrada Família</h2>
...
</seção>

<section class="project">
<h2 id="park-guell">Parque Guell</h2>
...
</seção> </
artigo>
...
</div>
</body>
</html>

Estrutura HTML Básica 93


Machine Translated by Google

Os atributos class e id podem ser adicionados


a qualquer elemento HTML. Um elemento pode ter um id
e qualquer número de classes.

Para obter informações sobre como aplicar


estilos a um elemento com um ID ou classe específico,
consulte “Selecionando Elementos por Classe ou ID” no
Capítulo 9.

Escolha nomes significativos (isto é,


semânticos) para seus ids e classes, independentemente
de como você pretende usá-los. Por exemplo, se você
usar uma classe para estilizar, evite nomes que
descrevam a apresentação, como class="red"
- isso é um pecado capital (entendeu, vermelho, capital?).
Falando sério, class="red" é uma escolha ruim
porque você pode decidir na próxima semana mudar o
esquema de cores do seu site para azul.
Alterar a cor atribuída a uma classe em CSS é
incrivelmente simples, mas seu HTML teria uma classe
chamada red que realmente seria renderizada em
uma cor diferente. Alterar todos os nomes de classes
em seu HTML geralmente não é trivial.

Ao escolher entre aplicar uma classe ou um


id a um elemento para fins de estilo, geralmente é
preferível usar uma classe
porque você pode reutilizar seus estilos associados em
outros elementos da mesma classe. No entanto,
certamente haverá momentos em que você desejará
direcionar seus estilos para um elemento (e possivelmente
para qualquer um de seus descendentes) através de seu id.

O atributo id transforma automaticamente o


elemento em uma âncora nomeada, para a qual você
pode direcionar um link. Para obter mais detalhes,
consulte “Criando Âncoras” no Capítulo 6.

Você pode usar o atributo class para implementar


microformatos (veja a barra lateral para mais detalhes).

Você pode usar JavaScript para acessar os


atributos id e class para aplicar comportamento a
elementos específicos.

94 Capítulo 3
Machine Translated by Google

R Você pode adicionar títulos a qualquer elemento


que desejar, embora seja mais comum usá-los em links. Adicionando o título
... Atributo aos Elementos
<corpo>
Você pode usar o atributo title - para não ser
<header role="banner">
confundido com o elemento title - para adicionar um
<nav role="navegação">
<ul id="toc" title="Tabela de rótulo de dica de ferramenta para praticamente qualquer
Conteúdo"> parte do seu site (A e B). No entanto, eles não servem
<li><a href="#gaudi" title=
apenas para dicas de ferramentas. Os leitores de tela podem
ÿ "Saiba mais sobre Antoni
ÿ Gaudí"> ÿ Arquiteto de ler o texto do título para os usuários, melhorando a acessibilidade.

Barcelona</a></li>
<li> <a href="#sagrada-familia" ÿ Para adicionar um título aos elementos
lang="es"> A Sagrada Família de uma página da web:
ÿ </a></li>
<li><a href="#park-guell">Parque No elemento HTML do item que você deseja rotular com
ÿ Guell</a></li>
título, adicione title="label", onde rótulo é o breve texto
</ul>
descritivo que deve aparecer na dica de ferramenta
</nenhum>

</header> quando um visitante apontar para o elemento ou que será


lido em voz alta por um leitor de tela.
...
</body>
</html>
Versões antigas do Internet Explorer (IE7 e
anteriores) também criam dicas de ferramentas a
partir do atributo alt usado em elementos img (veja o Capítulo 5).
No entanto, se os atributos title e alt estiverem
presentes em um elemento img , a dica de
ferramenta será definida para o conteúdo do atributo
title , não para o atributo alt .

B Quando seus visitantes apontarem para o


elemento rotulado, o título aparecerá. Se você estivesse
apontando para o link do Arquiteto de Barcelona, veria
“Saiba mais sobre Antoni Gaudí”, já que tem título próprio
atributo.

Estrutura HTML Básica 95


Machine Translated by Google

Adicionando comentários
Você pode adicionar comentários aos seus e mais A. Esses comentários só aparecem
documentos HTML para observar onde as seções quando o documento é aberto com um editor de
começam ou terminam, para comentar para você texto ou através da opção Exibir código-fonte do
mesmo (ou para futuros editores) a finalidade de um navegador. Eles são invisíveis para os visitantes no
navegador, caso contrário B.
determinado trecho de código, para impedir a exibição do conteúdo,

A Este exemplo inclui quatro comentários. Dois se combinam para marcar o início e o fim do artigo. Outro “comenta”
o primeiro parágrafo para que não seja exibido na página (se você deseja que o parágrafo seja removido a longo
prazo, seria melhor excluí-lo do HTML). O último comentário é um lembrete para adicionar mais conteúdo antes de
colocar a página no site ativo. Apenas certifique-se de remover quaisquer comentários temporários como “tarefas”
antes de colocar sua página no ar, caso os visitantes vejam seu código. “Criando Containers Genéricos” tem mais
exemplos de comentários.

...
<corpo>
...

<!-- ==== INICIAR ARTIGO ==== -->


<artigo class="arquiteto">
<h1 id="gaudi">Arquiteto de Barcelona</h1>

<!-- Este parágrafo não é exibido porque está comentado.


<p>Os incríveis edifícios de Antoni Gaudí trazem milhões de turistas a Barcelona todos os anos
ÿ .</p>
-->

<p>O inconformismo de Gaudí, já visível na sua adolescência, aliado à sua tranquila ÿ mas firme
devoção à Igreja, constituiu uma base única para os seus pensamentos e ideias. Sua ÿ busca pela
simplicidade...</p>

<seção class="projeto">
<h2 id="sagrada-familia" lang="es">A Sagrada Família</h2>
...
</seção>

<seção class="projeto">
<h2 id="park-guell">Parque Guell</h2>
...
</seção>
</artigo>
<!-- fim do artigo -->

<!--
O QUE FAZER: Adicione outro artigo aqui sobre outros edifícios famosos antes de colocar a página no ar.
-->

...
</body>
</html>

96 Capítulo 3
Machine Translated by Google

Para adicionar um
comentário à sua página HTML:
1. No seu documento HTML, onde deseja inserir
um comentário, digite <!--.

2. Digite os comentários.

3. Digite --> para completar o comentário


texto.

Um bom uso para comentários é lembrar a si


mesmo (ou aos futuros editores) de incluir, remover ou
atualizar certas seções A.

Outro uso para comentários é anotar um


B Os comentários são invisíveis (embora apareçam número de revisão.
prontamente quando o código-fonte é exibido).
Da mesma forma, se você colocar um comentário em É comum comentar o início e o fim das principais
torno de parte do seu conteúdo, ele não exibirá A. Aqui, seções do código para facilitar a modificação posterior
o primeiro parágrafo do código não é exibido. por você ou outros programadores (as páginas podem
ficar longas). Gosto de usar um formato diferente e
mais proeminente para um comentário inicial do que para
um que significa o final de um bloco, para que meus
olhos possam distinguir facilmente entre os dois pontos
enquanto leio o código A.

Você deve ver sua página comentada


com um navegador antes de publicar. Isso o ajudará
a evitar a exibição de seus (possivelmente)
comentários privados ao público porque você
acidentalmente formatou um comentário errado.

Cuidado, entretanto, com comentários muito


privados. Embora invisíveis ao visitar sua página
normalmente no navegador, eles podem ser vistos por
meio do recurso Visualizar código-fonte do navegador
ou se o usuário salvar a página como código HTML
(fonte).

Os comentários não podem ser aninhados dentro


outros comentários.

A sintaxe mostrada é para comentários HTML


apenas. CSS e JavaScript têm uma sintaxe de
comentários diferente. CSS e JavaScript usam /* O
comentário vai aqui */ para um comentário que cobre uma
ou mais linhas, enquanto o JavaScript também usa // O
comentário vai aqui para comentários de linha única.

Estrutura HTML Básica 97


Machine Translated by Google

Esta página foi intencionalmente deixada em branco

Você também pode gostar