gin49sz

导航

 

1. 前言

学习路线:

  • HTML4(排版标签)
  • CSS2(盒子模型)
  • HTML4(HTML5优势)
  • CSS3(弹性盒子)

marquee标签 滚动条效果(废弃,不再使用)

标签=元素

loop属性:循环次数;bgcolor属性:背景色

当标签中出现多个重复的属性,只显示一个属性

2. IDE(VS code)

2.1 调整字体

设置 -> 控制字体大小(建议22像素)

2.2 设置主题

主题 -> 颜色主题/文件图标主题/产品图标主题

2.3 插件

颜色主题:monokai Pro

文件图标主题:vscode-icons

快速打开文件:Live Server(使用Ctrl + Shift + P打开命令面板选择Open with Live Server)(必须使用文件夹打开vscode)

2.4 打开文件

双击 -> 未修改不被替换

单击 -> 未修改被替换

2.5 快捷键(持续补充)

Ctrl + Shift + K 快速删除光标所在的行

! 生成默认的html内容

Ctrl + Enter 移动到下一行(不将光标后面的内容换行)

Alt + Shift + ↑/↓ 将当前的代码向上/向下复制一行

Alt + Mouse1 多个光标

输入lorem 随机键入一些内容

Ctrl + D 选中当前的单词

2.6 关闭单文件夹折叠

设置 -> 搜索compact -> 取消勾选第一个选项

3. HTML头标识

3.1 文档声明

h5标准

<!DOCTYPE html>

3.2 字符编码

UTF-8

<meta charset="UTF-8">

3.3 设置语言

设置英文

<html lang="en">
</html>

设置中文

<html lang="zh-CN">
</html>

在VScode中修改默认生成的html内容中的语言

设置 -> 扩展 -> emmet -> Variables -> 添加项 -> lang后面添加zh-CN

3.4 添加页面标志

方法一、将一张.ico文件命名为favicon.ico放置在VScode打开的文件夹下面

4.HTML标签

4.1 语义化标签

标签的语义 > 标签默认的效果

对于一个标签来说,最重要的是其语义,例如h1就是页面最重要的标签,这样做的好处:

  • 增强代码可读性
  • 有利于SEO(搜索引擎优化)
  • 方便设备解析

4.2 文本标签

文本标签一般是行内元素,适用于词汇/短语

em 着重阅读内容

strong 十分重要的内容

span 没有语义,包裹短语的通用标签

4.3 不常用标签名

标签 标签语义 单/双标签
cite 作品标题
dfn 特殊术语
del/ins 删除的文本/插入的文本
sub/sup 下标/上标
code 一段代码
samp 从上下文中提取内容
kbd 键盘文本
abbr 缩写,配合title
bdo 更改文本方向,配合dir(属性值:ltr左到右、rtl右到左)
var 标记变量
small 附属细则
b 关键字
i 字体图标
u 反差文本
q 短引用
blockquote 长引用(块元素)
address 地址信息(块元素)

4.4 图片标签

src:配置图片路径

alt:配置图片描述

<img src="" alt="">

img是一个block-inline元素

4.4.1 相对路径

./ 当前位置

/ 下一级文件

../ 上一级文件夹

4.4.2 绝对路径

4.5 超链接

<a href="" target="_blank"></a><!--在新页面打开-->
<a href="" target="_self"></a><!--在当前页面打开-->

a标签可以包裹除了自己以外的任何标签

4.5.1 下载文件

<a href="文件地址" download="下载的文件名">下载链接</a>

4.5.2 跳转锚点

当页面中有较多的内容,通过跳转锚点可以快速跳转到本页的内容

<!-- 点击此链接跳转 -->
<a href="#htl"></a>

<!-- 跳转到的位置 -->
<a name="htl">灰太狼</a>
<div>
	...
</div>
  • 不写额外的a标签标记跳转的位置,也可以在正常标签中添加name

    <!-- 跳转到的位置 -->
    <div id="htl">
    	...
    </div>
    
  • 特殊的,通过<a href="#"></a>可以快速回到顶部,无需添加跳转的位置

    <a href="#">回到顶部</a>
    
  • 如果没有#本质上是刷新了当前页面

    <a href="">刷新</a>
    
  • 可以通过javascript: 脚本来快速添加脚本

    <a href="javascript:alert('some str ...');">点击弹窗</a>
    

4.5.3 唤起指定应用

<a href="tel:10010">电话联系</a>
<a href="mailto:123@456.com">邮件联系联系</a>
<a href="sms:10086">短信联系</a>

4.6 列表标签

4.6.1 有序列表

<ol>
	<li></li>
    <li></li>
</ol>

4.6.2 无序列表

<ul>
    <li></li>
    <li></li>
</ul>

4.6.3 自定义列表

<dl>
    <dt>术语名称1</dt>
    <dd>术语描述1</dd>、
    <dt>术语名称2</dt>
    <dd>术语描述2</dd>
</dl>

4.6.4 注意事项

列表嵌套

<ul>
    <li></li>
    <li>
    	<span>abc:</span>
        <ul>
            <li>q</li>
            <li>w</li>
            <li>e</li>
        </ul>
    </li>
</ul>

4.7 表格

4.7表格

<table>
    <caption>标题</caption>
    <thead>
        <tr>
            <th>a</th>
            <th>b</th>
            <th>c</th>
        </tr>
    </thead>
    <tbody>
        <tr>
        	<td>1</td>
            <td>2</td>
            <td>3</td>
        </tr>
        <tr>
        	<td>4</td>
            <td>5</td>
            <td>6</td>
        </tr>
    </tbody>
    <tfoot>
    	<tr>
        	<td></td>
            <td></td>
            <td>共计:xx</td>
        </tr>
    </tfoot>
</table>

4.7.1 表格基本属性

  • 为表格添加边框

    <table border="1px">
    	...    
    </table>
    

    border会为所有的单元格和表格都添加1px的边框,但是当border大于1的时候,只会应用于表格本体,单元格只会添加1px的边框

  • 控制表格宽度(根据内容分配每一列)和高度(只会修改data的高度,表头和脚注不会修改,且高度为最低值,实际可以超过表格设定的高度)

    <table width="500px" height="500px">
        ...
    </table>
    

    可以通过height控制表头和脚注的高度,但是不能控制宽度

    <thead height="100px">
    ...
    </thead>
    ...
    <tfoot height="100px">
    ...
    </tfoot>
    

    可以通过height控制body的高度,但必须高于表格设定的最小高度

    <tbody height="600px">
    ...
    </tbody>
    
  • 控制单元格之间的间距

    <table cellspacing="0">
        ...
    </table>
    
  • 控制对齐方式

    水平方向 align

    属性值:

    左侧:left

    居中:center

    右侧:right

    垂直方向 valign

    靠上:top

    中间:middle

    底部:bottom

    左上角对齐

    <thead align="left" valign="top"></thead>
    

    水平垂直居中

    <thead align="center" valign="middle"></thead>
    

    也适用于trth,并且可以通过修改th的宽度修改这一列的宽度,修改高度影响这一行的高度

4.7.2 表格跨行跨列

跨列 colspan

跨行 rowspan

4.8 常用标签

换行标签
<br>

分割线
<hr>

按原文显示
<pr>

4.9 表单

4.9.1 基本属性

网页中的交互区域

<form action="https://www.baidu.com/s" method="get" target="_blank">
    <!-- 通过表单联系百度搜索,需要在后面加上s - search -->
    <input type="text" name="wd">
    <button type="sbmit">搜索</button>
</form>

4.9.2 常用控件

value="abc" 控制显示的内容

maxlength="14" 控制text的输入长度

type="password" 修改为密码输入框

type="radio" 修改为单选输入框(要使用name添加名字,也能保证只有一个选中,要添加value)

type="checkbox" 修改为多选输入框(要使用name添加名字,要添加value,默认勾选方式添加属性checked)

4.9.3 隐藏域

添加一个隐藏的框

<input type="hidden" name="from" value="myserver">

4.9.4 确认和重置

<input type="submit" value="确认">

<input type="reset" value="重置 ">

4.9.5 文本域和下拉框

文本域

<textarea name="other" cols="30" rows="10"></textarea>

下拉框

<select name="place">
    <option value="x">xxx</option>
    <option value="y">yyy</option>
    <option value="z" selected>zzz</option>
</select>

4.9.6 禁用表单控件

<input type="text" name="username" disabled>

4.9.7 label标签

使用label的for属性绑定input,当点击label时候,对应的input会获得焦点

<label for="account">账户:</label>
<input id="account" type="text" name="username" maxlength="16">

也可以使用label标签包裹input实现

<label for="account">
    账户:<input id="account" type="text" name="username" maxlength="16">
</label>

使用单选也可以用label包裹显示的内容实现点击选中

<input id="woman" type="radio" name="gender" value="female"><label for="woman">女</label>

4.9.8 fieldset和legend

对表单中的内容进行一个分类,fieldset是分组,legend是分组名称,例如分为主要信息和次要信息

<fieldset>
    <legend>主要信息</legend>
    ...
</fieldset>
<fieldset>
    <legend>次要信息</legend>
    ...
</fieldset>

4.10 框架标签

嵌入一个其他的网页(也可以嵌入图片和视频)

<iframe src="https://www.toutiao.com" width="100" height="300">
    
</iframe>

属性

frameborder 是否显示边框,只有0或者1

使用a标签和iframe点击嵌入网页

<a href="...yyy" target="abc">点我查看yyy</a>
<a href="...zzz" target="abc">点我查看zzz</a>
<iframe name="abc" width="100px" height="100px">
    <!-- 嵌入的位置 -->
</iframe>

使用form将提交信息后返回的页面嵌入网页

<form action="https://so.toutiao.com/search" target="abc">
    <input type="text" name="keyword">
    <input type="submit" value="搜索">
</form>

<iframe name="abc" width="100px" height="100px">
    <!-- 嵌入的位置 -->
</iframe>

5.Flex弹性盒子模型(先导)

5.1 布局原理

通过给父盒子添加flex属性,来控制子盒子的位置和排列方式

5.2 父盒子的常见属性

5.2.1 flex-derection设置主轴方向

默认主轴向右,侧轴向下
属性:

row(向右)

column(向下)

reverse-row/column(反向)

5.2.2 justify-content设置主轴上的子元素排列方式

属性:

flex-start(默认)

flex-end(从尾部开始排列)

center(在主轴居中对齐)

space-around(水平分布)

space-between(两端对齐)

5.2.3 flex-wrap设置子元素是否换行

默认情况下,当元素的个数超出了盒子的宽度,会默认缩小元素的边距,甚至缩小元素的宽度来保持在同一行

如何关闭这一特性,使得超出的盒子自动摆放在下一行?

使用flex-wrap属性:

nowrap(不换行,默认)

wrap(换行)

5.2.4 align-items设置侧轴上的子元素排列方式(单行)

属性:

flex-start(默认)

flex-end(从尾部开始排列)

center(在主轴居中对齐)

stretch(拉伸,但是如果子盒子有高度,此属性会被屏蔽)

5.2.5 align-content设置侧轴上的子元素排列方式(多行)

设置子项在侧轴上的排列方式,并且只能用于子项出现换行的情况(多行),而在单行的情况下是不具备效果的

属性:

space-around(水平分布)

space-between(两端对齐)

5.2.6 flex-flow

flex-flow属性是flex-direction和flex-wrap的复合属性

div{
    flex-direction:column;
    flex-wrap:wrap;
}

等价于

div{
    flex-flow:column wrap;
}

5.3 子项常见属性

5.3.1 flex属性

flex属性定义子项目分配剩余空间,用flex来表示占多少份数

.item{
    flex:<number>; /*default 0*/
}

5.3.2 align-self控制子项在自己侧轴上的排列方式

在使用align-items时候,会控制所有的子盒子,如果从单个子盒子的角度进行处理,只修改这一个盒子在侧轴上的排列方式

属性:

flex-start(默认)

flex-end(从尾部开始排列)

center(在主轴居中对齐)

stretch(拉伸,但是如果子盒子有高度,此属性会被屏蔽)

5.3.3 order属性自定义项目的排列顺序

数值越小,排列越靠前,默认是0

注意:和z-index不一样

6.字符实体

HTML中用一种特殊的形式表示某个符号

&nbsp(&#160) 空格

&lt; <小于号

&gt; >大于号

&amp; &符号

&yen'; ¥符号

&copy; ©符号

&times; ×符号

&divide ÷符号

更多字符实体:HTML Standard (whatwg.org)

7.全局属性

id、class、style

dir 在bdo标签中:修改文字顺序;

​ 在普通标签中:修改文字位置(ltr左对齐,center 居中、rtl右对齐)

title 鼠标悬浮显示内容

lang 标签语言种类

更多全局属性:全局属性 - HTML(超文本标记语言) | MDN (mozilla.org)

8.meta元信息

meta标签的内容属于网页的基本信息

标准元数据名称 - HTML(超文本标记语言) | MDN (mozilla.org)

  • 兼容模式

    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    
  • 移动端设备适配

    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    
  • 配置网页关键字

    <meta name="keywords" content="aaa, bbb, ccc">
    
  • 配置网页描述信息

    <meta name="description" content="abcdefgh">
    
  • 配置搜索引擎爬虫

    <meta name="robots" content="详情参考MDN">
    
  • 一些其他的name属性值

    name=""

    author 网页作者

    generator 生成工具

    copyright 版权信息

  • 网页刷新

    <meta http-equiv="refresh" content="10;url="https://www.baidu.com">
    
posted on 2024-04-14 10:39  树深时见鹿nnn  阅读(26)  评论(0编辑  收藏  举报