@SovietPower
2021-12-12T15:11:58.000000Z
字数 23411
阅读 1279
学习笔记
作业部落链接:https://www.zybuluo.com/SovietPower/note/1819073
参考:
学习框架:https://www.runoob.com/html/html-tutorial.html
标签学习:https://www.w3school.com.cn/tags/index.asp
https://developer.mozilla.org/zh-CN/docs/Learn
<!-- ... -->
插入注释。<br />, <input type="text" id="qwq"/>
),在开始标签中进行关闭。 <option>
的selected属性,会被记为:当selected="selected"时,执行...
,事实上只需在定义元素时写出该属性selected
/该属性存在(不需设定值),或为该属性定义任意值,都会执行对应操作(但注意,在XHTML中不允许使用这样的属性简写)。在JS中将其设为空(如selected=""
)会取消该选项。使用ture/false
也可表示开启/关闭该选项。<h1>,<h2>,...,<h6>
,分别对应6号、5号、...、1号字体(font size=6,5,...,1
)。<hr>
插入分割线,<br>
插入折行(换行)。tab
:多个连续空格、制表符会被显示为一个空格,换行不会生效(只有使用<br>
标签可以)。 如果想保留空格、换行符、制表符,可使用
<pre>, </pre>
( preformatted)定义预格式化的文本。常用于表示源代码。
pre元素虽是块级元素,但只能包含文本或内联元素(行内元素),所以任何块级元素都不能处于<pre>
中,常见的为会分割段落的标签,比如标题<h1>, <h2>, ...
、<p>
、<address>
。
如果要用<pre>
表示源代码,注意用符号实体来表示特殊字符,如<
替换<
,>
替换>
,&
替换&
。用<code>, </code>
包含代码可不用替换。所以常用<pre>
包含<code>
来插入代码(或直接使用<code>
)。
<b>, <i>, <strong>, <em>
<b>
<i>
<b>, <i>
<strong>, <em>
<del>
<del>
定义文档中已删除的文本,通过给文字添加画删除线。代替以前的<s>(<strike>)
标签。 <ins>
一起使用,描述文档中的更新和修正。浏览器通常会在已删除文本上添加一条删除线,在新插入文本下添加一条下划线。属性:
cite
,值为URL,规定一个解释了文本被删除的原因的文档的URL。
datetime
,值为YYYY-MM-DDThh:mm:ssTZD
,规定文本被删除的日期和时间。
<ins>
<ins>
定义被插入文档中的文本,通过给文字添加下划线。属性:
cite
,值为URL,规定一个解释了文本被插入的原因的文档的URL。
datetime
,值为YYYY-MM-DDThh:mm:ssTZD
,规定文本被插入的日期和时间。
<sub>, <sup>
<sub>
(subscripted)定义下标文本。下标文本将会显示在当前文本流中字符高度的一半为基准线的下方,但是与当前文本流中文字的字体和字号都是一样的。
<sup>
(superscripted)定义上标文本。上标文本将会显示在当前文本流中字符高度的一半为基准线的上方,但是与当前文本流中文字的字体和字号都是一样的。常用来添加脚注。
<small>, <big>
<small>
定义小型文本。
<big>
定义比常规字体大一号的文本。注意HTML5不支持<big>
,需用CSS代替。
嵌套<big>
可获得大若干号的文本,直到上限7号字体。
<address>
<address>, </address>
定义文档作者/所有者的联系信息。
如果<address>
元素位于<body>
元素内部,则它表示该文档作者/所有者的联系信息。
如果<address>
元素位于<article>
元素内部,则它表示该文章作者/所有者的联系信息。
<address>
元素的文本通常为斜体。大多数浏览器会在该元素的前后添加换行。
<address>
元素通常被包含在<footer>
元素的其他信息中。
<bdo>
<bdo>, </bdo>
标签用来覆盖默认的文本方向。bdo指bidi覆盖(Bi-Directional Override)或文本显示方向(Direction of Text Display)。
含有一个必需属性dir
,值为ltr
或rtl
,规定<bdo>
元素内的文本方向。
常用属性
innerHTML
innerHTML
属性表示当前元素的开始和结束标签之间的所有HTML代码(包括标签)。
可以通过该值插入标签(会被视作代码)。
如:
获取<div><h1>title</h1></div>
的innerHTML
,结果为<h1>title</h1>
。
修改<div><h1>title</h1></div>
的innerHTML
为<p>123</p>
,会在该div
中新增一个段落123
,并替换掉原有的<h1>title</h1>
。
innerText
innerText
属性表示当前元素的开始和结束标签之间的所有HTML代码(包括标签)。
不能通过该值插入标签(被视作纯字符串)。
如:
获取<div><h1>title</h1></div>
的innerText
,结果为<h1>title</h1>
。
修改<div><h1>title</h1></div>
的innerText
为<p>123</p>
,会在该div
中新增一个纯文本<p>123</p>
,并替换掉原有的<h1>title</h1>
。
对于标签间没有其它标签(即纯文本)的元素,innerHTML
和innerText
等价,可通过这两个元素设置标签间的内容。
注意,使用innerHTML
修改父级块的包含元素后,会重新加载整个父级块,导致父级块的其它内容被加载到初始状态。使用appendChild
不会有这个问题。
所以如需添加固定格式的元素,可以在外层创建一个div
,使该外层div
的innerHTML
设为需要添加的内容,然后使用appendChild
添加该div
。
value
value
属性为元素的一个属性。
title
title
属性定义关于元素的额外信息。其定义的文本,会在鼠标移动到元素内容上时显示。
许多(大概)元素都有title
属性。
abbr, acronym
元素必须含title
属性,两个元素分别用于表示缩略语、首字母缩写,title
用于表示完整的表达。
align
设置对齐。取值为left, right, center
。
不推荐使用,应使用CSS的float
属性,如:style="float:right;"
(但这似乎无法居中)。
tagName
tagName
定义了元素的标签类型。如:<tr>
元素的tagName
为"TR"
。
自定义属性
标签在声明时,可以绑定任意它不拥有的属性。
但该属性不能直接通过elem.attr
获取(会返回undefined
),需使用elem.getAttribute("attr")
获取(DOM),或$(this).attr("attr")
(jQuery)。
例:
div
标签没有name, value
属性,但可自定义绑定该属性:<div class="A" value="123"></div>
,并通过document.getElementsByClassName("A")[0].getAttribute("value")
或$(".A").attr("value")
获取。
属性名可任取。
注意getElementsByName()
和getElementsByClassName()
返回的是一个list
,getElementsById()
返回的是拥有指定id
的第一个对象。
在HTML中,某些字符是预留的(用做特殊功能),称为预留字符。比如<, >
已用做标签。
要显示预留字符,或一些键盘上没有的字符、特殊字符,需使用字符实体(character entity)/转义字符(escape sequence)表示。
字符实体表:https://dev.w3.org/html5/html-author/charref;https://www.runoob.com/tags/ref-entities.html。
字符实体对大小写敏感。
Character | Entity |
---|---|
& |
& |
< |
< |
> |
> |
" |
" |
<
也可写作<
或<
(实体数字,entity number),但实体名比数字更容易记忆。不过并非所有浏览器支持实体名,但很可能支持实体数字。
:不换行空格/不间断空格/硬空格(No-Breaking Space),与按space产生的空格大小相同,但该字符处禁止自动换行,且显示时不会被合并。 
:全角空格(Em Space)。空格大小为1em,即占据一个中文的宽度(em是字体排印学的计量单位,相当于当前字体的大小)。 
:半角空格(En Space)。空格大小为1en即0.5em,即占据1/2个中文的宽度(en是字体排印学的计量单位,为em的一半)。 
:窄空格(Thin Space)。空格大小为em。‌
:零宽不连字(Zero Width Non Joiner),不打印字符,放在电子文本的两个字符之间,抑制本来会发生的连字,使这两个字符按原本的字形来绘制。‍
:零宽连字(Zero Width Joiner),不打印字符,放在某些需要复杂排版语言(如阿拉伯语、印地语)的两个字符之间,使得这两个本不会发生连字的字符产生连字效果。
以上为空格实体。
统一资源定位器(Uniform Resource Locators, URL)是一个网页地址,用于定位万维网上的文档。
Web浏览器通过URL从Web服务器请求页面。
URL的语法规则:
scheme://host.domain:port/path/filename
。
其中:
scheme
:定义因特网服务的类型。最常见的类型是http(超文本传输协议,不加密),还有https(安全超文本传输协议,加密所有信息交换)、ftp(文件传输协议,用于将文件下载或上传至网站)、file(当前计算机上的文件)。
host
:定义域主机(http的默认主机是www)。
domain
:定义因特网域名。比如cnblogs.com
。
:port
:定义主机上的端口号(http 的默认端口号是 80)。
path
:定义服务器上的路径(如果省略,则文档必须位于网站的根目录中)。
filename
:定义文档/资源的名称。
URL字符编码:
URL只能使用ASCII字符集。当URL包含ASCII集之外的字符时,会转换为有效的ASCII格式:使用%
加两位十六进制数来替换非ASCII字符。
URL不能包含空格。URL编码通常使用+
来替换空格。
<head>
<head>
元素包含了所有的头部标签元素。可以添加在头部区域的元素标签为:<title>, <base>, <link>, <style>, <meta>, <script>, <noscript>
。
<title>
必需元素。定义文档的标题。
<base>
描述了基本的链接地址/链接目标,该标签作为HTML文档中所有的链接标签的默认链接。
<link>
定义了文档与外部资源之间的关系。通常用于链接到样式表。
属性:
href
:规定被链接文档的位置。
media
:规定被链接文档将被显示在什么设备上。
rel
:规定当前文档与被链接文档之间的关系。
type
:规定被链接文档的 MIME 类型。
例:
当属性rel
取值为shortcut icon
时,可通过href
属性定义页面logo图片,如:
<head>
<link rel="shortcut icon" href="https://img2020.cnblogs.com/blog/1143196/202106/1143196-20210612002518830-1873723858.png">
</head>
<style>
<style>
标签。属性:
type
:必需,规定样式表的MIME类型。
media
:为样式表规定不同的媒介类型。
<meta>
<meta>
标签位于文档头部,不包含任何内容。其属性定义了与文档相关联的名称/值对。属性:
content
:必需,定义与 http-equiv 或 name 属性相关的元信息
name
:把 content 属性关联到一个名称。
http-equiv
:把 content 属性关联到 HTTP 头部。
scheme
:定义用于翻译 content 属性值的格式。
<script>
属性:
type
:必需,指示脚本的 MIME 类型。
async
:规定异步执行脚本(仅适用于外部脚本)。
charset
:规定在外部脚本文件中使用的字符编码。
defer
:规定是否对脚本执行进行延迟,直到页面加载为止。
src
: 规定外部脚本文件的URL。
<noscript>
<script>
标签但无法支持其中的脚本的浏览器。<a>
<a>
(anchor,锚点)通过href属性定义超链接。锚点又称锚记链接、命名锚记,是页面中的一类超链接。注:
href
属性是可选的。所以<a>
不只可以做链接,还可用于制作格式、按钮。
比如即使未定义链接,a:hover
和a:active
的样式也是会生效的,就不需写一对onmouseenter, onmouseleave
或一对onmousedown, onmouseup
。
但其实,其它元素也可直接使用elem:hover
和elem:active
来实现相同格式。
<a href="javascript:;" οnclick="js_method()">
或 href="javascript:void(0);"
或 href="####"
可实现点击元素执行函数,但不进行任何跳转(更推荐第一个)。
<a href="#" οnclick="js_method()">
可实现点击元素执行函数,并跳转到页面最顶端。
<a href="#" οnclick="js_method(); return false;">
可实现点击元素执行函数,但不进行任何跳转。
href="#"
表示top
,是一个空锚点/空书签,会跳转到页面最顶端。常用于实现回到页面顶端。
属性:
href
:一个URL,规定链接指向的页面的URL。
rev
:有特定的取值,规定当前文档与被链接文档之间的关系。
target
:规定在何处打开链接文档。
target属性有以下几种取值:
_black
:在新窗口中打开被链接文档。
_self
(默认):在相同的框架中打开被链接文档。
_parent
:在父框架集中打开被链接文档。
_top
:在整个窗口中打开被链接文档。
framename
:为一个框架名称,在指定的框架中打开被链接文档。
注:以下划线作为开头的窗口或者目标都会被浏览器忽略,因此,不要将下划线作为文档中任何框架 name 或 id 的第一个字符。
id
:在该处创建一个HTML文档书签(任意位置都可引用,包括之前)。
id属性的例子:
定义一个书签:<a id="tips">These are some tips</a>
引用(链接到)该书签:<a href="#tips">Go to tips!</a>
从其它网页链接到其书签:<a href="add#tips">Go to tips!</a>
,其中add为被引用网页完整地址。
<img>
<img>
标签并不会在网页中插入图像,而是从网页上链接图像。<img>
标签会创建被引用图像的占位空间。属性:
alt
:必需,规定图像的替代文本。
在浏览器无法载入图像时,会显示该替代文本信息而不是图像。为所有图像都加上替代文本有助于更好地显示信息,比如在纯文本浏览的时候。
src
:必需,规定显示图像的URL。
当URL错误无法正确显示图像时,会显示一个破碎的加载失败的图片。
height/width
:设置图像的高度/宽度。
指定图像的高度与宽度,可在页面加载时就预留好指定的空间。如果未指定,加载页面图片时 可能会破坏页面的整体布局。
align, border, hspace, vspace
属性不推荐使用,应使用CSS代替。
注意:
HTML文件每加载一个图像,都需多加载一个文件(HTML文件本身也是一个文件),会占用时间,所以应慎用图片。
<map>
<map>
标签指定id和name(因为引用id还是name是不确定的),用于<img>
引用该map。在XHTML中,name属性被废弃,应指定id属性。属性:
id
:必需,为<map>
标签定义唯一的名称。
name
:HTML中必需,为image-map定义唯一的名称。
在<img>
中使用usemap
属性,可通过引用<map>
中的id或name属性(由浏览器决定)来创建对应的图像映射。图像映射会给<img>
创建的空间(一般为图片所在空间)的对应位置,创建相应的可点击区域,不同区域可链接到不同位置。
例:
下列代码会为<img>
的对应位置创建三个不同大小的可点击区域,分别链接到三个网址。
<map name="planetmap">
<area shape="rect" coords="0,0,82,126" alt="Sun" href="sun.htm">
<area shape="circle" coords="90,58,3" alt="Mercury" href="mercur.htm">
<area shape="circle" coords="124,58,8" alt="Venus" href="venus.htm">
</map>
<img src="planets.gif" width="145" height="126" alt="Planets" usemap="#planetmap">
<area>
<area>
元素总是嵌套在<map>
标签内部。属性:
alt
:必需,定义此区域的替换文本。
coords
:定义可点击区域(对鼠标敏感的区域)的坐标(或参数,与shape
有关)(单位为像素)。
href
:定义此区域的目标URL。
nohref
:HTML5不支持。从图像映射排除某个区域。
rel
:规定当前文档与目标URL之间的关系。
shape
:定义区域的形状。可取值为:default、rect(此时coords
值应为4个数"x1,y1,x2,y2"
,表示左上角顶点坐标、右下角顶点坐标)、circ(此时coords
值应为3个数"x,y,r"
,表示圆心位置、半径)、poly(此时coords
值应为若干个数"x1,y1,x2,y2,..."
,表示多边形的所有顶点坐标)。
target
:规定在何处打开href属性指定的目标URL,同<a>
。
<table>
tr
元素定义表格行,th
元素定义表头,td
元素定义表格单元,caption
元素定义表格标题。
每个表格有若个行,分别由<tr>
与</tr>
间的内容定义(table row)。
每行有若干个单元格,每个单元格有两类:若单元格为数据,则由<td>
与</td>
间的内容定义(table data cell);若单元格为表头,则由<th>
与</th>
间的内容定义(table header cell)。数据一般为正常字体且左对齐,表头一般为粗体居中。
单元格内也可以嵌套表格。
使用tr, th
元素的cells
属性,可获取其中的td, th
列表。
属性:
border
:规定表格边框的宽度。单位为像素,只能取整数(实数会下取整)。当border=0时表格不会显示边框。
cellpadding
:取值为像素或百分比。规定单元格边缘与其内容之间的空白。
cellspacing
:取值为像素或百分比。规定单元格之间的空白。
frame
:规定外侧边框的哪个部分是可见的。
rules
:规定内侧边框的哪个部分是可见的。
summary
:规定表格的摘要。
width/height
:取值为像素或百分比。规定表格的宽度/高度。
例:
<table border="1">
<caption>Monthly savings</caption>
<tr>
<th>First Name:</th>
<td>Bill Gates</td>
</tr>
<tr>
<th rowspan="2">Telephone:</th>
<td>555 77 854</td>
</tr>
<tr>
<td>555 77 855</td>
</tr>
</table>
<th>, <td>
<th>, <td>
分别定义一个单元格的两类:表头单元、标准单元。属性:
abbr
:规定单元格中内容的缩写版本。abbr属性不会在普通的web浏览器中造成任何视觉效果方面的变化,只提供了该单元格的短描述。
align
:规定单元格内容的水平对齐方式。
axis
:定义该单元格的类别名(对单元格进行分类)。
bgcolor
:规定表格单元格的背景颜色。不推荐使用,应使用CSS代替。
char
:规定根据哪个字符来进行内容的对齐(会以该字符作为对齐的中心线)。只有当align
取值为char
时生效。目前几乎没有浏览器支持char
属性。
colspan
:设置单元格横跨的列数。
rowspan
:设置单元格横跨的行数。
scope
:定义将表头数据与单元数据相关联的方法。
width/height
:取值为像素或百分比。规定单元格的宽度/高度。不推荐使用,应使用CSS代替。
<tr>
属性:
align
:定义表格行的内容对齐方式。
bgcolor
:规定表格行的背景颜色。不推荐使用,应使用CSS代替。
char
:规定根据哪个字符来进行内容的对齐(会以该字符作为对齐的中心线)。只有当align
取值为char
时生效。目前几乎没有浏览器支持char
属性。
valign
:规定表格行中内容的垂直对齐方式。
<thead>, <tbody>, <tfoot>
<thead>, <tbody>, <tfoot>
三个标签组合使用,用来规定表格的各个部分:表头、主体、页脚。表格表头和表格页脚会独立于表格主体,不随主体滚动。当包含多个页面的长表格被输出时,表格的表头和页脚可被显示在包含表格数据的每个页面上。
可以只使用<tbody>
,可定义任意多个<tbody>
。
<thead>
需在<caption>, <colgroup>
元素之后,<tbody>, <tfoot>, <tr>
之前。
三个元素的内部都必须包含一个或者多个<tr>
标签。
这三个标签不包含特殊的样式。可使用CSS为它们定义样式。
tBodies
tBodies
返回表格的<tbody>
元素的集合。 语法:tableObject.tBodies
例:
在表格的第1个tBody
的最后插入行元素:table.tBodies[0].appendChild(tr_node)
。
HTML列表分为有序列表(带标号)、无序列表(无标号,项目符号不是数字而是黑色实心圆点)、自定义列表。
<li>
(list item)定义有序与无序列表的列表项目,<dt>, <dd>
(definition term, definition description)定义自定义列表项目及其注释。
列表项目内部可以使用段落、换行符、图片、链接和其他列表等。
<ol>
<ol>
(ordered list)定义有序列表,项目符号默认为数字。属性:
compact
:规定列表呈现的效果比正常情况更小巧。HTML5不支持,应使用CSS代替。
reversed
:规定列表顺序为降序显示。
start
:规定有序列表的项目符号的起始值,值为数字。
type
:规定列表的项目符号类型,取值为1、A、a、I、i(I,i分别代表罗马数字大小写)。
<ul>
<ul>
(unordered list)定义无序列表,项目符号默认为黑色实心圆点disc。二级嵌套无序列表符号为circle,三级及之后嵌套无序列表符号为square。属性:
compact
:规定列表呈现的效果比正常情况更小巧。不推荐使用,应使用CSS代替。
type
:规定列表的项目符号的类型。有三种取值:disc(黑色实心圆点)、circle(空心圆点)、square(黑色实心方块)。不推荐使用,应使用CSS代替。
<dl>
<dl>
(definition list)定义自定义列表。自定义列表的每条项目是项目及其注释的组合。 <dt>
(definition term)开始,每个自定义列表项目的注释以<dd>
(definition description)开始。例子:
<dl>
<dt>Coffee</dt>
<dd>black hot drink</dd>
<dt>Milk</dt>
<dd>white cold drink</dd>
</dl>
大多数HTML元素属于块级元素(block/block-level element,块元素)。
显示块级元素时,通常会从新行开始(以新行结束)。相邻的块级元素会在不同行显示。
通过CSS,可为块级元素添加display:inline
属性使其不换行显示。
特点:
1. 在新行开始(但可更改)。
2. 高度、行高、外边距、内边距都可控制。
3. 宽度缺省默认为其容器的100%,也可设定。
4. 一般可容纳内联元素和其它块级元素。
常见块级元素:
标题<h1>, <h2>, ...
,<p>
,列表<ol>, <ul>
,<table>
。
<div>
<div>
(division)为块级元素,是用于组合其它HTML元素的容器,可定义文档中的一个区域或节(division/section)。 <div>
可用作严格的组织工具,可以把文档分割为独立且不同的部分,以添加额外的文档结构,且不使用任何格式与其关联。通过CSS,可对该区域/内容块的所有元素设置样式属性。
可用于文档布局,以取代用表格<table>
定义布局的传统方法。
显示时其前后会有换行。
属性:
class
:定义该div所属的div类别。
id
:唯一标识该div。
align
:规定div元素中的内容的对齐方式。已废弃,应使用CSS代替。
与块级元素对应的为行内元素(inline element,内嵌元素,内联元素,直进式元素)。
显示行内元素时,会在同一行从左到右显示,不单独另占一行。
通过CSS,可为块级元素添加display:block
属性使其换行显示。
特点:
1. 不会从新行开始,与其它元素在一行上(但可更改)。
2. 高度、行高、外边距、内边距不可改变。
3. 宽度就是其文字或图片的宽度,不可改变。
4. 只能容纳文本或行内元素。
常见行内元素:
<a>
,<b>
,<img>
,<td>
,<big>
,<sub>
。
<span>
<span>
为行内元素,用来组合其它行内元素,可将文本或文档的一部分独立出来以添加额外的结构。 <span>
默认不会有格式变化(但仍将这一部分独立出来,添加了额外结构),用CSS可定义其样式,用JavaScript可对其进行操作。属性:
class
:定义该span所属的span类别。
id
:唯一标识该span。
例:
为class为tip的段落,设置span格式(该span为tip类的子元素):
CSS:
p.tip span {
font-weight: bold;
color: #ff9955;
}
HTML:
<p class="tip"><span>提示:</span>abcde</p>
大多数网站会把内容安排到多个列中(只要剩余宽度足够大,即使有换行内容也会在右侧显示)。
为多个div元素设置合适的宽度,可以实现多列内容的布局。
使用table也可创建多列内容,但并不推荐将table作为布局工具使用。
表单(Form)是一个包含表单元素的区域,用于数据采集。
一个表单有三个基本组成部分:表单标签、表单域(包含各种输入框或上传框)、表单按钮(如提交、复位、运行其它脚本)。
<form>
<form>
定义,为块级标签、空标签。属性:
action
:值为URL。规定当提交表单时向何处发送表单数据。
autocomplete
:值为on或off。规定是否启用表单的自动完成功能。自动完成允许浏览器预测对字段的输入:浏览器会记忆之前提交过的值,当在字段开始键入时,会显示出与当前输入内容匹配的过去提交过的值。
enctype
:规定在发送表单数据之前如何对其进行编码。默认为"application/x-www-form-urlencoded"。
method
:值为get或post。规定用于发送 form-data 的 HTTP 方法。
name
:规定表单的名称。
rel
:规定链接资源和当前文档之间的关系。
target
:规定在何处打开 action URL。
novalidate
:当值为"novalidate"时,提交表单时不进行验证。
input
标签一般通过输入标签<input>
输入元素。输入类型由其类型属性type决定。为空标签。
属性:
alt/src
:只能在<input type="image" src="...">
时使用。为图像设置替代文本/设置显示图像的URL。
autocomplete
:值为on或off。规定输入字段是否应该启用自动完成功能。自动完成允许浏览器预测对字段的输入:浏览器会记忆之前提交过的值,当在字段开始键入时,会显示出与当前输入内容匹配的过去提交过的值。
autofocus
:当值为"autofocus"时,规定输入字段在页面加载时会获得焦点。不适用于type="hidden"。
checked
:当值为"checked"时,规定此input元素首次加载时默认已被选中。
disabled
:当值为"disabled"时,禁用此input元素。被禁用的input元素既不可用,也不可点击。可通过JS在达成某些条件时,删除其disabled值使其可用。不适用于type="hidden"。
form
:值为某些表单的id(不能是name)。规定该输入字段所属的一个或多个表单(即使在这些表单之外)(多个表单用空格分隔)。
formaction/formenctype/formmethod/formtarget
:取值与表单对应属性相同。覆盖表单的action/enctype/method/target属性。适用于type="submit"和type="image"。
height/width
:值为像素或百分比。定义input字段的高度/宽度。仅适用于type="image"。
max/min
:规定输入字段的最大值/最小值。
maxlength
:规定输入字段中的字符的最大长度。
multiple
:当值为"multiple"时,规定输入子段可选择多个值。仅适用于type="email"、type="file"。
name
:定义 input 元素的名称。
pattern
:限制输入字段的值的模式或格式。格式使用正则表达式。
placeholder
:提供可描述输入字段预期值的提示信息(hint),规定帮助用户填写输入字段的提示。该提示会在输入字段为空时显示,并会在字段获得焦点时消失。
readonly
:当值为"readonly"时,规定输入字段为只读。只读字段不能修改,但仍可选中该子段。可通过JS在达成某些条件时,删除其readonly值,将输入字段切换到可编辑状态。
required
:当值为"required"时,指定该输入字段的值是必填/必选的。不填时提交表单会提交失败并出现提示。
size
:定义输入字段的宽度。
step
:规定输入字段的合法数字间隔(且输入只能为数字)。如:step="3"时,合法数字输入只能为。可与min, max
一起使用以创建准确的合法值范围。用于下面的input
类型:number、range、date、datetime、datetime-local、month、time、week。
type
:规定 input 元素的类型。
value
:规定 input 元素的值,为输入字段的默认值和提交到服务器的值。输入的内容会更改并存储在该input元素的value中。
<input type="text">
定义。可输入任意内容。 例:
<form>
First name: <input type="text" name="firstname"><br>
Last name: <input type="text" name="lastname">
</form>
密码字段
密码字段通过<input type="password">
定义。可输入任意内容,其字符不会明文显示,而是以星号或圆点替代。
单选按钮
单选按钮(radio buttons)通过<input type="radio">
定义。同一组单选按钮只能选中一个。
通过设定相同的name取值,来制作一组单选按钮。
注意它只是定义了一个按钮,按钮后的内容与其无关(因为value属性显示不出来)。
属性:
alt
:设置在不支持单选按钮时显示的替代文本。
checked
:表示当前按钮的状态,可设置checked="checked"
来使按钮默认被选中。
id/name
:设置单选按钮的id/名称。
tabIndex
:设置单选按钮的tab键控制次序。
value
:提交到服务器的值(选中某按钮会传递它的value)。
例:
<form>
<p>你生活在哪个国家?</p>
<input type="radio" name="country" value="China" checked="checked">中国<br />
<input type="radio" name="country" value="the USA">美国
</form>
<input type="checkbox">
定义。可选取任意多个选项。 属性:
同单选按钮(radio buttons)。
<input type="submit">
定义。 注意,点击提交按钮后,网页似乎会被重新加载,导致其它元素被重新加载。如果不想这样,使用一般的button
按钮实现提交。
但还要注意,不使用submit
提交会导致<input>
的内容检查不起作用(如min, step, required
检查)。
属性:
同单选按钮(radio buttons)。但按钮上显示的文字与value属性相同。
<input type="reset">
定义。 属性:
同单选按钮(radio buttons)。但按钮上显示的文字与value属性相同。
例:
<form action="demo.php">
Email: <input type="text" name="email"><br>
Pin: <input type="text" name="pin" maxlength="4"><br>
<input type="reset" value="重置">
<input type="submit" value="提交">
</form>
input type="button"
定义。 属性:
alt
:设置在不支持该按钮时显示的替代文本。
disabled
:当值为"disabled"时,规定禁用该按钮。
form
:值为某些表单的id(不能是name)。规定该输入字段所属的一个或多个表单(即使在这些表单之外)(多个表单用空格分隔)。
id/name
:设置单选按钮的id/名称。
tabIndex
:设置单选按钮的tab键控制次序。
value
:提交到服务器的值。
input type="file"
定义。 属性:
accept
:设置指示文件传输的 MIME 类型的列表(逗号分隔)。
其余同可点击按钮(button)。但value
为用户输入设置的文本/上传文件后,FileUpload对象的文件名。
input type="hidden"
定义。 value
设定值)。属性:
同可点击按钮(button)。
input type="image"
定义。 属性:
alt
:必需,规定图像的替代文本。
src
:必需,规定显示图像的URL。
input type="number"
可定义数字选择选项,用Input Number对象表示。 属性:
step, min, max
:见<input>
属性。
value
:设置或返回date字段的value值,如value="3"
。
input type="datetime"
可定义日期选择选项,用Input Date对象表示。 属性:
step, min, max
:见<input>
属性。
value
:设置或返回date字段的value值,如value="2021-09-01"
。
step, min, max
:见<input>
属性。 input type="week"
可定义周选择选项,用Input Week对象表示。 属性:
value
:设置或返回week字段的value值,如value="2021-W35"
。
select
标签通过<select>
创建单选或多选菜单(下拉选择列表)。
属性:
autofocus
:当值为"autofocus"时,规定在页面加载后文本区域自动获得焦点。
disabled
:当值为"disabled"时,规定禁用该下拉列表。
form
:值为某些表单的id(不能是name)。规定该下拉列表所属的一个或多个表单(即使在这些表单之外)(多个表单用空格分隔)。
multiple
:当值为"multiple"时,规定可选择多个选项。
name
:规定下拉列表的名称。
required
:当值为"required"时,规定它是必填的。
size
:规定下拉列表中可见选项的数目。
<option>
<select>
通过<option>
元素定义下拉列表中的一个选项(一个条目)。为空标签。 <option>
标签中的内容作为<select>
标签的菜单或是滚动列表中的一个元素显示。属性:
disabled
:当值为"disabled"时,规定禁用此选项。
label
:规定更短版本的选项。下拉列表中会显示出所规定的更短版本。只有IE 7+支持label属性。
selected
:当值为"selected"时,规定选项(在首次显示在列表中时)表现为选中状态。当有多个选项有该属性时,会显示其中最后的选项。
value
:提交到服务器的值。
<optgroup>
<select>
中将相关的选项(若干<option>
)组合在一起,用于为选项列表分类。属性:
label
:必需,为该选项组规定描述。
disabled
:当值为"disabled"时,规定禁用此选项组。
例:
该下拉列表默认显示Mercedes,且禁用French Cars选项组。
<select>
<optgroup label="Swedish Cars">
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
</optgroup>
<optgroup label="German Cars">
<option value="mercedes" selected>Mercedes</option>
<option value="audi">Audi</option>
</optgroup>
<optgroup label="French Cars" disabled>
<option value="none">???</option>
</optgroup>
</select>
fieldset
标签<fieldset>
可将表单内容的一部分打包/分组,生成一组相关表单的字段。
当一组表单元素放到<fieldset>
内时,浏览器会以特殊方式来显示它们:它们可能有特殊的边界、3D效果,甚至可能创建一个子表单来处理这些元素。
属性:
disabled
:当值为"disabled"时,规定禁用此fieldset。
form
:值为某些表单的id(不能是name)。规定该fieldset所属的一个或多个表单(即使在这些表单之外)(多个表单用空格分隔)。
name
:规定 fieldset 的名称。
用<legend>
为<fieldset>
元素定义标题(caption)。
例:
<form>
<fieldset>
<legend>健康信息</legend>
身高:<input type="text" /><br />
体重:<input type="text" />
</fieldset>
</form>
label
标签<label>
为<input>
元素定义标注/标记。它没有特殊显示效果,但如果点击<label>
元素内的文本,会触发点击相应的<input>
元素,即选中对应的选项或将焦点移到对应的文本框。
定义<label>
的for
属性为一个<input>
元素的id
,以关联该元素。
注:
在多行文本框中每行加入一个<label>
包含文本框名称,并设置文本右对齐、宽度一致,可实现多行文本框的竖直对齐(注意设置display: inline-block
)。
例:
<p>
<label for="id" style="width: 80px; padding: 2px 6px; display: inline-block; text-align: right;">ID:</label><input id="id" type="number" step="1" min="1" required>
</p>
<p>
<label for="name" style="width: 80px; padding: 2px 6px; display: inline-block; text-align: right;">姓名:</label><input id="name" type="text" required>
</p>
<p>
<label for="email" style="width: 80px; padding: 2px 6px; display: inline-block; text-align: right;">email:</label><input id="email" type="text" required>
</p>
<p>
<label for="gender" style="width: 80px; padding: 6px 6px; display: inline-block; text-align: right;">性别:</label>
<select id="gender">
<option value="male">男</option>
<option value="female">女</option>
<option value="secret" selected>保密</option>
</select>
</p>
属性:
for
:规定 label 绑定到哪个表单元素。
form
:规定 label 字段所属的一个或多个表单。
<iframe>
<iframe>
不是空标签。如果浏览器不支持<iframe>
,则会显示开始和结束标签之间的内容(用来做框架的替代文本,但一般没什么用)。属性:
frameborder
:取值为0或1。规定是否显示框架周围的边框。
height/weight
:规定iframe的高度/宽度。单位为像素或百分比。
marginheight/marginweight
:定义iframe的 顶部和底部/左侧和右侧 的边距。单位为像素。
name
:规定 iframe 的名称。
sandbox
:启用对行内框架中内容的额外限制。其值会移除对应的限制,比如当值为空字符串时,启用所有限制;当值为空格分隔的预定义值列表时,会移除这些限制。
一共有四种限制可被启用或移除:
allow-same-origin
:允许 iframe 内容被视为与包含文档有相同的来源。
allow-top-navigation
:允许 iframe 内容从包含文档导航(加载)内容。
allow-forms
:允许表单提交。
allow-scripts
:允许脚本执行。
scrolling
:取值为yes, no, auto。规定是否在 iframe 中显示滚动条。
seamless
:当值为"seamless"时,规定 iframe 看上去像是包含文档的一部分(无边框或滚动条)。
src
:规定在 iframe 中显示的文档的 URL。
srcdoc
:值为HTML代码。规定在 iframe 中显示的页面的 HTML 内容。如果浏览器支持该属性,会覆盖src属性;否则会被忽略。
例:
<a>
标签的target属性可以设置为某框架,点击链接时页面会显示在对应框架中。
以下例子中,点击链接后runoob网页会显示在框架中。
<p>
该内联框架不会换行。
<iframe src="https://home.cnblogs.com/u/SovietPower/" name="iframe_a" width="300" height="200">
<p>您的浏览器不支持框架。</p>
</iframe>
虽然是块级标签。
</p>
<p><a href="https://www.runoob.com" target="iframe_a">GO TO RUNOOB.COM</a></p>
注:
X-Frame-Options HTTP 响应头是用来给浏览器指示是否允许一个页面在<frame>, </iframe>
或者<object>
中展现的标记。网站可以使用此功能,来确保自己网站的内容没有被嵌套到别人的网站中去,也从而避免了点击劫持 (clickjacking) 的攻击。
X-Frame-Options有三种取值:
DENY:表示该页面不允许在frame中展示,即便是在相同域名的页面中嵌套也不允许。
SAMEORIGIN:表示该页面可以在相同域名页面的frame中展示。
ALLOW-FROM uri:表示该页面可以在指定来源的frame中展示。
HTML使用RGB或RGBA(Red-Green-Blue-Alpha)颜色值。RGBA为RGB拓展了alpha通道,允许设置透明度(取值为0~1,0为全透明)。
RGB共有1600多万种颜色取值()。
颜色由红(R)、绿(G)、蓝(B)组成。颜色值(RGB)是一个表示了红、绿、蓝的数值,记作#号后加六位或三位十六进制数(用三位表示时,如#RGB,会表示#RRGGBB)。
红、绿、蓝的每个颜色的最小值为0(0x00),最大值为255(0xFF),用两位或一位十六进制数表示(为一位时表示另一位与其相同)。
使用颜色名称可代替颜色值。
有141种颜色定义了颜色名称。其中有17种标准颜色:黑,蓝,水,紫红,灰,绿,石灰,栗,海军,橄榄,橙,紫,红,白,银,蓝绿,黄。
JS笔记见:https://www.zybuluo.com/SovietPower/note/1820040
<script>
<script>
可定义客户端脚本,比如JavaScript。 <script>
既可包含脚本语句,也可通过src属性指向外部脚本文件。注意,假如此元素内部的代码没有位于某个函数中,那么这些代码会在页面被加载时被立即执行。<frameset>
标签之后的脚本会被忽略。
属性:
type
:必需,指示脚本的 MIME 类型。
async
:当值为"async"时,规定异步执行脚本(仅适用于外部脚本)。
charset
:规定在外部脚本文件中使用的字符编码。
defer
:当值为"defer"时,对脚本执行进行延迟,直到页面加载为止。如果脚本不会改变文档内容,可将defer属性加入到<script>
标签中,以便提高加载文档的速度。因为这告诉浏览器它能安全地加载文档的剩余部分而不用执行脚本,它将推迟对脚本的解释,直到文档已经完全显示给用户。只有IE支持defer。
src
:规定外部脚本文件的 URL。
xml:space
:规定是否保留代码中的空白。
<noscript>
<noscript>
中的内容。<noscript>
元素可包含几乎所有元素。 <script>, </script>
后添加<noscript>
可用于显示<script>
的替代内容。<code>
<code>
定义预格式化的代码文本。
<em>, <strong>
<em>, <strong>
分别定义被强调的文本、重要的文本,分别用斜体、粗体呈现。
<dfn>
<dfn>
定义一个定义项目(一种格式)。
更推荐使用CSS以获得更好的效果。
<var>
<var>
定义变量(一种格式)。
更推荐使用CSS以获得更好的效果。
<samp>
<samp>
定义计算机程序的样本文本(一种格式)。
更推荐使用CSS以获得更好的效果。
<kbd>
<kbd>
定义键盘文本(一种格式)。
已废弃,不推荐使用。推荐使用CSS以获得更好的效果。
textarea
标签<textarea>
定义多行的文本输入控件。该文本区中可容纳无限数量的文本。文本的默认字体是等宽字体(通常为Courier)。
属性:
autofocus, disabled, form, maxlength, placeholder, readonly, required
:见<input>
。
cols, rows
:定义文本区的大小。推荐使用CSS的height, width
属性。
wrap
:规定文本区域如何换行。
若
wrap="wrap"
,文本区不会自动换行,超出右边界的部分需移动光标才可见,只能由用户使用回车换行。
若wrap="virtual"
,文本区会在显示时自动换行,即超出右边界的部分会显示到下一行。当文本内容提交时,自动换行的换行符不会被提交,即该换行符只对用户可见。
若wrap="physical"
,文本区会在显示时自动换行,即超出右边界的部分会显示到下一行。当文本内容提交时,自动换行的换行符也会被提交,即该换行符不仅对用户可见,还会同输入内容一起被提交。
meter
标签<meter>
显示数值条,来表现一个进度或数据度量。也被称为 gauge(尺度)。
不用做进度条,用做度量,如磁盘使用情况。进度条使用<progress>
。
IE不支持。
属性:
value
:必需,规定度量的当前值。
form
:规定其所属的一个或多个表单。
low/high
:规定被视为合适的数值范围(感觉上是:在该范围中的数值条为绿色,该范围外的数值条为黄色。但实际表现并不如此,而且有红色,很迷惑)。low/high
值必须合法,如low应不小于min,不大于high, max。
min/max
:规定数值条最左最右的界限代表的值(低于min
则条为空,高于max
则条全满)。
optimum
:规定一个最佳值。
例:
<meter value="3" min="0" max="10">会显示3/10(meter间的内容不会被显示)</meter><br>
<meter value="0.6">会显示60%</meter>
progress
标签<progress>
显示进度条,来标示任务的进度(进程)。
不用做度量,用做进度条。数值度量使用<meter>
。
IE不支持。
属性:
value
:必需,规定当前完成的数量(进度条显示量即为value/max)。
max
:默认为1。规定应完成的数量,即进度条满时value应达到的数值。
例:
<progress value="3" max="10">会显示0.3的进度状态(progress间的内容不会被显示)</progress><br>
<progress>不填写value时,会显示进度左右移动的进度条</progress>
具体见:https://www.zybuluo.com/SovietPower/note/1824527
CSS(Cascading Style Sheets,层叠样式表)用于渲染HTML元素标签的样式(定义如何显示HTML元素)。
CSS可以通过以下方式添加到HTML中:
内联样式:在HTML元素中使用
style
属性。
内部样式表:在HTML文档头部<head>
区域使用<style>
元素来包含CSS。
外部引用:使用外部CSS文件(样式表,样式通常存储在外部的.css
样式表文件中)。
最好的方式是通过外部引用CSS文件。内联样式更方便。
CSS修饰标签的方式分为两种:内联和外引。
对于大部分标签,内联和外引两种方法均可,且修改父级标签,子级标签特性也会改变。但某些标签确无法通过修改父级标签来改变子级标签特性,如<a>
标签,修改其颜色特性,必须直接修改<a>
标签的特性才可。
CSS规则由两个主要部分构成:选择器和一条或多条声明。
选择器是需要改变样式的HTML元素。每条声明是一个属性:值
对,属性(property)是要设置的样式属性(style attribute),每个属性都有一个值。
每条声明以分号结束,所有声明用大括号括起来。
如:h1 {color:blue; font-size:12px;}
,h1
为选择器,color:blue
、font-size:12px
为两条声明,冒号前为属性、后为值。
为了让其可读性更强,通常一行只写一句声明。
CSS注释类似C++,以/*
开始、以*/
结束。
<>
属性:
:
:
:
:
:
:
:
:
:
:
<>
属性:
:
:
:
:
:
:
:
:
:
: