写在开头:本文是学习Java后端开发的个人笔记,便于自己复习。文章内容引用了尚硅谷的javaweb教学,有兴趣的朋友可以上B站搜索。另外,由于是侧重java后端,所以对于HTML和CSS这里仅做了简单的介绍,着重点在于如何去使用前端工程师写好的静态页面。如果想详细了解前端的朋友,可以再去看前端相关的博客和视频。
Ⅰ B/S软件结构
Ⅱ 前端开发流程
Ⅲ 网页的组成部分
Ⅳ HTML技术
Ⅴ CSS技术
网页由三部分内容组成:内容(结构)、表现、行为
内容:我们在页面中看到的数据,称之为内容。一般内容,我们使用html技术来展示
表现:内容在页面上的展示形式。比如说:布局,颜色,大小等等。一般使用CSS技术实现
行为:页面中元素与输入设备交换的响应。一般用javascrip技术实现
Hyper Text Markup Language (超文本标记语言) 简写:HTML
HTML 通过标签来标记要显示的网页中的各个部分。网页文件本身是一种文本文件,
通过在文本文件中添加标记符,可以告诉浏览器如何显示其中的内容(如:文字如何处 理,画 面如何安排,图片如何显示等)
创建HTML文件
(1)创建一个web工程
(2)在工程下创建html页面
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200403104015614.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0ljZVRpZ2VyXw==,size_16,color_FFFFFF,t_70
HTML文件的书写规范
<html> 表示整个html页面的开始
<head> 头信息
<title>标题title> 标题
head>
<body> body是页面的主体内容
页面主体内容
body>
html> 表示整个html页面的结束
Html 的代码注释
示例:https://paste.ubuntu.com/p/qfShJ3mwQs/
HTML标签介绍
- 标签的格式
<标签名>封装的数据标签名>
- 标签名大小写不敏感
- 标签拥有自己的属性
+ 基本属性:bgcolor="red" 可以修改简单的样式效果
+ 时间属性:onclick="alert"('你好') 可以直接设置事件响应后的代码
- 标签又分为单标签和双标签
+ 单标签格式:<标签名 />
+ 双标签格式:<标签名>...封装的数据...标签名>
- 标签的语法易错点
+
正确:早安
错误:早安
+
正确:早安,尚硅谷
错误:早安,尚硅谷
正确:
错误:
+
正确:早安,尚硅谷
错误:早安,尚硅谷
错误:早安,尚硅谷
+
正确:
错误: -->
-
常用标签介绍与示例
5.1 font字体标签
示例:在网页上显示 我是字体标签,并修改字体为 宋体,颜色为 红色
<body>
<font color="red" face="宋体" size=7>我是字体标签font>
body>
5.2 特殊字符
示例:把
换行标签变成文本转换成字符显示在页面上(更多的特殊字符转换大家可以自行百度)
<body>
我是<br>标签
body>
5.3 标题标签
示例:演示标题 1 到 标题 6
<body>
<h1 align="left">标题1h1>
<h2 align="center">标题2h2>
<h3 align="right">标题3h3>
<h4 align="left">标题4h4>
<h5 align="left">标题5h5>
<h6 align="left">标题6h6>
body>
5.4 超链接(重点)
示例:实现普通的超链接
<body>
<a herf="http://localhost:8080">百度a><br />
<a herf="http://localhost:8080" target=“——self”>百度a><br />
<a herf="http://localhost:8080" targer="blank">a><br />
body>
5.5 列表标签
示例:使用无序列表,把FPX,IG,RNG,EDG展示出来
<body>
<ul type="none">
<li>IGli>
<li>FPXli>
<li>RNGli>
<li>EDGli>
ul>
body>
5.6 img标签
示例:使用img标签显示一张照片。并修改宽高,和边框属性
<body>
<img src="1.jpg" width="200" height="260" border="1" alt="找不到图片!"/>
<img src="../2.jpg" width="200" height="260">
body>
5.7 表格标签(重点)
示例:做一个带表头的,三行三列的表格,并显示边框;修改表格的宽度、高度、表格的对齐方式,单元格间距。
<body>
<table align="center" border="1" width="300" height="300" callspacing="0">
<tr>
<th>1.1th>
<th>1.2th>
<th>1.3th>
tr>
<tr>
<td>2.1td>
<td>2.2td>
<td>2.3td>
tr>
<tr>
<td>3.1td>
<td>3.2td>
<td>3.3td>
tr>
table>
body>
5.8 跨行跨列表格(重点)
示例:新建一个五行五列的表格,第一行,第一列的单元格要跨两列,第二行第一列的单元格要跨两行,第四行第四列的单元格跨两行两列。
<body>
<table width="500" height="500" cellspacing="0" border="1">
<tr>
<td colspan="2">1.1td>
<td>1.3td>
<td>1.4td>
<td>1.5td>
tr>
<tr>
<td rowspan="2">2.1td>
<td>2.2td>
<td>2.3td>
<td>2.4td>
<td>2.5td>
tr>
<tr>
<td>3.2td>
<td>3.3td>
<td>3.4td>
<td>3.5td>
tr>
<tr>
<td>4.1td>
<td>4.2td>
<td>4.3td>
<td colspan="2" rowspan="2">4.4td>
tr>
<tr>
<td>5.1td>
<td>5.2td>
<td>5.3td>
tr>
table>
body>
示例图:
5.9 iframe框架标签(内嵌窗口)
示例:在一个html页面上,打开一个窗口,去加载一个单独的页面
<body>
我是一个单独的完整的页面<br/><br/>
<iframe src="3.标签标题.html" width="500" height="400" name="abc">iframe>
<br/>
<ul>
<li><a href="0-标签语法.html" target="abc">0-标签语法.htmla>li>
<li><a href="1.font 标签.html" target="abc">1.font 标签.htmla>li>
<li><a href="2.特殊字符.html" target="abc">2.特殊字符.htmla>li>
ul>
body>
5.10 表单标签(超重点)
示例:创建一个个人信息注册的表单界面。包含用户名,密码,确认密码。性别(单选),兴趣爱好(多选),国籍(下拉列表)。
隐藏域,自我评价(多行文本域)。重置,提交。
表单的显示:
<body>
<form>
用户名称:<input type="text" value="默认值"/><br/>
用户密码:<input type="password" value="abc"><br/>
确认密码:<input type="password" value="abc"><br/>
性别:<input type="radio" name="sex" checked="checked">男<input type="radio" name="sex">女<br/>
兴趣爱好:<input type="checkbox" checked="checked"/>Java<input type="checkbox" />C<input type="checkbox" />Python<br/>
国籍:<select>
<option>--请选择国籍--option>
<option selected="selected">中国option>
<option>美国option>
<option>日本option>
select><br/>
自我评价:<textarea rows="10" cols="20">默认值textarea><br/>
<input type="reset" value="reset" />
<input type="submit" value="submit" />
<form>
body>
<body>
<form>
<h1 align="center">用户注册h1>
<table align="center">
<tr>
<td> 用户名称:td>
<td>
<input type="text" value="默认值"/>
td>
tr>
<tr>
<td> 用户密码:td>
<td>
<input type="password" value="abc">
td>
tr>
<tr>
<td> 确认密码:td>
<td>
<input type="password" value="abc">
td>
tr>
<tr>
<td>性别:td>
<td>
<input type="radio" name="sex" checked="checked">男
<input type="radio" name="sex">女
td>
tr>
<tr>
<td>兴趣爱好: td>
<td>
<input type="checkbox" checked="checked"/>Java
<input type="checkbox" />C
<input type="checkbox" />Python
td>
tr>
<tr>
<td> 国籍:td>
<td>
<select>
<option>--请选择国籍--option>
<option selected="selected">中国option>
<option>美国option>
<option>日本option>
select>
td>
tr>
<tr>
<td>自我评价:td>
<td>
<textarea rows="10" cols="20">默认值textarea><br/>
td>
tr>
<tr>
<td><input type="reset" value="reset" />td>
<td align="center"><input type="submit" value="submit" />td>
tr>
table>
form>
body>
<body>
<form action="http://www.baidu.com" method="get">
<input type="hidden" name="action" value="login"/>
<h1 align="center">用户注册h1>
<table align="center">
<tr>
<td> 用户名称:td>
<td>
<input type="text" name="username" value="默认值"/>
td>
tr>
<tr>
<td> 用户密码:td>
<td>
<input type="password" name="password" value="abc">
td>
tr>
<tr>
<td> 确认密码:td>
<td>
<input type="password" name="repassword" value="abc">
td>
tr>
<tr>
<td>性别:td>
<td>
<input type="radio" name="sex" checked="checked" value="boy">男
<input type="radio" name="sex" value="girl">女
td>
tr>
<tr>
<td>兴趣爱好: td>
<td>
<input name="hobby" type="checkbox" checked="checked" value="java" />Java
<input name="hobby" type="checkbox" value="c" />C
<input name="hobby" type="checkbox" value="python" />Python
td>
tr>
<tr>
<td> 国籍:td>
<td>
<select name="country">
<option value="none">--请选择国籍--option>
<option value="cn" selected="selected">中国option>
<option value="usa">美国option>
<option value="jp">日本option>
select>
td>
tr>
<tr>
<td>自我评价:td>
<td>
<textarea name="desc" rows="10" cols="20">默认值textarea><br/>
td>
tr>
<tr>
<td><input type="reset" value="reset" />td>
<td align="center"><input type="submit" value="submit" />td>
tr>
table>
form>
body>
5.11 其他标签
示例:div、span、p标签的演示
<body>
<div>div标签1div>
<div>div标签2div>
<span>span标签1span>
<span>span标签2span>
<p>p段落标签1p>
<p>p段落标签2p>
body>
Ⅴ CSS技术
-
CSS技术介绍
CSS是[层叠样式表单]。是用于(增强)控制网页样式并允许将样式信息与网页内容分离的一种标记行语言。
-
CSS语法规则
选择器: 浏览器根据“选择器”决定受CSS样式影响的HTML元素(标签)
属性 (property)是你要改变的样式名,并且每个属性都有一个值。属性和值被冒号分开,并由花括号包围,这样就组成了一个完整的样式声明(declaration),例如:p{color:blue}
多个声明: 如果要定义不止一个声明,则需要用分号将每个声明分开。虽然最后一条声明的最后可以不加分号(但尽量在每条声明的末尾加上分号)
例如:
p{
color:red;
font-size:30px;
}
-
CSS和HTML的结合方式
(1)第一种:在标签的stytle属性上设置"key:value value",修改标签样式
示例:分别定义两个div、span标签,分别修改每个div标签的样式为:边框1个像素,实线,红色。
<body>
<div style="border: 1px solid red;">div标签1div>
<div style="border: 1px solid red;">div标签2div>
<span style="border: 1px solid red;">span标签1span>
<span style="border: 1px solid red;">span标签2span>
body>
(2)第二种:在head标签中,使用stytle标签来定义各种自己需要的css样式
格式如下:
xxx{
Key : value value;
}
示例:分别定义两个 div、span 标签,分别修改每个 div 标签的样式为:边框 1 个像素,实线,红色。
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style type="text/css">
/* 需求 1:分别定义两个 div、span 标签,分别修改每个 div 标签的样式为:边框 1 个像素,实线,红色。*/
div{
border: 1px solid red;
}
span{
border: 1px solid red;
}
style>
head>
<body>
<div>div标签1div>
<div>div标签2div>
<span>span标签1span>
<span>span标签2span>
body>
(3)第三种:把css样式写成一个单独的css文件,再通过link标签引入即可复用
使用 html 的 rel=“stylesheet” type=“text/css” href="./styles.css" / > 标签 导入 css 样 式文件。
css文件内容:
div{
border: 1px solid yellow;
}
span{
border: 1px solid red;
}
html文件代码:
<head>
<meta charset="UTF-8">
<title>Titletitle>
<link rel="stylesheet" type="text/css" herf="1.css" />
head>
<body>
<div>div 标签 1div>
<div>div 标签 2div>
<span>span 标签 1span>
<span>span 标签 2span>
body>
-
CSS选择器
在学习css选择器之前,我们首先要明确,作为后端程序员,我们并不关注如何写样式,我们关注的是如何使用样式。所以,再阅读下边示例的时候,我们应该把注意点落在如何用而不是如何写。
4.1 标签名选择器
标签名选择器的格式是:
标签名{
属性: 值
}
/* 便签名选择器,可以决定哪些标签被动的使用这个样式 */
示例:在所有 div 标签上修改字体颜色为蓝色,字体大小 30 个像素。边框为 1 像素黄色实线。 并且修改所有 span 标签的字体颜色为黄色,字体大小 20 个像素。边框为 5
/* css代码 */
div{
border: 1px solid yellow;
color: blue;
font-size: 30px;
}
span{
border: 5px dashed blue;
color: yellow;
font-size: 20px;
}
<body>
<div>div标签div>
<span>span标签span>
body>
4.2 ID选择器
ID选择器的格式是:
#id 属性值{
属性:值;
}
/* id选择器,可以让我们通过id属性选择性的去使用这个样式 */
示例:分别定义两个 div 标签,
第一个 div 标签定义 id 为 id001 ,然后根据 id 属性定义 css 样式修改字体颜色为蓝色, 字体大小 30 个像素。边框为 1 像素黄色实线。
第二个 div 标签定义 id 为 id002 ,然后根据 id 属性定义 css 样式 修改的字体颜色为红色,字体大小 20 个像 素。边框为 5 像素蓝色点线。
/* css代码 */
#id001{
color: blue;
font-size: 30px;
border: 1px yellow solid;
}
#id002{
color: red;
font-size: 20px;
border: 5px blue dotted;
}
<body>
<div id="id001">div标签1div>
<div id="id002">div标签2div>
body>
4.3 class选择器
class选择器的格式是:
.class 属性值{
属性:值;
}
/* class类型选择器,可以通过class属性有效的选择性地去使用这个样式 */
示例:
修改 class 属性值为 class01 的 span 或 div 标签,字体颜色为蓝色,字体大小 30 个像素。边框为 1 像素黄色实线。
修改 class 属性值为 class02 的 div 标签,字体颜色为灰色,字体大小 26 个像素。边框为 1 像素红色实线。
/* css代码 */
.class01{
color: blue;
font-size: 30px;
border: 1px solid yellow;
}
.class02{
color: gray;
font-size: 26px;
border: 1px solid red;
}
<body>
<div class="class01">div标签class01div>
<div class="class02">div标签div>
<span class="class01">span标签class01span>
<span>span标签2span>
body>
4.4 组合选择器
组合选择器的格式是:
选择器1,选择器2,...,选择器n{
属性:值;
}
/* 组合选择器可以让多个选择器共用同一个css代码 */
示例:修改 class=“class01” 的 div 标签 和 id=“id01” 所有的 span 标签,字体颜色为蓝色,字体大小 20 个像素。 边框为 1 像素黄色实线。
/* css代码 */
.class01,#id01{
color: blue;
font-size: 20px;
border: 1px solid yellow;
}
<body>
<div class="class01">div标签class01div> <br />
<span id="id01">span 标签span> <br />
<div>div标签div> <br />
<div>div标签id01div> <br />
body>
-
常用样式
- 字体颜色
color:red;
颜色可以写颜色名如:black, blue, red, green 等
颜色也可以写 rgb 值和十六进制表示值:如 rgb(255,0,0),#00F6DE,如果写十六进制值必 须加#
- 宽度
width:19px;
宽度可以写像素值:19px;
也可以写百分比值:20%;
- 高度
height:20px;
高度可以写像素值:19px;
也可以写百分比值:20%;
- 背景颜色
background-color:#0F2D4C
- 字体样式
color:#FF0000;字体颜色红色
font-size:20px; 字体大小
- 红色1像素实线边框
border:1px solid red;
- DIV居中
margin-left: auto;
margin-right: auto;
- 文本居中
text-align: center;
- 超链接去下滑线
text-decoration: none;
- 表格细线&列表去修饰
/* 表格细线 */
table {
border: 1px solid black; /*设置边框*/
border-collapse: collapse; /*将边框合并*/ }
td,th {
border: 1px solid black; /*设置边框*/
}
/* 列表去修饰 */
ul {
list-style: none;
}