整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

前端学习笔记 HTML +CSS

TML

  1. 基本概念

  • HTML 是网页内容的载体。内容就是网页制作者放在页面上想要让用户浏览的信息,可以包含文字、图片、视频等。

  • CSS 样式是表现。比如,标题字体、颜色变化,或为标题加入背景图片、边框等,所有这些用来改变内容外观的东西称之为表现。

  • JavaScript 是用来实现网页上的特效效果。如:鼠标滑过弹出下拉菜单,或鼠标滑过表格的背景颜色改变,还有焦点新闻(新闻图片)的轮换。有动画的,有交互的一般都是用 JavaScript 来实现的。

2.常用标签

  • 强调语气:<em>是斜体,<strong>是加粗

  • 引用:<q>短文本引用,<blockquote>长文本引用

  • 换行 <br />

  • 水平横线 <hr />

  • 空格 &nbsp;

  • 表格 <table><tbody>

  • 加上后表格内容全部下载完才会显示

  • <tr>

  • <td>

  • 表格表头 <th>

  • 标题 <caption>

  • 超链 <a>

  • 例子:<a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>

  • 新标签打开:target="_blank"

  • 图片 <img>,图像可以是 GIF,PNG,JPEG 格式的图像文件

  • 例子:<img src="图片地址" alt="下载失败时的替换文本" title = "提示文本">

  • 表单 <form>

  • 文本域 <textarea>

  • 例子 <textarea rows="行数" cols="列数">文本</textarea>

  • cols 多行输入域的列数;rows 多行输入域的行数。这两个属性可用 CSS 样式的 width 和 height 来代替:col 用 width、row 用 height 来代替

  • 输入框 <input type="text/password" name="名称" value="文本" />

  • 当 type=”text” 时,输入框为文本输入框

  • 当 type=”password” 时, 输入框为密码输入框

  • 单/复选框 <input type="radio/checkbox" value="值" name="名称" checked="checked"/>

  • 当 type=”radio” 时,控件为单选框,同一组单选框 name 命名要一致

  • 当 type=”checkbox” 时,控件为复选框

  • 提交按钮 <input type="submit" value="提交">

  • 重置按钮 <input type="reset" value="重置">

  • 下拉列表框 ` `

  • value <option value="提交值">选项</option>

  • 选中 selected="selected"

  • 多选 multiple="multiple"

  • 标签 <label for="控件id名称">,标签的 for 属性中的值应当与相关控件的 id 属性 值一定要相同

CSS

基本知识

CSS 样式由选择符和声明组成,而声明又由属性和值组成。

  • 选择符:又称选择器,指明网页中要应用样式规则的元素。

  • 声明:在英文大括号{}中的的就是声明,属性和值之间用英文冒号{}分隔。当有多条声明时,中间可以英文分号;分隔。

从CSS 样式代码插入的形式来看基本可以分为以下3种:内联式、嵌入式和外部式三种。优先级遵循就近原则,一般来说,内联式 > 嵌入式 > 外部式

  • 内联式

例子 <p style="color:red;font-size:12px">这里文字是红色。</p>

  • 嵌入式

  • 外部式

例子:<link href="base.css" rel="stylesheet" type="text/css" />

CSS 选择器

常见的类选择器类型有如下几种:

  • 标签选择器,.标签选择器名称{css样式代码;}

  • 类选择器,.类选器名称{css样式代码;}

  • ID 选择器,#类选器名称{css样式代码;}

  • 子选择器,即大于符号(>),用于选择指定标签元素的第一代子元素

  • 包含选择器,即加入空格 ,用于选择指定标签元素下的后辈元素

  • 通用选择器,匹配html中所有标签元素,* {css样式代码;}类选择器和ID选择器都可以应用于任何元素,但 ID 选择器只能在文档中使用一次,可以使用类选择器词列表方法为一个元素同时设置多个样式,ID 选择器是不可以的。

子选择器和包含选择器区别:>作用于元素的第一代后代,空格作用于元素的所有后代。

另外还有两种选择符:

  • 伪类选择符,允许给 HTML 不存在的标签(标签的某种状态)设置样式。常用的有 a:hover{color:red;}

  • 分组选择符,为 HTML 中多个标签元素设置同一个样式时,可以使用分组选择符,

。例如h1,span{color:red;}

CSS 的继承、层叠和特殊性

  • CSS 的某些样式是具有继承性的,继承是一种规则,它允许样式不仅应用于某个特定 HTML 标签元素,而且应用于其后代。

  • 特殊性:不同选择器具有不同权值,标签的权值为 1,类选择符的权值为 10,ID选择符的权值最高为 100。

  • 层叠 就是在 HTML 文件中对于同一个元素可以有多个 CSS 样式存在,当有相同权重的样式存在时,会根据这些 CSS 样式的前后顺序来决定,处于最后面的 CSS 样式会被应用。

CSS 格式化排版

文字排版

  • 字体,body{font-family:"Microsoft Yahei";}

  • 字号、颜色,body{font-size:12px;color:#666}

  • 粗体,body{font-weight:bold;}

  • 斜体,body{font-style:italic;}

  • 下划线,body{font-style:italic;}

  • 删除线,body{text-decoration:line-through;}

段落排版

  • 缩进,p{text-indent:2em;}

  • 行间距(行高),p{line-height:1.5em;}

  • 中文字间距、字母间距,letter-spacing:50px;word-spacing:50px;

  • 对齐,div{text-align:center;}

CSS 盒模型

元素分类

在 CSS 中,HTML 中的标签元素大体被分为三种不同的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。

  • 常用的块状元素有:

块级元素特点:

  1. 每个块级元素都从新的一行开始,并且其后的元素也另起一行。

  2. 元素的高度、宽度、行高以及顶和底边距都可设置。

  3. 元素宽度在不设置的情况下,是它本身父容器的 100%(和父元素的宽度一致),除非设定一个宽度。

设置 display:block就是将元素显示为块级元素,从而使元素具有块状元素特点。

注:img 标签与 div 层之间会有空隙的解决方法是:使用 display:block 就可以消除间隙。

  • 常用的内联元素有:

内联元素特点:

  1. 和其他元素都在一行上;

  2. 元素的高度、宽度及顶部和底部边距不可设置;

  3. 元素的宽度就是它包含的文字或图片的宽度,不可改变。

块状元素也可以通过代码 display:inline将元素设置为内联元素。

  • 常用的内联块状元素有:

inline-block 元素特点:

  1. 和其他元素都在一行上;

  2. 元素的高度、宽度、行高以及顶和底边距都可设置。

内联块状元素(inline-block)就是同时具备内联元素、块状元素的特点,代码 display:inline-block就是将元素设置为内联块状元素。

盒模型

  • 边框

盒子模型的边框就是围绕着内容补白的线,这条线你可以设置它的粗细样式颜色(边框三个属性)。

单独设置下边框的例子 div{border-bottom:1px solid red;}

  • 宽度和高度

CSS 内定义的宽(width)和高(height),指的是 填充以里的内容范围。一个元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界。

W3C 的标准 Box Model:

所以有时会设置 box-sizing: border-box;来避免计算内部元素大小

  • 填充(padding)

元素内容与边框之间是可以设置距离的,称之为“填充”。填充也可分为上、右、下、左(顺时针)。

例子:

  • 边界(margin)

元素与其它元素之间的距离可以使用边界(margin)来设置,顺序和填充一样是上,右,下,左。padding 在边框里,margin 在边框外。

CSS 布局模型

CSS 包含 3 种基本的布局模型,用英文概括为:Flow、Layer 和 Float。 在网页中,元素有三种布局模型:

  1. 流动模型(Flow)

  2. 浮动模型 (Float)

  3. 层模型(Layer)

流动模型

流动模型,流动(Flow)是默认的网页布局模式。

流动布局模型具有2个比较典型的特征:

  1. 块状元素 都会在所处的包含元素内自上而下按顺序垂直延伸分布,因为在默认状态下,块状元素的宽度都为 100%。实际上,块状元素都会以行的形式占据位置。

  2. 在流动模型下,内联元素 都会在所处的包含元素内从左到右水平分布显示。

浮动模型

任何元素在默认情况下是不能浮动的,但可以用 CSS 定义为浮动。例子:#div1{float:left;}

层模型

CSS 定义了一组定位(positioning)属性来支持层布局模型。

层模型有三种形式:

  1. 绝对定位(position: absolute)

  2. 相对定位(position: relative)

  3. 固定定位(position: fixed)

  • 绝对定位(position: absolute)

如果想为元素设置层模型中的绝对定位,需要设置 position:absolute(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用 left、right、top、bottom 属性相对于其最接近的一个具有定位属性的父包含块进行绝对定位。如果不存在这样的包含块,则相对于 body 元素,即相对于浏览器窗口

  • 相对定位(position: relative)

如果想为元素设置层模型中的相对定位,需要设置 position:relative(表示相对定位),它通过 left、right、top、bottom 属性确定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按 static(float) 方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动

简单来说,就是相对元素原来的位置进行移动,元素本身所占的位置会保留。

  • 固定定位(position: fixed)

设置 position:fixed;。fixed:表示固定定位,与 absolute 定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与 background-attachment:fixed; 属性功能相同。

Relative 与 Absolute 组合使用,必须遵守下面规范:

  1. 参照定位的元素必须是相对定位元素的前辈元素

  2. 参照定位的元素必须加入 position:relative;

  3. 定位元素加入 position:absolute,便可以使用 top、bottom、left、right 来进行偏移定位了

例子(HTML 和 CSS 代码分别为):

颜色和长度

设置颜色的方法也有很多种:

  • 英文命令颜色,p{color:red;}

  • RGB颜色,p{color:rgb(133,45,200);}p{color:rgb(20%,33%,25%);}

  • 十六进制颜色, 这种颜色设置方法是现在比较普遍使用的方法,其原理其实也是 RGB 设置,但是其每一项的值由 0-255 变成了十六进制 00-ff。p{color:#00ffff;}(当你设置的颜色是 16 进制的色彩值时,如果每两位的值相同,可以缩写一半,#0ff)RGB 配色表参考 RGB颜色对照表 - 在线工具 - 开源中国 或者 RGB 配色表长度单位总结一下,目前比较常用到px(像素)、em、% 百分比,要注意其实这三种单位都是相对单位。

  • 像素

  • em,就是本元素给定字体的 font-size 值

  • % 百分比

设置小技巧

水平居中设置

  • 行内元素。如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 text-align:center来实现的。

  • 定宽块状元素(块状元素的宽度 width 为固定值)。满足定宽块状两个条件的元素是可以通过设置“左右 margin”值为 auto 来实现居中的。

  • 不定宽块状元素。

  • 加入 table 标签(包括 <tbody>、<tr>、<td>),为这个 table 设置“左右 margin 居中”

  • 设置 display: inline方法:与第一种类似,显示类型设为 行内元素,然后使用 text-align:center来实现居中效果,进行不定宽元素的属性设置。

  • 给父元素设置 float 和 position:relative; left:50%,子元素设置 position:relativeleft: -50% 来实现水平居中。

垂直居中设置

  • 父元素高度确定的单行文本。通过设置父元素的 height 和 line-height 高度一致来实现的。(height: 该元素的高度;line-height: 顾名思义,行高(行间距),指在文本中,行与行之间的 基线间的距离 )。

  • 父元素高度确定的多行文本。使用插入 table (包括 tbody、tr、td)标签,同时设置 vertical-align:middle

另外,为元素设置以下两个属性之一会隐形改变 display 类型,元素的display显示类型就会自动变为以display:inline-block(块状元素)的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。

position: absolute

float: leftfloat:right

什么学习网页制作?

互联网时代的今天,各种各样的网页充斥着我们的生活。只要使用浏览器,打开的每一个页面都可以称之为网页。即使使用头条这样的APP,其内容布局、展示的方法也脱胎于网页页面设计的方法与原则。可以说页面的概念已经遍布我们的信息化世界。

作为芸芸众生中的一员,学习网页制作对我们的事业、生活有怎样的帮助呢?

第一,学习网页制作有助于理解网络信息的传播运行机制,即使通过本课程不能全面了解这些核心机制,也能为大家铺垫下继续深入学习的知识基础。即使自己不必亲自制作网页,在使用第三方工具时,比如微信公众号、微信小程序或者其他自动网页或网站生成工具时也会比没有基础的人更快的掌握这些工具。

第二,学好网页制作是制作网站的基础,如果您因为事业需要或者个人爱好打算制作自己的网站或博客,无论是打算使用php还是Java还是Python去构建您的网站,精通网页制作技术是您的第一块技术基石。

第三,如果您打算学习网络爬虫来分析一些网络数据,了解网页页面构成也是必要基础,至少您要知道一个网页页面中每个标签中对应的是哪些信息,才能有的放矢拿到自己想要的信息。

第四,如果您想学习编程,但是缺少相应的基础知识,看不懂复杂的C语言教学,那么从网页制作入手尝试理解编程的语法也是一个很不错的选择。

除此之外,浏览器可以做的事情越来越多,比如webgl的出现,可以让我们通过浏览器构建3d世界,无论是虚拟现实(VR)还是增强现实(AR)都有很多开源免费的解决方案。TensorFlow的JavaScript版本的出现,让我们可以通过结合浏览器学习使用人工智能技术,且非常容易实现。

所以,新的一年里,我打算做网页制作的学习教程,让更多没有基础却对网络技术感兴趣的小伙伴能加入进来。

制作网页需要学习哪些技术?

简单来说学习网页制作需要掌握三门技术。

第一,也是最基础最核心的内容是HTML超文本标记语言。大家不必纠结HTML到底是什么,但是一定要记住它能干什么。HTML通俗来说可以比喻成容器。大家试想,网页里都有哪些内容呢?

一般网页中都会有文字、图片、声音、视频、表格等内容,这些内容就是靠HTML中的标签添加进页面的。

所以说HTML这个工具就是个容器,我们使用HTML标签语言为网页添加所有需要的信息内容。

第二,CSS层叠样式表,这是一个用来装饰页面的工具。如果说HTML是个信息容器,那么如何让这些信息条理清晰的显示出来呢?那就需要CSS来帮忙了。如下图所示,这是一个最简单的页面,只用到了HTML,里面装了一个标题和一个只有六个字的段落。

为了让这个页面看起来美观些,我们为其添加css样式表。添加后如图所示:

我们可以看出来,CSS让标题文字换了颜色,也居中显示了,背景也变成了蓝色。

第三,JavaScript,这个工具相比HTML和CSS来讲是最难学习的,学习JavaScript就是在学习编程了。它虽然只是个脚本语言,但是用到的知识和其他编程语言相差不大。

那JavaScript能干什么呢?

首先,它能为页面中添加很多交互效果。举个例子,我们常见的图片翻页、轮播很多就是基于JavaScript脚本实现的。

其次,JavaScript可以为传统页面扩展出很多新功能,例如结合three.js我们可以很容易的在页面中构建三维空间,或者实现一些3d游戏或其他三维动态演示效果。举个例子(https://renaultespace.littleworkshop.fr/),打开可能略慢。3d展示的汽车广告是不是很酷!

再次,JavaScript可以以网页为基础,实现各种各样的在线小游戏,例如Phaser.js就是目前非常火的一个开源免费网页游戏制作库。phaser官网:http://phaser.io/

JavaScript为网页的功能拓展提供了很多可能性,无论是3d显示还是游戏制作还是未来的人工智能工具,都是由JavaScript都为大家提供了将功能引入到页面的接口,这也是学习难度比较大的原因。不过只要坚持下去一定能学通的!

网站与网页的区别?

网页是指我们看到的单个页面。这些页面分为静态页面和动态页面两种。静态页面指的是不能与服务器进行数据交互的页面,顾名思义动态页面指的是可以与服务器进行数据交互的页面,这一点大家不必纠结。

简单来说,静态页面写好后什么样就是什么样,谁打开都是事先编辑好的内容,而动态页面写好后会随着不同的访问变换不同数据,动态页面更像是一个页面模板,随时套用不同信息

大部分网站中的页面都是动态页面。

如果使用静态页面做网站会出现什么问题呢?如果您有300篇博客文章,那您就要做300个静态页面来显示,大型资讯网站信息量更加庞大,如果都用静态页面来做,占用的服务器空间也是庞大到不可想象。

网站中的动态页面就解决了这个问题,例如一个简单的网站我们只需一个主页、文章页、搜索页基本上就可以了,这些页面中没有具体内容,我们称之为模板。当您打开后,显示的内容都是在数据库中调出的。这样,一个数据库用来存储压缩过的精简信息,这些信息通过不同页面模板显示在用户面前就成为网站的基本运行模式。

例如在静态页面中显示文字字数的代码是这样

<p>300字</p>

如果使用以php编写的WordPress网站框架来动态显示文章字数就是这样

<p><?php echo zm_count_words($text); ?></p>

<?php echo zm_count_words($text); ?>这条语句可以调取数据库中文章字数的记录并显示出来。这也我们通过这一条语句就可以显示不同文章的字数了。

无论是静态页面还是动态页面,他们的核心内容都是一样的,HTML,CSS,JavaScript都是必修知识。只是静态页面在HTML中插入信息,而动态页面插入的是调取数据库信息的语句。

因此,我们这个教程看起来是在做静态页面,但是我们学习的也是制作网站的基础知识。

本教学学完能干什么?

第一,可以写出静态页面。

第二,有能力读懂他人写好的页面代码。

第三,为继续深入学习网站制作或更为炫酷的页面制作打下基础。

第四,掌握编程基础,至少是基于JavaScript的。

我是大鱼,致力于数字艺术技术分享!欢迎大家关注!祝愿大家2020年学有所成!

HTML学习目录

HTML是什么?——零基础自学网页制作

第一个HTML页面如何写?——零基础自学网页制作

HTML页面中head标签有啥用?——零基础自学网页制作

初识meta标签与SEO——零基础自学网页制作

HTML中的元素使用方法1——零基础自学网页制作

HTML中的元素使用方法2——零基础自学网页制作

HTML元素中的属性1——零基础自学网页制作

HTML元素中的属性2(路径详解)——零基础自学网页制作

使用HTML添加表格1(基本元素)——零基础自学网页制作

使用HTML添加表格2(表格头部与脚部)——零基础自学网页制作

使用HTML添加表格3(间距与颜色)——零基础自学网页制作

使用HTML添加表格4(行颜色与表格嵌套)——零基础自学网页制作

16进制颜色表示与RGB色彩模型——零基础自学网页制作

HTML中的块级元素与内联元素——零基础自学网页制作

初识HTML中的<div>块元素——零基础自学网页制作

在HTML页面中嵌入其他页面的方法——零基础自学网页制作

封闭在家学网页制作!为页面嵌入PDF文件——零基础自学网页制作

HTML表单元素初识1——零基础自学网页制作

HTML表单元素初识2——零基础自学网页制作

HTML表单3(下拉列表、多行文字输入)——零基础自学网页制作

HTML表单4(form的action、method属性)——零基础自学网页制作

HTML列表制作讲解——零基础自学网页制作

为HTML页面添加视频、音频的方法——零基础自学网页制作

音视频格式转换神器与html视频元素加字幕——零基础自学网页制作

HTML中使用<a>标签实现文本内链接——零基础自学网页制作

见标签


1.段落标签<p>

  • <p>标签的默认样式,段前段后都会有空白,如果不喜欢这个空白,可以用css样式来删除或改变它。
  • 改变CSS样式删除段前段后空白处。
<style> 
 p{margin:0px;} 
</style>

2.斜体标签<em>

 <em>斜体</em>

3.粗体标签<strong>

 <strong>加粗</strong>

4.<span>标签

被用来组合文档中的行内元素。使用 <span> 来组合行内元素,以便通过样式来格式化它们。

  • <span> 在CSS定义中属于一个行内元素,在行内定义一个区域,也就是一行内可以被 <span>划分成好几个区域,从而实现某种特定效果。
  • <span>本身没有任何属性。
  • <div>在CSS定义中属于一个块级元素<div>可以包含段落、标题、表格甚至其它部分。这使DIV便于建立不同集成的类,如章节、摘要或备注。在页面效果上,使用<div> 会自动换行,使用<span> 就会保持同行。

例如:

 <style> 
 span{ color:blue; } 
 </style>

这样,<span>标签包含的文本就变成了蓝色的字体。

5.<q>标签

作用:段文本引用

例如:

<p>最初知道庄子,是从一首诗<q>庄生晓梦迷蝴蝶。望帝春心托杜鹃。</q>开始的。虽然当时不知道是什么意思,只是觉得诗句挺特别。后来才明白这个典故出自是庄子的《逍遥游》,《逍遥游》代表了庄子思想的最高境界,是对世俗社会的功名利禄及自己的舍弃。</p>
在上面的例子中,“庄生晓梦迷蝴蝶。望帝春心托杜鹃。” 这是一句诗歌,出自晚唐诗人李商隐的《锦瑟》 。因为不是作者自己的文字,所以需要使用<q></q>实现引用。
注意要引用的文本不用加双引号,浏览器会对q标签自动添加双引号。
这里用<q>标签的真正关键点不是它的默认样式双引号(如果这样我们不如自己在键盘上输入双引号就行了),而是它的语义:引用别人的话。
补充知识:语义化网页结构有助于搜索引擎的收录。同一个效果可以用很多钟方式实现,但这只方便了浏览者,而搜索引擎不知道这里到底是什么内容,这里如果你使用标签,那么就告诉浏览器这里是引用的话。而且在手持设备或移动设备不能很好支持css的基础上,浏览器会使用默认的效果,因而提供较好可读性。

6.<blockquote>标签

作用:长文本引用

例如:

<blockquote>明月出天山,苍茫云海间。长风几万里,吹度玉门关。汉下白登道,胡窥青海湾。由来征战地,不见有人还。 戍客望边色,思归多苦颜。高楼当此夜,叹息未应闲。</blockquote>

注意:浏览器对<blockquote>标签的解析是缩进样式

7.<br>标签

怎么可以让每一句诗词后面加入一个折行呢?那就可以用到<br />标签了,在需要加回车换行的地方加入<br />,<br />标签作用相当于word文档中的回车。

语法:

xhtml1.0写法:

 <br/>

html4.01写法:

 <br>

现在一般使用 xhtml1.0 的版本的写法(其它标签也是),这种版本比较规范。

与以前我们学过的标签不一样,<br />标签是一个空标签,没有HTML内容的标签就是空标签,空标签只需要写一个开始标签,这样的标签有<br />、<hr />和<img />。

讲到这里,你是不是有个疑问,想折行还不好说嘛,就像在 word 文件档或记事本中,在想要折行的前面输入回车不就行了吗? 不好意思,在 html 中是忽略回车和空格的,你输入的再多回车和空格也是显示不出来的。

8.<hr>标签

在信息展示时,有时会需要加一些用于分隔的横线,这样会使文章看起来整齐些。

语法:

html4.01版本

<hr>

xhtml1.0版本

<hr/>

注意:

  • <hr />标签和<br />标签一样也是一个空标签,所以只有一个开始标签,没有结束标签。
  • <hr />标签的在浏览器中的默认样式线条比较粗,颜色为灰色,可能有些人觉得这种样式不美观,没有关系,这些外在样式在我们以后学习了css样式表之后,都可以对其修改。
  • 大家注意,现在一般使用 xhtml1.0 的版本(其它标签也是),这种版本比较规范

9.<address>标签

一般网页中会有一些网站的联系地址信息需要在网页中展示出来,这些联系地址信息如公司的地址就可以<address>标签。也可以定义一个地址(比如电子邮件地址)、签名或者文档的作者身份。

语法:

 <address>联系地址信息</address>

如:

<address>文档编写:lilian 北京市西城区德外大街10号</address>

10.<code>标签

在介绍语言技术的网站中,避免不了在网页中显示一些计算机专业的编程代码,当代码为一行代码时,你就可以使用<code>标签了,如下面例子:

<code>var i=i+300;</code>

注意:在文章中一般如果要插入多行代码时不能使用<code>标签了。

语法:

<code>代码语言</code>

:如果是多行代码,可以使用<pre>标签。

11.<pre>标签

主要作用:预格式化的文本。被包围在 pre 元素中的文本通常会保留空格和换行符。

语法:

<pre>语言代码段</pre>

如下代码:

<pre> 
 var message="欢迎"; 
 for(var i=1;i<=10;i++) { 
 alert(message); 
 } 
</pre>

效果如下:

注意:<pre> 标签不只是为显示计算机的源代码时用的,在你需要在网页中预显示格式时都可以使用它,只是<pre>标签的一个常见应用就是用来展示计算机的源代码。

12.<ul>标签

ul-li是没有前后顺序的信息列表。

  • 这样是空心圆,
ul{ list-style:circle; }
  • 这个就是去除前面的点
ul{ list-style:none }
  • 语法:
<ul> 
 <li>信息</li> 
 <li>信息</li> 
 ...... 
</ul>
  • 举例:
<ul> 
 <li>精彩少年</li> 
 <li>美丽突然出现</li> 
 <li>触动心灵的旋律</li> 
</ul>
  • ul-li在网页中显示的默认样式一般为:每项li前都自带一个圆点

13.<ol>标签

ol-li是有前后顺序的信息列表

  • 语法:
<ol> 
 <li>信息</li> 
 <li>信息</li> 
 ...... 
</ol>
  • 举例:
 <ol> 
 <li>前端开发面试心法 </li> 
 <li>零基础学习html</li>
 <li>JavaScript全攻略</li> 
</ol>

<ol>在网页中显示的默认样式一般为:每项<li>前都自带一个序号,序号默认从1开始。

14.<div>标签

  • <div> 可定义文档中的分区或节(division/section)。
  • <div>标签可以把文档分割为独立的、不同的部分。它可以用作严格的组织工具,并且不使用任何格式与其关联。
  • 如果用 id 或 class 来标记 <div>,那么该标签的作用会变得更加有效。
  • <div>是一个块级元素。这意味着它的内容自动地开始一个新行。实际上,换行是 <div>固有的唯一格式表现。可以通过<div> 的 class 或 id 应用额外的样式。不必为每一个 <div> 都加上类或 id,虽然这样做也有一定的好处。
  • 可以对同一个 <div>元素应用 class 或 id 属性,但是更常见的情况是只应用其中一种。这两者的主要差异是,class 用于元素组(类似的元素,或者可以理解为某一类元素),而id 用于标识单独的唯一的元素。

15.<table>标签

  • 常用属性

1)属性:border

作用:规定表格边框的宽度

2)属性:cellpadding

作用:单元格中的文本与单元格边框的间距

3)属性:cellspacing

作用:单元格之间的间距

  • 创建表格的四个元素:

table、tbody、tr、th、td

1、<table>…</table>:整个表格以<table>标记开始、</table>标记结束。

2、<tbody>…</tbody>:当表格内容非常多时,表格会下载一点显示一点,但如果加上<tbody>标签后,这个表格就要等表格内容全部下载完才会显示。如右侧代码编辑器中的代码。

3、<tr>…</tr>:表格的一行,所以有几对tr 表格就有几行。

4、<td>…</td>:表格的一个单元格,一行中包含几对<td>...</td>,说明一行中就有几列。

- 常用属性: colspan:规定单元格可横跨的列数,值为数字 rowspan:规定单元格可横跨的行数,值为数字

5、<th>…</th>:表格的头部的一个单元格,表格表头。

6、表格中列的个数,取决于一行中数据单元格的个数。

总结:

  • 1、表头,也就是th标签中的文本默认为粗体并且居中显示
  • 2、table表格在没有添加css样式之前,在浏览器中显示是没有表格线的
  • 3、用css样式,为表格加入边框Table 表格在没有添加 css 样式之前,是没有边框的。

16.<caption>标签

表格还是需要添加一些标签进行优化,可以添加标题和摘要。

  • 摘要

摘要的内容是不会在浏览器中显示出来的。它的作用是增加表格的可读性(语义化),使搜索引擎更好的读懂表格内容,还可以使屏幕阅读器更好的帮助特殊用户读取表格内容。语法:

<table summary="表格简介文本">
  • 标题

用以描述表格内容,标题的显示位置:表格上方。语法:

<table> 
 <caption>标题文本</caption> 
 <tr> 
 <td>…</td> 
 <td>…</td> 
 … 
 </tr> 
 … 
</table>

17.<a>标签

  • _blank --在新窗口中打开链接
  • _parent --在父窗体中打开链接
  • _self --在当前窗体打开链接,此为默认值
  • _top --在当前窗体打开链接,并替换当前的整个窗体(框架页)
  • 一个对应的框架页的名称 -在对应框架页中打开
  • href:Hypertext Reference的缩写。意思是超文本引用。
  • 使用<a>标签可实现超链接,它在网页制作中可以说是无处不在,只要有链接的地方,就会有这个标签。语法:
 <a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>

例如:

 <a href="http://www.imooc.com" title="点击进入慕课网">click here!</a>

上面例子作用是单击click here!文字,网页链接跳转到http://www.imooc.com这个网页。

  • <a>标签在默认情况下,链接的网页是在当前浏览器窗口中打开,有时我们需要在新的浏览器窗口中打开。如下代码:
 <a href="目标网址" target="_blank">click here!</a>
  • title属性的作用,鼠标滑过链接文字时会显示这个属性的文本内容。这个属性在实际网页开发中作用很大,主要方便搜索引擎了解链接地址的内容(语义化更友好)。
  • 注意:还有一个有趣的现象不知道小伙伴们发现了没有,只要为文本加入a标签后,文字的颜色就会自动变为蓝色(被点击过的文本颜色为紫色),颜色很难看吧,不过没有关系后面我们学习了css样子就可以设置过来(a{color:#000}),下面会详细讲解。
  • 使用mailto在网页中链接Email地址

<a>标签还有一个作用是可以链接Email地址,使用mailto能让访问者便捷向网站管理者发送电子邮件。

注意:如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。引号只有一对!

例子:
<a href="mailto:yy@qq.com? cc=xx@qq.com & bcc=aa@qq.com & subject=邮件主题 & body=邮件内容">
  • 如果:A 发送邮件给B1、B2、B3,抄送给C1、C2、C3,密送给D1、D2、D3。
那么:
1)A知道自己发送邮件给了B1、B2、B3,并且抄送给了C1、C2、C3,密送给了D1、D2、D3。
2)B1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,但不知道密送给了D1、D2、D3。
3)C1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,但不知道密送给了D1、D2、D3。
4)D1知道这封是A发送给B1、B2、B3的邮件,并且抄送给了C1、C2、C3,而且密送给了自己,但不知道密送给了D2、D3。
5)邮箱地址
 mailto: <a href="mailto:qiujie@staff.weibo.com">发送</a>
6)抄送地址
cc: <a href="mailto:qiujie@staff.weibo.com?cc=zz@sina.com">发送</a>
7)密件抄送地址
用分号分隔: <a href="mailto:qiujie@staff.weibo.com?bcc=zz@sina.com">发送</a>
8)多个收件人、抄送人、密送人 ;
bcc: <a href="mailto:qiujie@staff.weibo.com;zz@sina.com">发送</a>
9)邮件主题
subject: <a href="mailto:qiujie@staff.weibo.com?subject=邮件主题">发送</a>
10)邮件内容
body: <a href="mailto:qiujie@staff.weibo.com?body=邮件正文">发送</a>
例子:
<a href="mailto:yy@imooc.com;10001@qq.com?cc=10002@qq.com&bbc=madanteng@qqhelp.com&subject=观了不起的盖茨比有感。&body=你好,对此评论有些想法。">对此影评有何感想,发送邮件给我</a>

18.<img>标签

在网页的制作中为使网页炫丽美观,肯定是缺少不了图片,可以使用

标签来插入图片。

  • 语法:
 [站外图片上传中……(2)] <img src = "myimage.gif" alt = "My Image" title = "My Image" />
  • 讲解:
src:标识图像的位置;
alt:指定图像的描述性文本,当图像不可见时(下载不成功时),可看到该属性指定的文本;
title:提供在图像可见时对图像的描述(鼠标滑过图片时显示的文本);
图像可以是GIF,PNG,JPEG格式的图像文件。
路径有两种填写方式:绝对路径、相对路径
相对路径:相对于我们当前 html 文件的位置来写路径即可!
./表示当前目录,../表示上一级目录

19.<form>标签

注意:

1、所有表单控件(文本框、文本域、按钮、单选框、复选框等)都必须放在<form></form>标签之间(否则用户输入的信息可提交不到服务器上哦!)。

2、method:post/get的区别这一部分内容属于后端程序员考虑的问题。

  • 网站怎样与用户进行交互?答案是使用HTML表单(form)。表单是可以把浏览者输入的数据传送到服务器端,这样服务器端程序就可以处理表单传过来的数据。

语法:

<form method="传送方式" action="服务器文件">
  • 讲解:
<form> :<form>标签是成对出现的,以<form>开始,以</form>结束。
action :浏览者输入的数据被传送到的地方,比如一个PHP页面(save.php)。
method : 数据传送的方式(get/post)。
 <form method="post" action="save.php"> 
 <label for="username">用户名:</label> 
 <input type="text" name="username" /> 
 <label for="pass">密码:</label> 
 <input type="password" name="pass" /> 
 </form>

20.<input>标签

  • 当用户要在表单中键入字母、数字等内容时,就会用到文本输入框。文本框也可以转化为密码输入框。

语法:

 <form> 
 <input type="text/password" name="名称" value="文本" /> 
 </form>
  • 属性:
举例:
 <form> 
 姓名: <input type="text" name="myName"/><br/> 
 密码: <input type="password" name="pass"/> 
 </form>
 value="xxx" 替换为 placeholder="xxx" 的体验更好一些,placeholder属性为 HTML 5 的新属性。placeholder 属性提供可描述输入字段预期值的提示信息(hint)。该提示会在输入字段为空时显示,并会在字段获得焦点时消失。

语法:

<input placeholder="text"/>
注释:placeholder 属性适用于以下的 <input> 类型:text, search, url, telephone, email 以及 password。

注意:同一组的单选按钮,name 取值一定要一致,比如上同一个名称“gender”,这样同一组的单选按钮才可以起到单选的作用!

type:

  • 当type="text"时,输入框为文本输入框;
  • 当type="password"时, 输入框为密码输入框。
  • hidden 定义隐藏输入字段
  • image 定义图像作为提交按钮
  • number 定义带有 spinner 控件的数字字段
  • password 定义密码字段。字段中的字符会被遮蔽
  • radio 定义单选按钮
  • checkbox 定义复选框按钮
  • range 定义带有 slider 控件的数字字段
  • reset 定义重置按钮。重置按钮会将所有表单字段重置为初始值
  • search 定义用于搜索的文本字段
  • submit 定义提交按钮。提交按钮向服务器发送数据
  • text 默认。定义单行输入字段,用户可在其中输入文本。默认是 20 个字符
  • url 定义用于 URL 的文本字段

name:为文本框命名,以备后台程序ASP 、PHP使用。

value:为文本输入框设置默认值。(一般起到提示作用)

21.<textarea>标签

  • 当用户需要在表单中输入大段文字时,需要用到文本输入域。

语法:

 <textarea rows="行数" cols="列数">文本</textarea>
  1. <textarea>标签是成对出现的,以<textarea>开始,以</textarea>结束。
  2. cols :多行输入域的列数。
  3. rows :多行输入域的行数。
  4. 在<textarea></textarea>标签之间可以输入默认值。

举例:

 <form method="post" action="save.php"> 
 <label>联系我们</label> 
 <textarea cols="50" rows="10" >在这里输入内容...</textarea> 
 </form>

22.<select>标签

  • 使用下拉列表框,节省空间。下拉列表在网页中也常会用到,它可以有效的节省网页空间。既可以单选、又可以多选。

语法:

 <select> 
 <option value="提交的值">显示的值</option> ... 
 </select>
 设置selected="selected"属性,则该选项就被默认选中。 
 selected="selected"
  • 若想实现多选
<select multiple="multiple"> 然后选择时候按ctrl点鼠标选中
  • 若想让某个选项不可选
<option disabled="disabled">
  • optgroup 标签

把相关的选项组合在一起

属性 label:给选项组命名

属性 disabled:禁用该选项组

23.<label>标签

  • label标签不会向用户呈现任何特殊效果,它的作用是为鼠标用户改进了可用性。如果你在 label 标签内点击文本,就会触发此控件。就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)。
  • 语法:
 <label for="控件id名称">

注意:标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同。

  • 例子:
 <form> 
 <label for="male">男</label> 
 <input type="radio" name="gender" id="male" /> <br /> 
 <label for="female">女</label> 
 <input type="radio" name="gender" id="female" /> 
 <label for="email">输入你的邮箱地址</label> 
 <input type="email" id="email" placeholder="Enter email"> 
 </form>

24.<map>标签

使用 map 标签可以给图片某块区域加超链接

使用方法:

1)为 map 标签首先加上 id 属性用来为 map 标签定义一个唯一的名称

2)为了保证兼容性再加上 name 属性,属性值与 id 的值相同

3)为 map 标签所作用的图片加上 usemap 属性,属性值为 #id 名称

4)在 map 标签内嵌套 area 标签来实现给指定区域加链接

 <area shape="" coords="" href ="" alt="" />
 shape 属性:定义链接区域的形状,常用值 rect、circle
 coords 属性:确定区域的精确位置。填写坐标即可,以父元素左上角为原点,可借助qq截图来得到想要的坐标
 href 属性:填写链接地址即可
 alt 属性:给链接加一些说明信息

例子:

 <map id="img1" name="img1"> 
 <area shape="rect" coords="184,33,391,258" href="http:www.baidu.com" alt="百度一下" target="_blank" /> 
 <area shape="circle" coords="507,287,20" href="http://www.sifangku.com" alt="私房库我的博客" target="_blank" /> 
 </map>

注意:

  1. 第一个coords的四个参数中,前两个参数为矩形的接近原点的顶角的坐标,后两个参数为对角的坐标。
  2. 第二个coords的三个参数中,前两个为圆心坐标,第三个参数为圆的半径。

25.<iframe>标签

创建包含另外一个文档的内联框架(即行内框架)

属性:

  • frameborder

值:1、0

作用:规定是否显示框架周围的边框。

  • width值:以像素计的宽度值、以包含元素百分比计的宽度值

作用:定义 iframe 的宽度

  • height

作用:定义高度

  • name

作用:给 iframe 命名

  • scrolling

值:yes、no、auto

作用:规定是否在 iframe 中显示滚动条

  • src

作用:规定在 iframe 中显示的文档的 URL

可以是本地的 html 文件,也可以是远程的 html 文件

标签写法与嵌套的讨论


标签写法

  • 元素标记的省略(在 html5 里面有的标记是可以省略不写的)

1)不允许写结束标签的元素

area,base,br,col,command,embed,hr,img,input,keygen,link,meta,paran,source,track,wbr。这些标签都是单标签例如:br 标签,不可以这样<br></br>,只能<br />这样来关闭标签。

2)可以省略结束标记的元素有:

 li,dt,dd,p,rt,rp,optgroup,option,colgroup,thead,tbody,tfoot,tr,td,th。

3)可以省略全部标记的元素有

 html,head,body,colgroup,tbody
  • 具有 boolean 值得属性
 例如:disabled,readonly,checked 等只写属性而不写属性值得时候当做 ture
 不写属性表示 false
  • 属性值的引号可以省略
 要求:属性值不包含 空字符串,<,>,=, ‘

标签嵌套探讨


1.html 规定我们必须要嵌套着写的标签

例如:页面头部是嵌套在 head 标签里面的,主体内容都是嵌套在 body 标签里面的表单的内容是嵌套在 form 标签里面的,dt、dd 是嵌套在 dl 标签里面的,li 是嵌套到ul 标签里面的,等等...

2.块级元素可以嵌套内联元素,但是内联元素不能包含块元素

<div>
 <span>我是一个 span 元素</span>
 </div> —— 对 
<span>
 <div>div 元素</div>
</span> —— 错

3.内联元素可以嵌套内联元素

<a href="#">
 <span></span>
</a> —— 对

4.块级元素与块级元素嵌套注意点

  • div 块级元素是一个容器,几乎可以存放任何常用标签,包括自己,我们为什么要使用 div 来嵌套标签?这个问题可以用用我们国家的省份划分来解释,国家需要划分不同的省份来利于管理,那么我们 html 页面也是的,整个 html 文档元素太多,我们需要使用 div 标签将页面划分成不同的块,这样可以对每块进行分开管理,学完 css 我们就知道怎么进行管理了。
  • 块级元素不能放在 p 标签里面
<p><ol><li></li></ol></p> —— 错 <p><div></div></p> —— 错
  • li 内可以包含 div 标签,li 和 div 标签都是装载内容的容器,地位平等,没有级别之分(例如:h1、h2 这样森严的等级制度) ,要知道 li 标签连它的父级 ul 或者是 ol 都可以容纳的

喜欢前端的小伙伴们可以在评论区留言,寻找和小冯童鞋一样热爱前端的友人,让我们一起玩转前端的世界!