在HTML中使用form来创建一个表单,表单中包含各式各样的输入控件、选框以及按钮。最终表单要提交到服务器,这就需要在form标签上面设置method=‘post‘
和action=‘index.php‘
。表单中 可以使用fieldset
来区分不同的类型的输入信息,使用<legend></legend>
。
<form method="post" action="index.php">
<fieldset>
<legend>
基本信息
</legend>
<!--一些输入控件--->
</fieldset>
<fieldset>
<legend>
详细信息
</legend>
<!--一些输入控件--->
</fieldset>
</form>
输入控件主要是input标签,不同类型的输入控件,它的type属性值不一样:
type=‘text‘ 普通文本框 可以输入一行信息 一般是短内容的输入,它支持的属性:
文本框还可以配合datalist标签一起使用,datalist用来输入提示信息,每个提示项放在<option>
标签中,然后在文本框里面使用list属性关联该datalist列表:
<input type=‘text‘ name=‘username‘ list=‘rel‘>
<datalist id=‘rel‘>
<option value="Wang" />
<option value="Hey Gor" />
<option value=‘lautin‘ />
</datalist>
type=‘password‘ 密码框,输入内容不可见,它的属性同文本框相似
type=‘number‘ 数值输入框,指定输入数值以及控制它的范围,属性如下:
type=‘date‘ 它可以生成一个日历控制面板 供用户选择一个日期 避免输入格式的混乱
2019-08-12
type=‘color‘ 它可以一个颜色面板 供用户选择
type=‘url‘ 支持输入一个url地址,在提交时 会验证格式中是否包含http(s)://
协议
type=‘email‘ 支持输入一个邮箱地址,同样在提交时 会自动严格它的格式 至少写成a@b
表单中的按钮选框也是使用input,它有几种类型:
表单中 必须的控件还有按钮,按钮也分为几种:
特别强调
所有的表单控件(输入控件、选框等)都必须声明它的name
属性,用于服务端接收数据
<style>
选择器 {
/*声明列表*/
属性1:值1;
属性2:值2;
}
</style>
在HTML中嵌入css样式 有三种方式:
当对同一元素 使用了不同的方式定义了同一个属性,会存在优先级,采用就近原则。
.类名
来选中元素。class可以同时标记多个元素#ID
来选中该元素,ID名不能重复关系选择器是通过元素之间的关联关系来查找元素,例如:父子关系、兄弟关系、邻里关系
S1 S2
,匹配S1内部的所有后代S2,不限于某一级S1>S2
,匹配S1中的下一级S2,也就是“子级”元素。S1+S2
,匹配S1后面紧挨着的同级(兄弟)元素S2S1~S2
,匹配S1后面的所有同级(兄弟)元素S2在书写时 关系符号和元素之间 可以有空白符,但不建议加,可以使用格式化去除。
根据HTML标签的属性特征来选择元素,它有几种匹配的方式:
[attr]
:[]表示匹配具有attr属性的元素 ,不要求值[attr="aa"]
表示具有attr属性且为定值aa的元素[attr*="aa"]
表示具有attr属性,值包含aa关键字即可[attr~="aa"]
表示具有attr属性,值中包含aa单词,aa必须作为一个单词出现[attr^="aa"]
表示具有attr属性,值以aa开头即可[attr$="aa"]
表示具有attr属性,值以aa结尾即可伪类选择器是通过单冒号(:)和特定的具有某种含义的单词来确定所选元素。
所谓伪类选择器,是相对于“类选择器”来说的,对比如下:
类选择器:
说明:类的名称是由我们程序员来设定的,符合命名规范就行。
形式:.类名称{ ... }
伪类选择器:
说明:伪类的名称是CSS标准中所预先设定的,我们不能自己设定。可用的伪类名不多。
形式::伪类名称{ ... }
这4个伪类主要用于表示一个链接(也就是a标签)的4种不同状态。
它们可以设定一个链接在不同状态下的外观表现(样式表现)。
:link
——表示一个链接初始时候的状态。
:visited
——表示一个链接在访问(点击)过之后的状态。
:hover
——表示一个链接在鼠标移上去(鼠标悬停)的时候的状态。
:active
——表示一个链接在活动状态的时候的状态,通常就是点击的瞬间(按住不放能看到)。
注意:
表示一个元素在成为可输入状态(获得焦点)的时候,主要用于表单元素。
其中“E”表示某个元素(或某个选择器所选中的元素)。
前缀元素E是表示该元素在获得焦点的时候,其样式表现如何。
也可以不用前面写“E”,而是直接用“:focus”,但实际应用中,一般会在前面有这个限定。
比如:
input:focus{ .... } /表示input元素在获得焦点的时候/
也可以不用input,如下所示:
:focus{ .... }
但此时其实所选择的范围扩大了(不仅仅针对input元素)。
这几个伪类用于表示(或选中)“具有某种特征的子元素E”,它有如下几种形式:
E:first-child
——匹配作为父元素的第一个子元素E。
E:last-child
——匹配作为父元素的最后一个子元素E。
E:only-child
——匹配作为父元素的唯一一个子元素E。
E:nth-child(n)
——匹配作为父元素的第n个子元素E。括号中的n是一个具体数字
E:nth-last-child(n)
--匹配作为父元素的倒数第n个子元素E,n的值从1开始
li:first-child{ ... } /*表示作为第一个子元素的li标签*/
td:last-child{ ... } /*表示作为最后一个子元素的td标签*/
p:only-child{ ... } /*表示作为父元素中只有一个子元素且为p标签*/
li:nth-child(2){ ... } /*表示作为第2个子元素的li标签*/
子元素选择器中 一些特殊的用法:
:nth-child(2n+1)
在表达式2n+1中,n的值从0开始,代表0,1,2,3,,,,n这样的值。它表示每2个中的第1个元素,也就是所有子元素中编号为奇数的那些。编号为偶数的即是2n
或者2n+2
nth-last-child(-n+3)
表达式中n的值也是0,1,2,,,n,随着n值的改变 -n+3
表达式的值是3,2,1
,对应的倒数前3个元素。也就是说-n+x
可以用来选择连续倒数的x个元素。注意:上述也可以单用(不要冒号前面的部分),但一般较少这样用。
<style>
li:empty {
color : red;
}
</style>
<ul>
<li>item1</li>
<li> </li>
<li></li> /*它会变红*/
</ul>
radio和checkbox
伪元素选择器是通过双冒号(::)和特定的具有某种含义的单词来确定所选元素。
伪元素选择器通常是"本没有这个元素(标签)",但会创建出一个隐性元素并对其进行样式设定。
伪元素选择器又称为“伪对象选择器”。
E::before
表示会创建一个新元素并添加到元素E的内部的最前面(伪元素)。
其中必须写上一个属性:content:"内容"
; 当然,内容可以为空。
E::after
表示会创建一个新元素并添加到元素E的内部的最后面(伪元素)。
其中必须写上一个属性:content:”内容”;
E::selection
E::first-line
E::first-letter
选择器的组合是将多个不同形式的选择器组合起来以确定所选元素,它主要有以下几种形式:
div , p
选择div和p所谓层叠性,是指对同一元素同一属性的设定,后设定的某个样式(属性)会覆盖之前设定的样式。例如:
.d1 { color: red; }
.d1 {color: blue; }
<div class="d1">文字内容</div>
则此时文字颜色就是blue,即后者覆盖了前者的设定。
事实上它分为两种情况:
body .d1 { color : red; }
div.d1 { color : blue; }
所谓继承性,是指对某个元素所设定的样式,不但影响该元素本身,还影响该元素的后代元素。例如:
.d1 {color:red;}
<div class="d1">
文字1
<p>文字2</p>
</div>
则此时文字1和文字2实际都是红色。
实际上继承性不是普遍情况,而只是少数一些属性才具有继承性(即能够影响后代元素)。
应用中继承性通常用在有关文字属性上。
所谓盒子,就是将HTML网页中的标签在网页版面中所占据的平面范围,抽象出来的一个“视觉形状”。
一个简单的理解就是:几乎所有标签,都可以看做是一个“矩形盒子”,具有一定的宽高(区域)。
总体上来说,一个盒子是由若干个部分构成的,从内到外依次包括:
? 盒子内容区,内边距区,边框,外边距区
content:内容
padding:内边距,又称为内补白,是一片空白区域
border:边框
margin:外边距,又称为外补白,也是一片空白区域
top,right,bottom,left:上,右,下,左
特别注意:
一般情况下,给容器设置的width和height是指内容区的大小,不包括边框和内边距。事实上盒子模型有两种,可以通过box-sizing
来设置:
? 1.1 外扩型:内容区大小不变 当设置内边距和边框时 盒子模型放大
? 1.2 内减型:盒子的总大小不变 当设置内边距和边框时 内容区减小
平常我们看不到内边距,边框和外边距,是因为他们默认都是0(宽度,或厚度)。
与盒子模型相关的属性有:
边框可以使用border缩写形式,它包含三个属性:border-width,border-style,border-color。这里使用border是给盒子整体设置的边框,还可以分别设置某一侧的边框:
css中 合成词 都是以"-"作为逻辑断点的
div {
border-bottom:1px solid red;
}
div {
border-bottom-width : 1px;
border-bottom-color : red;
border-bottom-style : solid;
}
outline是边框以外的轮廓设置,它有四个属性:
基本使用:
div {
background: url() no-repeat left top red;
}
精灵图(spirit)设计
width和height设置盒子内容区的尺寸,重点:只有块级元素 才有盒子模型的概念以及尺寸大小。
css中使用padding给盒子或者元素 添加内补白(内间距),它是元素和边框之间的距离,有四个方向:
左边距:padding-left
右边距:padding-right
上边距:padding-top
下边距:padding-bottom
缩写形式:padding,书写时要遵循固定的顺序(顺时针):↑→↓←
div {
padding-top : 5px;
padding-right : 10px;
padding-bottom : 15px;
padding-left : 20px;
padding : 5px 10px 15px 20px;
padding : 8px;/*四个方向都是8px*/
padding : 8px 18px; /*上下8px 左右18px*/
padding : 8px 18px 25px;/*缺省的第四个值 取第二个*/
}
margin是外补白,也就是外边距,它的设置和padding是一样的:
原文:https://www.cnblogs.com/xiaoyixiang/p/14900540.html