表单是什么?——表单不是表格。
用户可以在其中提供一定的数据或信息或选项的一些html元素。表单通常有一个“提交”按钮,然后可以将这些数据据/信息/选项提供给服务器上的程序使用——数据处理。
——表单的核心是数据。
表单标签的构成和形式:
<form name=”form1” action=”将本表单中的数据提交给的对象(是一个php文件名而已)” method=”post”>
第一个表单项
第二个表单项
。。。。。。。
</form>
到底有哪些表单项?
单行文本框:<input type=”text” name=”n1” />
其他属性:
value:设定其中的初始文字
size:设置其输入框的宽度(单位是“字符宽”)——其中能放置该数量的字符
maxlength:设置该输入框最多能输入的字符个数
readonly:这是一个“无值”属性,表示“只读”,则写法是:readonly=”readonly”
disable: 设置该输入框“无效”,即数据无效。
密码框:<input type=”passWord” name=”n2” />
其他属性:
value:设定其中的初始文字
size:设置其输入框的宽度(单位是“字符宽”)——其中能放置该数量的字符
maxlength:设置该输入框最多能输入的字符个数
单选项:<input type=”radio” name=”n3” value=”某个值” />
说明:单选项通常必须有value值;
其他属性:
checked: 表示该选项默认是选中的状态。也是一个“无值属性”
name特别说明:一组的单选项要求name值必须相同。
多选项:<input type=”checkbox” name=”n4” value=”某值” />
说明:多选项通常必须有value值;
其他属性:
checked: 表示该选项默认是选中的状态。也是一个“无值属性”
提交按钮:<input type=”submit” name=”n5” value=”提交文字” />
说明:点击提交按钮,则表单就会“被提交”,即数据会传入到表单的action所设定的文件中去。
图片按钮:<input type=”image” name=”n6” src=”图片地址” />
说明:图片按钮的功能其实也是“提交”,但其显示出来的效果是一张图片——这样有利于美化页面。
重置按钮:<input type=”reset” name=”n7” value=”重置文字” />
说明:会将表单的所有用户填写或选择的数据恢复到初始状态
普通按钮:<input type=”button” name=”n8” value=”文字” />
说明:对表单没有影响,但可以从中产生“动作”以实现其他要求(js程序)
文件域:<input type=”file” name=”n9” />
说明:可以让用户选择本地的文件(并发送到服务器)——文件也是数据。
隐藏域:<input type=”hidden” name=”n10” />
说明:界面上不可见,但是作为一份“隐藏的数据”提交给服务器——编程所需。
下拉选择:使用select和option标签配合实现。但要把此当作“一个表单项”
<select name=”n11” multiple=” multiple” >
<option value=”1” >文字1</option>
<option value=”2” selected=”selected” >文字2</option>
<option value=”3” >文字3</option>
………………….
</select>
说明:
option标签上可以使用selected属性,表明该select元素的默认选中的项(默认是第一项被选中)。
select标签上可以使用multiple属性,使该select元素可以“选择多项”(即默认只能选一个)
多行选项(也叫列表选项):多行选项其实只是下拉选择的一种“变形”——设置其size值大于等于就会成多行。
<select name=”n12” size=”4”>
<option value=”1” >文字1</option>
<option value=”2” >文字2</option>
<option value=”3” >文字3</option>
………………….
</select>
多行文本框:
<textarea name=”n13” rows=”行数” cols=”列数”></textarea>
说明:
rows设定的行数是一个数字,表示该多行文本框可以显示的文字的行数
cols设定的列数是一个数字,表示该多行文本框可以显示的一行文字中个数
此标签没有value属性。但其实际的“值”是放在此标签中间的所有内容。
注意:表单项都必须有name属性,以表明其“名字”——服务器取其中的数据就是凭此名字。
框架标签第一个观念:我们在打开的一个“窗口”中总是只会显示一个网页。
但是:
我们其实也可以在一个窗口中打开多个网页——其实其实质还是一个窗口显示一个网页,只是我们会使用某些特定标签(frameset)来将一个“大窗口”分割成若干个“小窗口”。
首先要明确:
1, 使用框架标签(frameset)就不能使用body标签——即body标签使用frameset标签代替
2, 使用frameset标签就要使用framseset文档类型
则具体分割代码如下:
<frameset cols=”将当前窗口按列分割的设置” rows=”将当前窗口按行分割的设置”>
<frame src=”网页1路经url” />
<frame src=”网页2路经url” />
。。。。。。。。。。。。。
</frameset>
cols的值是连续的表示列的宽度的数字或百分数,相互之间用(,)分开,其中“*”号表示“其余”的宽度。比如:
cols=”100,800” :表示将大窗口按列分割成两个小窗口,第一个为100宽,第二个为800宽
cols=”100,200,*” :表示将大窗口按列分割成3个小窗口,第一个为100宽,第二个为200宽,其余给第3个
cols=”15%, *”
rows的值是连续的表示行的宽度的数字或百分数,相互之间用(,)分开,其中“*”号表示“其余”的宽度。比如:
rows=”100,200,*”
row=”20%, *”
注意:一个frameset只能按某一个方向(列或行)进行分割
CSS介绍CSS:Cascading Style Sheet(层叠样式表)
CSS能够让我们将网页从以下两个方面来控制网页的外观:
1, 批量控制网页的外观,使我们节省劳力。
2, 精确控制网页的外观:到像素级别。
css的基本语法形式:
选择器 { css属性名1:值1;css属性名2:值2; ………… }
举例:
font{color:red; font-weight:bold; font-size:18px;}
dt{
font-size:14px;
font-weight:bold;
color:pink;
}
区分两个属性的说法html属性:写在标签中,形式为: 属性名=“属性值”——此引号可以省略,但墙裂推荐不省略
——也可以叫“标签属性”
——html属性通常是“各个标签的自有属性,一般不一样”
——使用相同html属性的标签极少
css属性: 写在选择器的大括号中,形式为: 属性名:属性值——特别注意,值不可以加引号
——也可以叫“样式属性”
——css属性通常是 “对各个标签都可用”,一般都一样
——不使用相同css属性的标签极少
选择器分类标签选择器:
形式: 标签名 { …….. }
含义: 指代(对应)网页中的所有该标签都应用其中的属性设置。
类选择器:
形式: .类名 { …… }
含义: 指代(对应)网页中的class的值为该类名的所有标签都应用该属性设置。
举例:
<style> .cc1{color:red;} </style>
<h1 class=”cc1”> 惺惺惜惺惺信息</h1>
ID选择器:
形式: #id名{ …… }
含义: 指代(对应)网页中的id的值为该名称的该标签都应用该属性设置。
注意: 通常,一个网页中的id名不要相同,因为id本身就是表示“唯一”的意思。
举例:
<style> #d1{color:red;} </style>
<h1 id=”d1”> 惺惺惜惺惺信息</h1>
通用选择器:
形式: *{ ….. } ——通用选择器只有这一个形式(符号)
含义: 其自动指代“所有标签”,即所有标签都应用该属性设置
注意: 通用选择器慎用,通常只用于设置基本的几个属性,比如文字颜色,文字大小,padding,margin
伪类选择器:
形式: :伪类名 { …… }
注意: 伪类名其实只有系统内部规定的不多的几个,不是我们自己定义的,比如:link, visited, hover, active.他们的含义也是特定的。通常上述几个伪类只用于a标签,则其形式和含义通常为:
a:link{ …… } :表示一个a链接标签在网页初始打开的时候的状态(初始链接状态)
a:visited{…..} :表示一个a链接标签在点击(访问)过之后的时候的状态(访问后状态)
a:hover{….} :表示一个a链接标签在鼠标放上去的时候的状态(悬停状态)
a:active{….} :表示一个a链接标签在鼠标摁住但还没有抬起的状态(活动状态)。
不过,最新的浏览器中,出于安全考虑,a的hover和visited效果有些属性不能用了。
复合选择器之:层级选择器
形式: 选择器1 选择器2 { ……… }
含义: 在选择器1所对应的标签中由选择器2所对应的那些标签。。。。。其中,选择器1和选择器2可以是前面所学的任意某种选择器,而且这种层级关系还可以多层次,比如:
#d1 div{…}
.cc1 p span{…..}
p .cc2 img{…..}
#d1 p a:hover{….}
举例:
<style>
div p{ color: red;}
</style>
<div>
<p>段落1</p>
</div>
<p>段落2</p>
复合选择器之:分组选择器
形式: 选择器1,选择器2 { ……… }
含义:指这两个选择器都使用同样的属性设置,其实无非是简缩代码的一种写法,否则他们得用两个选择器来写。
.a {color:red; font-size:15px;}
.b{ color:red; font-size:15px;}
è
.a, .b{ color:red; font-size:15px;}
其他复合形式(举例):
div.cc1{…} :代表具有class值为cc1的div标签,它跟 div .cc1{…}是完全不同的。
p#d1{…} :代表具有id值为d1的p标签,但这种形式其实并不推荐(意义不大)。
框架:
框架标签是用于将“当前窗口”进行瓜分成更小窗口的一种技术。framseset代替body标签,并要使用框架文档类型。
<frameset rows=”行高度划分” cols=”列宽度划分”>
<frame src=”第1个小窗口中的网页地址url” border=”0” scrolling=”no” />
<frame src=”第2个小窗口中的网页地址url” />
。。。。。。。
</frameset>
css基本概念:
css是用于这样一个目的: 将网页中的某个(些)标