共计 10311 个字符,预计需要花费 26 分钟才能阅读完成。
前言
学习网页的概念和分类,理解动态网页和动静网页的不同;理解网页浏览器的工作原理。理解 HTML,XHTML,HTML5 的概念,制作简略的 HTML 页面的开发。
什么是网页
能够在 internet 上通过网页浏览信息,如新闻,图片等,还可公布信息,如招聘信息等,网页是在某个中央某一台计算机上的一个文件。
网页次要由 3 局部组成:构造,体现,行为。
动态网页的特点是不管在何时何地浏览这个网页,看到的模式和内容都雷同,且只能浏览,用户无奈与网站进行互动。动态页面由 HTML 编写,扩展名个别为 .htm, .html, .shtml, .xml
等。与动静页面相比,动静网页是以 .asp, .jsp, .php, .perl, .cgi
等模式为后缀。
动静网页指网页的内容能够依据某种条件而主动扭转。
网页浏览器的工作原理
采纳 B / S 构造,即浏览器 / 服务器构造,用户工作界面是通过 www 浏览器来实现的:
- 事务逻辑次要在服务器端实现,极少局部的事务逻辑在前端实现。
- 大大简化了客户端的计算机载荷。
- 加重了系统维护与降级的老本和工作量。
- 升高了用户的总体老本。
浏览器的工作原理:
- 浏览器通过 HTML 表单或超链接申请指向一个应用程序的 URL。
- 服务器收到用户的申请。
- 服务器执行已接管创立的指定应用程序。
- 应用程序通常基于用户输出的内容,执行所须要的操作。
- 应用程序把后果格式化为网络服务器和浏览器可能了解的文档,即通常所说的 HTML 网页。
- 网络服务器最初将后果返回到浏览器中。
www 的根底是 HTTP 协定,web 浏览器就是用于通过 url 来获取并显示 web 网页的一种软件工具,url 用于指定要获得的 Internet 上资源的地位与形式。
HTML 和 HTML5
HTML 是一种用来制作超文本文档的简略标记语言,用其编写的超文本文档称为 HTML 文档,它能独立于各种操作系统平台。
可扩大超文本标记语言 XHTML:
XHTML 是不须要编译,能够间接由浏览器执行,是一种加强了的 HTML。它的可扩展性和灵活性将适应将来网络应用的更多需要,是基于 XML 的利用。开发者在 HTML4.0 的根底上,用 XML 的规定对其进行一些扩大,由此失去了 XHTML,所以,建设 XHTML 的目标是为了实现 HTML 向 xml 的过渡。
HTML5 简化了:<!DOCTYPE html>
,简化了 DOCTYPE, 简化了字符集申明,以浏览器的原生能力代替脚本代码的实现,简略而弱小的 HTML5API。
HTML 网页的构造
文件扩展名是操作系统用来标记文件格式的一种机制。扩展名如同文件的身份阐明,区别了文件的类别和作用。
HTML 网页的文件后缀名是 .html
或者.htm
.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"xxx">
申明的作用,通知浏览器所书写的 HTML 代码的版本。
<meta>
标签,是 HTML 文档 <head>
标签内的一个辅助性标签,meta
标签分为 2 个重要的属性:name
和http-equiv
,通常用于可能优化页面被搜寻的可能性。
meta
标签下 name
属性的应用:
<head>
<meta name="keywords" content="nine, twenty-three">
<meta name="description" content="...">
<meta name="generator" content="Dreamweaver">
<meta name="author" content="depp">
<meta name="robots" content="all">
</head>
keywords
向搜索引擎阐明页面的关键字,在 content 后输出供搜寻的具体关键字。description
向搜索引擎形容页面的次要内容。generator
向页面形容生成的软件名,在 content 前面输出具体的软件名称。author
网页的设计者,在 content 前面输出设计者的具体姓名。robots
限度搜寻的形式,在 content 前面通常可输出all,one,index,noindex,follow,nofollow
其中之一,不同的属性别离有不同的作用,限度页面被搜寻的形式。
meta
标签下的另一个属性http-equiv
, 其作用是反馈给浏览器一些明确的信息,帮忙浏览器更准确地展现页面。
<head>
<meta http-equiv="content-type" content="text/html; charset=gb2312"/>
</head>
refresh
对属性的具体形容,阐明是令页面主动跳转的成果。content
后跟期待的工夫,url 后跟跳转的页面链接地址。
link
标签,定义了一个内部文件的链接,常常被用于链接内部 css 款式。
base
标签为整个页面定义了所有链接的根底定位,其次要的作用是确保文档中所有的绝对 url 都能够被分解成确定的文档地址。
style
标签用于定义 css 的款式。表明了在页面中引入一个 .style
的样式表。
script
标签用于定义页面内的脚本。
titl
题目标签,body
体标签.
一个好的 HTML 文档应具备以下 3 个方面:
- 代码应用标准规范,不应该有谬误的拼写
- 代码构造清晰,使人高深莫测
- 没有谬误或者多余不必要的代码呈现
文本设计
<br>..</br>
<p>...</p>
<p align=left>...</p>
<p align=center>...</p>
<p align=right>...</p>
给文本加标注:<acronym title="">...</acronym>
正文的内容放在 title 属性后的引号中,被正文的内容放在标签内。
无序列表:ul,li
,有序列表:ol li
定义列表:
<dl>
<dt>...</dt>
<dd>...</dd>
<dt>...</dt>
<dd>...</dd>
</dl>
网页中的图像设计
jepg
格局的图像,该文件是常见的图像格式,.jpg
后缀名,jpeg
文件是通过压缩的一种图像。压缩的图像能够放弃为 8 位,24 位,32 位深度的图像,压缩比率能够高达 100:1.jpeg
能够很好地解决大面积色调的图像。png
格局的图像,后缀名.png
,这是一种能存储 32 位信息的位图图像,采纳的是一种无损压缩的形式。反对通明信息,指图像以浮现在其余页面文件或页面图像之上。gif
格局的图像,是一种图像交互格局,后缀名.gif
,只反对 256 色以内的图像,gif
文件的图像成果是很差的。
所以总的来说:jepg
能够压缩图像的容量,png
的品质较好,gif
能够做动画。
矢量图
说说矢量图和位图最大的区别:
无论是否对图像进行缩放,都不会影响矢量图的成果,但会影响图的品质。
设计者个别只违心将 logo,ui 图标,标识符号等简略图像存为矢量图。
图像的分辨率
分辨率的单位是 dpi
即每英寸显示的线数。通常所指的分辨率有两种,屏幕分辨率和图片分辨率,屏幕分辨率即计算机显示器默认的分辨率。
个别目前大部分显示器的分辨率是 1024px x 768px,图片分辨率定义是用于量度位图图像内数据量多少的一个参数。
分辨率越高的图像,蕴含的数据越多,图像的容量就越大,会耗费更多的计算机资源,须要更大的存储空间。
分辨率指的是每英寸的像素值,通过像素和分辨率的换算能够测算图片的长度。
页面中的图像
<img src=... alt=.../>
- 使图像的顶部和同一行的文本对齐
<img style="vertial-align:text-top"/>
- 使图像的中部和同一行的文本对齐
<img style="vertical-align:middle"/>
- 使图像的底部和同一行的文本对齐
<img style="vertical-align:text-bottom"/>
- 使图像的底部和文本的基线对齐
<img style="vertical-alignbaseline"/>
hspace=30px 示意图像左,右两边与页面其余内容隔 30px 的间隔。vspace=30px 示意图像上,下两边与页面的其余内容的距离间隔是 30px。
<img src=""widht="" height="">
<img src="..." border=>
<hr align=".." width="..." size="...">
<a href="链接对象的门路"> 链接锚点对象 </a>
把邮箱留给须要分割你的人
<a href="mailto: 邮箱地址"> 链接锚点对象 </a>
- 链接还未被拜访:
a:link{...}
- 链接被选中:
a:active{...}
- 光标滑过链接:
a:hover{...}
- 链接被拜访后:
a:visited{...}
dashed 虚线
double 双线
groove 槽线
inset 内陷
outset 外陷
热点图像区域的链接
map
标签:
<map id=...>
<area shape="..." coords="..." href="...">
</map>
shape
属性,用于确定选区的形态,rect
矩形,circle
圆形,poly
多边形。href
属性,就是超链接。coords
属性,用于管制形态的地位,通过坐标来找到这个地位。
网页中的表单
计算矩形的面积
<html>
<head>
<title> 计算矩形的面积 </title>
<style type="text/css">
.result {font-weight:bold;}
</style>
<script language="JavaScript">
function calculate() {
var length = document.data.length.value;
var width = document.data.width.value;
var height = document.data.height.value;
var area = document.getElementById('area');
area.innerHTML = length*widht;
volume.innerHTML = length*widht*height;
}
</script>
创立表单
action
属性,通过form
标签定义的表单里必须有action
属性能力将表单中的数据提交进来:
<form action="my.php"></form>
它表明了这是一个表单,其作用是提交 my.php 页面中的数据。
method
属性通知浏览器数据是以何种形式提交进来的。method
属性下能够有 2 个抉择:post
或者get
。name
属性,为了令递交进来的表单数据可能被解决这些数据的程序辨认。
<form name="data">
- 编码方式,
enctype
代表 HTML 表单数据的编码方式。
表单的工作原理
原理:在客户端接管用户的信息,而后将数据递交给后盾的程序来操控这些数据。
<script language="JavaScript">
如果通过援用内部 javascript 程序,就像链接外联款式:
<script type="text/javascript" src="dada.js"></script>
创立表单
- action 属性,有 action 属性能力将表单中的数据提交进来:
<form action="da.php"></form>
- method 属性,作用是通知浏览器数据是以何种形式提交进来的。在 method 属性下能够有 2 个抉择,post 或 get。
提交形式用 get,表单域中输出的内容会增加在 action 指定的 url 中,当表单提交之后,用户会获取一个明确的 url。get
在安全性上较差,所有表单域的值间接出现。post
除了有可见的解决脚本程序,别的货色都能够暗藏。
- name 属性,增加 name 属性是为了令递交进来的表单数据可能被解决这些数据的程序辨认。
<form name="dada">
- 编码方式:
enctype
代表 HTML 表单数据的编码方式,application/x-www-form-urlencoded, multipart/form-data, text/plain
三种形式。
application/x-www-form-urlencoded
是规范的编码方式,提交的数据被编码为名称 / 值对。multipart/form-data
属性示意数据编码为一条音讯,为表单定义mime
编码方式,创立了一个与传统不同的post
缓冲区,,页面上每个控件对应音讯中的一个局部。text/plain
示意数据以纯文本的模式进行编码,这样在信息中将不蕴含控件或者格局字符。multipart/form-data
形式上传文件时,不能应用post
属性。
- 指标显示方式,示意在何处关上指标
url
,能够设置 4 种形式。
_blank
示意在新的页面中关上链接_self
示意在雷同的窗口中关上页面_parent
示意在父级窗口中关上页面_top
示意将页面载入到蕴含该链接的窗口, 取代任何以后在窗口中的页面。
<form action="mailto:da@qq.com" method="post" name="dada"
enctype="text/plain" target="_blank"></form>
表单域
是指用户输出数据的中央,表单域可分为 3 个对象,input, textarea, select。
input 对象下的多种表单的表现形式。
<input name=""type="" value=""size="" maxlength="">
type
示意所定义的是哪种类型的表单模式size
示意文本框字段的长度maxlength
示意可输出的最长的字符数量value
示意事后设置好的信息
text
单行的文本框password
将文本替换*
的文本框checkbox
只能做二选一的是或否抉择radio
从多个选项中确定的一个文本框submit
确定命令文本框hidden
设定不可浏览用户批改的数据image
用图片示意的确定符号file
设置文件上传button
用来配合客户端脚本
<form action=""method="post">
<input name="name" type="text" size="20" maxlength="12">
</form>
<input name="secret" type="password" size="20" maxlength="20">
<input name="one" type="radio" value="one" checked="checked">
<input name="one" type="radio" value="two">
<input type="submit" value="确定">
<input type="reset" value="复原">
创立 submit 按钮或 reset 按钮时,name 属性不是必须的。
hidden 暗藏域的样式表单
应用 hidden 来记录页面的数据并将它暗藏起来,用户对这些数据通常并不关怀,然而必须提交数据。
<form action=da.asp>
<input type=hidden name=somehidden value=dada>
<input type=submit value= 下一页 >
</form>
image 款式的表单
<input type="image" src="图片 / 小图标.jpg" alt="确定">
- src 属性指定这张图像的门路
- alt 属性增加文本正文
file 上传文件的样式表单
file 样式表单容许用户上传本人的文件
<html>
<head>
<title>file 款式的表单 </title>
<style type="text/css">
body {font:120% 微软雅黑;}
input {font:100% 微软雅黑;}
</style>
</head>
上传我的文件:<form action="..." method="post" enctype="multipart/form-data">
<input type="file" name="uploadfile" id="uploadfile"/>
</form>
</body>
</html>
textarea 对象的表单
textarea 对象的表单
<html>
<head>
<title>file 款式的表单 </title>
<style type="text/css">
body{font:120% 微软雅黑;}
textarea{font:80% 微软雅黑;color:navy;}
</style>
</head>
<body>
留言板
<form action="..." method="post" enctype="multipart/form-data">
<textarea name="dada" rows="10" cols="50" value="dada"> 请说:</textarea>
</form>
</body>
</html>
select 对象的表单
select 对象的表单
<form action="">
地址:
<select name="da1">
<option>1</option>
</select>
</form>
应用 optgroup
标签配合 label
属性来给选项分类:
<select name="上海">
<optgroup label="da1">
<option>1</option>
</optgroup>
<optgroup label="da2">
<option>2</option>
</optgroup>
</select>
在 select
标签中退出 size
属性即可,如 size=6
示意是一个能包容 6 行文字的文本框,超出设置的行数时,将呈现滚动条。
<select name="上海" size="6">
表单域汇合:表单域的代码由 fieldset
标签和 legend
标签组合而成。
<form action="..." method="post">
<fieldset>
<legend> 注册信息:</legend>
输出用户名:<input name="name" type="text" size="20" maxlength="12">
</fieldset>
</form>
表单输出类型
- url 类型的 input 元素是专门为输出 url 地址定义的文本框。
<input type="url" name="webUrl" id="webUrl" value="http://wwwxxx"/>
- email 类型的 input 元素是专门为输出 email 地址定义的文本框。
<input type="email" name="dada" id="dada" value="23@qq.com"/>
- range 类型的 input 元素用于把输入框显示为滑动条,能够作为某一特定范畴内的数值选择器。
<input type="range" name="volume" id="volume" min="0" max="1" step="0.2"/>
- number 类型的 Input 元素是专门为输出特定的数字而定义的文本框。
<input type="number" name="score" id="score" min="0" max="10" step="0.5"/>
- tel 类型的 input 元素是专门为输出电话号码而定义的文本框,没有非凡的验证规定。
- search 类型的 input 元素是专门为输出搜索引擎关键词定义的文本框,没有非凡的验证规定。
- color 类型的 input 元素默认会提供一个色彩选择器。
- date 类型的 Input 元素是专门用于输出日期的文本框,默认为带日期选择器的输入框。
- month 提供一个月的选择器,week 提供一个周选择器,time 会提供工夫选择器,datetime 会提供残缺的日期和工夫选择器,datetime-local 会提供残缺的日期和工夫选择器。
减少表单的个性以及元素
- form 个性:
<input name="name" type="text" form="form1" required/>
<form id="form1">
<input type="submit" value="提交"/>
</form>
- formaction 个性,将表单提交至不同的页面。
<form id="form1" method="post">
<input name="name" type="text" form="form1"/>
<input type="submit" value="提交到 page1" formaction="?page=1”/>
<input type="submit" value="提交到 page2" formaction="?page=2"/>
<input type="submit" value="提交"/>
</form>
- formmethod 个性可笼罩表单的 method 个性
- formenctype 个性可笼罩表单的 enctype 个性
- formnovalidate 个性可笼罩表单的 novalidate 个性
- formtarget 个性可笼罩表单的 target 个性
placeholder 个性
<input name="name" type="text" placeholder="请输出关键词"/>
autofocus 个性:用于当页面加载实现时,可主动获取焦点,每个页面只容许呈现一个有 autofocus 个性的 input 元素。
<input name="key" type="text" autofocus/>
autocomplete 个性用于 form 元素和输出型的 Input 元素,用于表单的主动实现。
input name="key" type="text" autocommplete="on"/>
autocomplete 个性有三个值,能够指定 ”on”,”off” 和 ”” 不指定,不指定就将应用浏览器的默认设置。
<input name="email" type="email" list="emaillist"/>
<datalist id="emaillist">
<option value="23#qq.com">xxxx</option>
</datalist>
keygen 元素提供一个平安的形式来验证用户。
<form action="">
<input type="text" name="name"/><br>
<keygen name="security"/>
<br><input type="submit"/>
</form>
- keygen 元素有密钥生成的性能,在提交表单时,会别离生成一个私人密钥和一个公共密钥。
- 私人密钥保留在客户端,公共密钥则通过网络传输至服务器。
output 元素
output
元素用于不同类型的输入,比方计算结果或脚本的输入等。output
元素必须从属于某个表单,即写在表单的外部。
<form oninput="x.value=dada.value">
<input type="range" name="volume" value="50"/>
<output name="x"></output>
</form>
required
为某个表单外部的元素设置了 required 个性,那么这项的值不能为空,否则无奈提交表单。
<input name="name" type="text" placeholder="dada" required/>
pattern
- pattern 用于为 Input 元素定义一个验证模式。
- 该个性值是一个正则表达式,提交时会查看输出的内容是否合乎给定的格局,如果不合乎则不能提交。
<input name="code" type="text" value=""pattern="[0-9]{6}"placeholder="da"/>
min,max,step
- min 示意容许范畴内的最小值
- max 示意容许范畴内的最大值
- step 示意非法数据的距离步长
<input type="range" name="dada" id="dada" min="0" max="1" step="0.2"/>
novalidate
- 用于指定表单或表单外在提交时不验证
- 如果在 form 元素利用 novalidate 个性,则表单中的所有元素在提交时都不须要再验证
<form action="dada.asp" novalidate="novalidate">
<input type="email" name="user_email"/>
<input type="submit"/>
</form>
validity
- 获取表单元素的 ValidityState 对象,该对象蕴含 8 个方面的验证后果
- ValidityState 对象会继续存在,每次获取 validity 属性时,返回的是同一个 ValidityState 对象
var validityState=document.getElementById("username").validity;
willValidate 属性
- 用于获取一个布尔值,示意表单元素是否须要验证
- 如表单元素设置了 required 个性或 pattern 个性,则 willValidate 属性的值为 true,即表单的验证将执行
var willValidate = document.getElementById("username").willValidate;
validationMessage
- 获取以后表单元素的谬误提示信息。
var validationMessage=document.getElementById("username").validationMessage;
点关注,不迷路
好了各位,以上就是这篇文章的全部内容,能看到这里的人都是人才。我前面会不断更新技术相干的文章,如果感觉文章对你有用,欢送给个“赞”,也欢送分享,感激大家!!