JavaWeb--HTML&CSS

HTML&CSS

  • 1 HTML
    • 1.1 介绍
    • 1.2 快速入门
    • 1.3 基础标签
      • 1.3.1 标题标签
      • 1.3.2 hr标签
      • 1.3.3 字体标签
      • 1.3.4 换行标签
      • 1.3.5 段落标签
      • 1.3.6 加粗、斜体、下划线标签
      • 1.3.7 居中标签
      • 1.3.8 案例
    • 1.4 图片、音频、视频标签
    • 1.5 超链接标签
    • 1.6 列表标签
    • 1.7 表格标签
    • 1.8 布局标签
    • 1.9 表单标签
      • 1.9.1 表单标签概述
      • 1.9.2 form标签属性
      • 1.9.3 代码演示
    • 1.10 表单项标签
  • 2 CSS
    • 2.1 概述
    • 2.2 css 导入方式
    • 2.3 css 选择器
    • 2.4 css 属性


目标:

  • 能够掌握课程中讲解的标签的使用
  • 了解css的使用

1 HTML


1.1 介绍

HTML 是一门语言,所有的网页都是用HTML 这门语言编写出来的,也就是HTML是用来写网页的,像京东,12306等网站有很多网页。
JavaWeb--HTML&CSS_第1张图片

HTML(HyperText Markup Language):超文本标记语言:

  • 超文本:超越了文本的限制,比普通文本更强大。除了文字信息,还可以定义图片、音频、视频等内容

    如上图看到的页面,我们除了能看到一些文字,同时也有大量的图片展示;有些网页也有视频,音频等。这种展示效果超越了文本展示的限制。

  • 标记语言:由标签构成的语言

    之前学习的XML就是标记语言,由一个一个的标签组成,HTML 也是由标签组成 。我们在浏览器页面右键可以查看页面的源代码,如下

    JavaWeb--HTML&CSS_第2张图片

    可以看到如下内容,就是由一个一个的标签组成的

    JavaWeb--HTML&CSS_第3张图片

这些标签不像XML那样可以自定义,==HTML中的标签都是预定义好的,运行在浏览器上并由浏览器解析,==然后展示出对应的效果。例如我们想在浏览器上展示出图片就需要使用预定义的 img 标签;想展示可以点击的链接的效果就可以使用预定义的 a 标签等。

HTML 预定义了很多标签,由于我们是Java工程师、是做后端开发,所以不会每个都学习,页面开发是有专门的前端工程来开发。那为什么我们还要学习呢?在公司中或多或少大家也会涉及到前端开发。

简单的给大家聊一下开发流程:

以后我们是通过Java程序从数据库中查询出来数据,然后交给页面进行展示,这样用户就能通过在浏览器通过页面看到数据。

W3C标准:

W3C是万维网联盟,这个组成是用来定义标准的。他们规定了一个网页是由三部分组成,分别是:

  • 结构:对应的是 HTML 语言
  • 表现:对应的是 CSS 语言
  • 行为:对应的是 JavaScript 语言

HTML定义页面的整体结构;CSS是用来美化页面,让页面看起来更加美观;JavaScript可以使网页动起来,比如轮播图也就是多张图片自动的进行切换等效果。

为了更好的给大家表述这三种语言的作用。我们通过具体的页面给大家说明。

如下只是使用HTML语言编写的页面的结构:

JavaWeb--HTML&CSS_第4张图片

可以看到页面是比较丑的,但是每一部分其实都已经包含了。接下来咱们加上 CSS 进行美化看到的效果如下:

JavaWeb--HTML&CSS_第5张图片

瞬间感觉好看多了,这就是CSS的作用,用来美化页面的。接下来再加上JavaScript试试

JavaWeb--HTML&CSS_第6张图片

在上图中可以看到多了轮播图,在浏览器上它是会自动切换图片的,并且切换的动态效果是很不错的。


1.2 快速入门

需求:编写如下图效果的页面

JavaWeb--HTML&CSS_第7张图片

要实现这个页面,我们需要从以下三步进行实现

  • 新建文本文件,后缀名改为 .html

    页面文件的后缀名是 .html,所以需要该后缀名

  • 编写 HTML 结构标签

    HTML 是由一个一个的标签组成的,但是它也用于表示结构的标签

    <html>
    	<head>
        	<title> title>
        head>
        <body>
            
        body>
    html>
    

    html标签是根标签,下面有 head 标签和 body 标签这两个子标签。而 head 标签的 title 子标签是用来定义页面标题名称的,它定义的内容会展示在浏览器的标题位置,如下图红框标记

    JavaWeb--HTML&CSS_第8张图片

    body 标签的内容会被展示在内容区中,如下图红框标记

    JavaWeb--HTML&CSS_第9张图片

  • 在中定义文字

代码如下:

<html>
	<head>
    	<title>html 快速入门title>
    head>
    <body>
        乾坤未定,你我皆是黑马~
    body>
html>

同学们在访问其他网站页面时会看到字体颜色是五颜六色的,我们可以该字体颜色吗?当然可以了

font 标签就可以使用,该标签有一个 color 属性可以设置字体颜色,如: 就是将文字设置成了红颜色。那么我们只需要将需要变成红色的文字放在标签体部分就可以了,如下:

<html>
	<head>
    	<title>html 快速入门title>
    head>
    <body>
        <font color='red'>乾坤未定,你我皆是黑马~font>
    body>
html>

总结:

  • HTML 文件以.htm或.html为扩展名

  • HTML 结构标签

    JavaWeb--HTML&CSS_第10张图片

  • HTML 标签不区分大小写

    如上案例中的 font 写成 Font 也是一样可以展示出对应的效果的。

  • HTML 标签属性值 单双引皆可

    如上案例中的color属性值使用双引号也是可以的。

  • HTML 语法松散

    比如 font 标签不加结束标签也是可以展示出效果的。但是建议同学们在写的时候还是不要这样做,严格按照要求去写。


1.3 基础标签

基础标签就是一些和文字相关的标签,如下:

JavaWeb--HTML&CSS_第11张图片

1.3.1 标题标签

  • 创建模块

    在 Idea 中创建模块,而我们现在不需要写java代码,所以 src 目录就可以删除掉。在模块下创建一个html文件夹,该我们今天的所以的页面文件所部放在该文件夹下。模块目录如下

  • 创建页面文件

    选中 html 文件夹右键创建页面文件(01-基础标签.html)

JavaWeb--HTML&CSS_第12张图片

创建好后 idea 会自动加上结构标签,如下

JavaWeb--HTML&CSS_第13张图片

我们只需要在 body 标签中书写标签。

  • 书写标题标签

    标题标签中 h1最大,h6最小。

    <h1>我是标题 h1h1>
    <h2>我是标题 h2h2>
    <h3>我是标题 h3h3>
    <h4>我是标题 h4h4>
    <h5>我是标题 h5h5>
    <h6>我是标题 h6h6>
    
  • 通过浏览器查看效果

    idea 提供了快捷的打开方式,如下图

    JavaWeb--HTML&CSS_第14张图片

    浏览器展示效果如下:

    JavaWeb--HTML&CSS_第15张图片


1.3.2 hr标签


hr 标签在浏览器中呈现出 横线 的效果。

在页面文件中书写 hr 标签


效果如下:


1.3.3 字体标签


font:字体标签

  • face 属性:用来设置字体。如 “楷体”、"宋体"等

  • color 属性:设置文字颜色。颜色有三种表示方式

    • 英文单词:red,pink,blue…

      这种方式表示的颜色特别有限,所以一般不用。

    • rgb(值1,值2,值3):值的取值范围:0~255

      此种方式也就是三原色(红绿蓝)设置方式。 例如: rgb(255,0,0)。

      这种书写起来比较麻烦,一般不用。

    • #值1值2值3:值的范围:00~FF

      这种方式是rgb方式的简化写法,以后基本都用此方式。

      值1表示红色的范围,值2表示绿色的范围,值3表示蓝色范围。例如: #ff0000

  • size 属性:设置文字大小

代码演示:

<font face="楷体" size="5" color="#ff0000">传智教育font>

效果如下:

注意:

font 标签已经不建议使用了,以后如果要改变文字字体,大小,颜色可以使用 CSS 进行设置。


1.3.4 换行标签

在页面文件中书写如下内容

茶几上摆着馓子、麻花和水果,炉子上刚煮开的奶茶香气四溢……
看望慰问藏族群众。

1.3.5 段落标签

上面文字展示的效果还是不太好,我们想让每一段上下都加空行。此时就需要使用段落标签(p标签)

在页面文件中书写如下内容:

<p>
藏族牧民索南才让家中,茶几上摆着馓子、麻花和水果,炉子上刚煮开的奶茶香气四溢……
p>
<p>
看望慰问藏族群众。
p>

这种效果就会比之前的效果好一些,呈现出段落的效果。


1.3.6 加粗、斜体、下划线标签


  • b:加粗标签
  • i:斜体标签
  • u:下划线标签,在文字的下方有一条横线

代码如下:

<b>沙柳河水流淌b><br>
<i>沙柳河水流淌i><br>
<u>沙柳河水流淌u><br>

在浏览器展示的效果如下:


1.3.7 居中标签

center :文本居中

代码如下:

<hr>
<center>
    <b>沙柳河水流淌b>
center>

在浏览器效果如下:


1.3.8 案例

实现如下图所示页面效果:

JavaWeb--HTML&CSS_第16张图片

此案例同学们自己实现,用我们学过的基础标签。

注意:在上图页面中版权所有里有特殊字符,需要使用转义字符。有如下转义字符:

JavaWeb--HTML&CSS_第17张图片


1.4 图片、音频、视频标签

JavaWeb--HTML&CSS_第18张图片

  • img:定义图片

    • src:规定显示图像的 URL(统一资源定位符)

    • height:定义图像的高度

    • width:定义图像的宽度

  • audio:定义音频。支持的音频格式:MP3、WAV、OGG

    • src:规定音频的 URL

    • controls:显示播放控件

  • video:定义视频。支持的音频格式:MP4, WebM、OGG

    • src:规定视频的 URL
    • controls:显示播放控件

尺寸单位:

height属性和width属性有两种设置方式:

  • 像素:单位是px
  • 百分比。占父标签的百分比。例如宽度设置为 50%,意思就是占它的父标签宽度的一般(50%)

资源路径:

图片,音频,视频标签都有src属性,而src是用来指定对应的图片,音频,视频文件的路径。此处的图片,音频,视频就称为资源。资源路径有如下两种设置方式:

  • 绝对路径:完整路径

    这里的绝对路径是网络中的绝对路径。 格式为: 协议://ip地址:端口号/资源名称。

    如:

    
    

    这里src属性的值就是网络中的绝对路径。

  • 相对路径:相对位置关系

    找页面和其他资源的相对路径。

    ./ 表示当前路径

    …/ 表示上一级路径

    …/…/ 表示上两级路径

    如模块目录结构如下:

    JavaWeb--HTML&CSS_第19张图片

    01-基础标签.html 里的标签中找不同的图片,路径写法不同

    
    <img src="../img/a.jpg" width="300" height="400">
    
    <img src="aa.jpg" width="300" height="400">
    

使用这些标签的代码如下:

<img src="../img/a.jpg" width="300" height="400">
<audio src="b.mp3" controls>audio>
<video src="c.mp4" controls width="500" height="300">video>

在浏览器展示的效果如下:

JavaWeb--HTML&CSS_第20张图片


1.5 超链接标签

在网页中可以看到很多超链接标签,如下

JavaWeb--HTML&CSS_第21张图片

上图红框中的都是超链接,当我们点击这些超链接时会跳转到其他的页面或者资源。而超链接使用的是 a 标签。

a 标签属性:

  • href:指定访问资源的URL

  • target:指定打开资源的方式

    • _self:默认值,在当前页面打开
    • _blank:在空白页面打开

代码演示:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>
	<a href="https://www.itcast.cn" target="_self">点我有惊喜a>
body>
html>

1.6 列表标签

HTML 中列表分为

  • 有序列表

    如下图,页面效果中是有标号对每一项进行标记的。

  • 无序列表

    如下图,页面效果中没有标号对每一项进行标记,而是使用 点 进行标记。

标签说明:

JavaWeb--HTML&CSS_第22张图片

有序列表中的 type 属性用来指定标记的标号的类型(数字、字母、罗马数字等)

无序列表中的 type 属性用来指定标记的形状

代码演示:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>
    <ol type="A">
        <li>咖啡li>
        <li>li>
        <li>牛奶li>
    ol>
    
    <ul type="circle">
        <li>咖啡li>
        <li>li>
        <li>牛奶li>
    ul>
body>
html>

1.7 表格标签

JavaWeb--HTML&CSS_第23张图片

如上图就是一个表格,表格可以使用如下标签定义

  • table :定义表格

    • border:规定表格边框的宽度

    • width :规定表格的宽度

    • cellspacing:规定单元格之间的空白

  • tr :定义行

    • align:定义表格行的内容对齐方式
  • td :定义单元格

    • rowspan:规定单元格可横跨的行数

    • colspan:规定单元格可横跨的列数

  • th:定义表头单元格

代码演示:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>

<table border="1" cellspacing="0" width="500">
    <tr>
        <th>序号th>
        <th>品牌logoth>
        <th>品牌名称th>
        <th>企业名称th>
    tr>
    <tr align="center">
        <td>010td>
        <td><img src="../img/三只松鼠.png" width="60" height="50">td>
        <td>三只松鼠td>
        <td>三只松鼠td>
    tr>

    <tr align="center">
        <td>009td>
        <td><img src="../img/优衣库.png" width="60" height="50">td>
        <td>优衣库td>
        <td>优衣库td>
    tr>

    <tr align="center">
        <td>008td>
        <td><img src="../img/小米.png" width="60" height="50">td>
        <td>小米td>
        <td>小米科技有限公司td>
    tr>
table>
body>
html>

1.8 布局标签

这两个标签,一般都是和css结合到一块使用来实现页面的布局。

div标签 在浏览器上会有换行的效果,而 span 标签在浏览器上没有换行效果。

代码演示:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>
    <div>我是divdiv>
    <div>我是divdiv>
    <span>我是spanspan>
    <span>我是spanspan>
body>
html>

浏览器效果如下:


1.9 表单标签

表单标签效果大家其实都不陌生,像登陆页面、注册页面等都是表单。

JavaWeb--HTML&CSS_第24张图片

像这样的表单就是用来采集用户输入的数据,然后将数据发送到服务端,服务端会对数据库进行操作,比如注册就是将数据保存到数据库中,而登陆就是根据用户名和密码进行数据库的查询操作。

表单是很重要的标签,需要重点来学习。


1.9.1 表单标签概述

表单:在网页中主要负责数据采集功能,使用< form>标签定义表单

表单项(元素):不同类型的 input 元素、下拉列表、文本域等

JavaWeb--HTML&CSS_第25张图片

form 是表单标签,它在页面上没有任何展示的效果。需要借助于表单项标签来展示不同的效果。如下图就是不同的表单项标签展示出来的效果。

JavaWeb--HTML&CSS_第26张图片


1.9.2 form标签属性

  • action:规定当提交表单时向何处发送表单数据,该属性值就是URL

    以后会将数据提交到服务端,该属性需要书写服务端的URL。而今天我们可以书写 # ,表示提交到当前页面来看效果。

  • method :规定用于发送表单数据的方式

    method取值有如下两种:

    • get:默认值。如果不设置method属性则默认就是该值
      • 请求参数会拼接在URL后边
      • url的长度有限制 4KB
    • post:
      • 浏览器会将数据放到http请求消息体中
      • 请求参数无限制的

1.9.3 代码演示

由于表单标签在页面上没有任何展示的效果,所以在演示的过程是会先使用 input 这个表单项标签展示输入框效果。

代码如下:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>
    <form>
        <input type="text">
        <input type="submit">
    form>
body>
html>

浏览器展示效果如下:

从效果可以看到页面有一个输入框,用户可以在数据框中输入自己想输入的内容,点击提交按钮以后会将数据发送到服务端,当然现在肯定不能实现。现在我们可以将 form 标签的 action 属性值设置为 # ,将其将数据提交到当前页面。还需要注意一点,要想提交数据,input 输入框必须设置 name 属性。代码如下:

DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
head>
<body>
    <form action="#">
        <input type="text" name="username">
        <input type="submit">
    form>
body>
html>

浏览器展示效果如下:

在输入框输入 hehe ,然后点击 提交 按钮,就能看到如下效果

我们可以看到在浏览器的地址栏的URL后拼接了我们提交的数据。username 就是输入框 name 属性值,而 hehe 就是我们在输入框输入的内容。

接下来我们来聊 method 属性,默认是 method = 'get',所以该取值就会将数据拼接到URL的后面。那我们将 method 属性值设置为 post,浏览器的效果如下:

从上图可以看出数据并没有拼接到 URL 后,那怎么看提交的数据呢?我们可以使用浏览器的开发者工具来查看

JavaWeb--HTML&CSS_第27张图片

按照如上步骤操作能看到如下页面

JavaWeb--HTML&CSS_第28张图片

重新提交数据后,可以看到提交的数据,如下图

JavaWeb--HTML&CSS_第29张图片


1.10 表单项标签

表单项标签有很多,不同的表单项标签有不同的展示效果。表单项标签可以分为以下三个:

  • :表单项,通过type属性控制输入形式

    input 标签有个 type 属性。 type 属性的取值不同,展示的效果也不一样

    JavaWeb--HTML&CSS_第30张图片