设为首页收藏本站
查看: 3403|回复: 0

[前端开发] 016 HTML基础回顾(第一章完结!)

[复制链接]
  • TA的每日心情
    开心
    2024-1-13 00:31
  • 签到天数: 535 天

    [LV.9]以坛为家II

    发表于 2021-9-15 21:22:04 | 显示全部楼层 |阅读模式
    本文主要内容

    - html 的常见元素
    - html 元素的分类
    - html 元素的嵌套关系
    - html 元素的默认样式和 CSS Reset
    - html 常见面试题


    html 的常见元素

    html 的常见元素主要分为两类:head 区域的元素、body 区域的元素。下面来分别介绍。

    1、head 区域的 html 元素

    > head 区域的 html 元素,不会在页面上留下直接的内容。

    - meta
    - title
    - style
    - link
    - script
    - base

    base元素的介绍:

    1. <base href="/">
    复制代码


    base 标签用于指定基础的路径。指定之后,所有的 a 链接都是以这个路径为基准。

    2、html 元素(body 区域)

    > body 区域的 html 元素,会直接出现在页面上。

    - div、section、article、aside、header、footer
    - p
    - span、em、strong
    - 表格元素:table、thead、tbody、tr、td
    - 列表元素:ul、ol、dl、dt、dd
    - a
    - 表单元素:form、input、select、textarea、button

    div 是最常见的元素,大多数场景下,都可以用div(实在不行就多包几层div)。可见,**div 是比较通用的元素,这也决定了 div 的的语义并不是很明确**。

    常见标签的重要属性:

    - a[href,target]
    - img[src,alt]
    - table td[colspan,rowspan]。设置当前单元格占据几行几列。在合并单元格时,会用到。
    - form[target,method,enctype]
    - input[type,value]
    - button[type]
    - selection>option[value]
    - label[for]

    html 文档的大纲

    我们平时在写论文或者其他文档的时候,一般会先列出大纲,然后再写具体的内容。

    同样,html 网页也可以看成是一种文档,也有属于它的大纲。

    一个常见的html文档,它的结构可以是:

       
    1. <section>
    2.         <h1>一级标题</h1>

    3.         <section>
    4.             <h2>二级标题</h2>
    5.             <p>段落内容</p>
    6.         </section>

    7.         <section>
    8.             <h2>二级标题</h2>
    9.             <p>段落内容</p>
    10.         </section>

    11.         <aside>
    12.             <p>广告内容</p>
    13.         </aside>

    14.     </section>

    15.     <footer>
    16.         <p>某某公司出品</p>
    17.     </footer>
    复制代码


    查看网页大纲的工具

    我们可以通过 <http://h5o.github.io/> 这个工具查看一个网页的大纲。

    使用方法:

    (1)将网址 <http://h5o.github.io/> 保存到书签栏

    (2)去目标网页,点击书签栏的网址,即可查看该网页的大纲。

    这个工具非常好用,既可以查看网页的大纲,也可以查看 markdown 在线文档的结构。

    html 元素的分类

    按照样式分类:

    - 块级元素
    - 行内元素
    - inline-block:比如`form`表单元素。对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。

    按照内容分类:



    图片来源:<https://html.spec.whatwg.org/multipage/dom.html#kinds-of-content>

    html 元素的嵌套关系

    - 块级元素可以包含行内元素。

    - 块级元素不一定能包含块级元素。比如 div 中可以包含 div,但 p 标签中不能包含 div。

    - 行内元素一般不能包含块级元素。比如 span 中不能包含 div。但有个特例:在 HTML5 中, a 标签中可以包含 div。

    注意:在 HTML5 中 `a > div` 是合法的, `div > a > div`是不合法的 ;但是在 html 4.0.1 中, `a > div` 仍然是不合法的。

    html 元素的默认样式和 CSS Reset

    比如下拉框这种比较复杂的元素,是自带默认样式的。如果没有这个默认样式,则该元素在页面上不会有任何表现,则必然增加一些工作量。

    同时,默认样式也会带来一些问题:比如,有些默认样式我们是不需要的;有些默认样式甚至无法去掉。

    如果我们不需要默认的样式,这里就需要引入一个概念:*CSS Reset*。

    常见的 CSS Reset 方案

    *方案一:

    CSS Tools: Reset CSS。链接:<https://meyerweb.com/eric/tools/css/reset/>

    方案二:

    雅虎的 CSS Reset。链接:<https://yuilibrary.com/yui/docs/cssreset/>

    我们可以直接通过 CDN 的方式引入:

    1. <link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/3.18.1/build/cssreset/cssreset-min.css">
    复制代码


    方式三:(比较有争议)

    1. *{
    2.     margin: 0;
    3.     padding: 0;
    4. }
    复制代码


    上面何种写法,比较简洁,但也有争议。有争议的地方在于,可能会导致 css 选择器的性能问题。

    Normalize.css

    上面的几种 css reset 的解决思路是:将所有的默认样式清零。

    但是,[Normalize.css](https://necolas.github.io/normalize.css/) 的思路是:既然浏览器提供了这些默认样式,那它就是有意义的。**既然不同浏览器的默认样式不一致,那么,`Normalize.css`就将这些默认样式设置为一致**。

    html 常见面试题

    doctype 的意义是什么

    - 让浏览器以标准模式渲染

    - 让浏览器知道元素的合法性

    HTML、XHTML、HTML5的区别

    - HTML 属于 SGML

    - XHTML 属于 XML,是 HTML 进行 XML 严格化的结果

    - HTML5 不属于SGML,也不属于 XML(HTML5有自己独立的一套规范),比 XHTML 宽松。

    HTML5 有什么新的变化

    - 新的语义化元素

    - 表单增强

    - 新的API:离线、音视频、图形、实时通信、本地存储、设备能力等。

    em 和 i 的区别

    共同点:二者都是表示斜体。

    区别:

    - em 是语义化的标签,表示强调。

    - i 是纯样式的标签,表示斜体。HTML5 中不推荐使用。

    语义化的意义是什么

    - 开发者容易理解,便于维护。

    - 机器(搜索引擎、读屏软件等)容易理解结构

    - 有助于 SEO

    哪些元素可以自闭和

    > 自闭和的元素中不能再嵌入别的元素。且 HTML5 中要求加斜杠。

    - 表单元素 input

    - 图片 img

    - br、hr

    - meta、link

    form 表单的作用

    - 直接提交表单

    - 使用 submit / reset 按钮

    - 便于浏览器保存表单

    - 第三方库(比如 jQuery)可以整体获取值

    - 第三方库可以进行表单验证

    所以,如果我们是通过 Ajax 提交表单数据,也建议加上 form。

    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    红盟社区--红客联盟 

    Processed in 0.055529 second(s), 21 queries.

    站点统计| 举报| Archiver| 手机版| 黑屋 |   

    备案号:冀ICP备20006029号-1 Powered by HUC © 2001-2021 Comsenz Inc.

    手机扫我进入移动触屏客户端

    关注我们可获取更多热点资讯

    Honor accompaniments. theme macfee

    快速回复 返回顶部 返回列表