目录

JavaWeb技术概览

HTML技术

HTML简介

HTML标签介绍

CSS技术

css简介

CSS语法规则        

CSS和HTML的结合方式

第一种

第二种

第三种

CSS选择器

标签名选择器

id选择器

class选择器(类选择器) 

组合选择器

常用样式


JavaWeb技术概览

javafx bootstrapfx 好看的css样式表 java html css_属性设置

html:浏览器页面的骨架结构(内容),是我们在页面中可以看到的数据,一般内容我们使用html展现

css:渲染页面表现 。指的是内容在页面上的表现形式,如布局颜色大小等,一般使用css技术实现

js:页面行为。页面中元素与输入设备交互的响应。

jQuery:js的库,js操作的封装。目前vue,react,ajs是主流框架 

Servlet:Tomcat中的重要组件,更多的用来处理业务逻辑1.获取用户请求2.处理请求3.响应请求

Filter:过滤器

Listen:监听器

http:服务端和浏览器端的交互协议。属于应用层的协议

jsp:java服务器端页面,实现动态页面展示(数据根据后台动态展示,没有固定在前端页面展示中)

EL、JSTL表达式:提升JSP的开发效率

Cookie\Session:缓存技术

Ajax:异步请求

json:数据交换格式

HTML技术

HTML简介


Hyper Text Markup Language (超文本标记语言)简写: HTML


HTML通过标签来标记要显示的网页中的各个部分。网页文件本身是一种文本文件,通过在文本文件中添加标记符,可以告诉浏览器如何显示其中的内容(如:文字如何处理,画面如何安排,图片如何显示等)



创建 HTML 文件



1.创建一个web工程(静态的web工程)




javafx bootstrapfx 好看的css样式表 java html css_前端_02


 新版本的idea选择javascript

javafx bootstrapfx 好看的css样式表 java html css_javaweb_03

javafx bootstrapfx 好看的css样式表 java html css_属性设置_04


2.在工程下创建html页面


javafx bootstrapfx 好看的css样式表 java html css_前端_05

选择浏览器执行页面

javafx bootstrapfx 好看的css样式表 java html css_HTML_06

 第一个html示例

<!DOCTYPE html><!--约束,声明-->
<html lang="zh_CN"> <!--html标签表示html的开始,lang="ch_CN"表示中文 html标签中一般分为两部分,分别是:head和body-->
<head><!--表示头部信息,一般包含3部分内容,title标签,css样式,js代码-->
    <meta charset="UTF-8"><!--表示当前页面使用UTF-8字符集-->
    <title>标题</title><!--表示标题-->
</head>
<body>
    hello
</body>
</html>

注:Java文件是需要先编译,再由 java 虚拟机跑起来。但HTML文件它不需要编译,直接由浏览器进行解析执行。


HTML 文件的书写规范


<html>                          表示整个html页面的开始
    <head>                      头信息
        <title>标题</title>     标题
    </head>
    <body>                      body是页面的主题内容
        页面主题内容                 
    </body>
</html>                         表示整个html页面的结束


Html 的代码注释 <!-- 这是 html 注释,可以在页面右键查看源代码中看到 -->


HTML标签介绍


1. 标签的格式 :


标签名>


2.标签名大小写不敏感。


3.标签拥有自己的属性。


        i. 分为基本属性: bgcolor = "red"                             可以修改简单的样式效果


        ii. 事件属性: onclick = "alert('你好!');"                 可以直接设置事件响应后的代码。


4.标签又分为,单标签和双标签。


        i. 单标签格式: <标签名 />                                   br换行  hr水平线


        ii. 双标签格式: <标签名 > ... 封装的数据 ...</标签名>


javafx bootstrapfx 好看的css样式表 java html css_属性设置_07

标签的语法

①标签不能交叉嵌套 ②标签必须正确关闭 ③属性必须有值,属性值必须加引号 ④注释不能嵌套 

font字体标签


需求 1 :在网页上显示 我是字体标签 ,并修改字体为 宋体,颜色为红色。


<body>
    <!-- 字体标签
    需求 1:在网页上显示 我是字体标签 ,并修改字体为 宋体,颜色为红色。
    font 标签是字体标签,它可以用来修改文本的字体,颜色,大小(尺寸)
    color 属性修改颜色
    face 属性修改字体
    size 属性修改文本大小
    -->
    <font color="red" face="宋体" size="7">我是字体标签</font>
</body>


特殊字符


需求 1 :把 换行标签变成文本转换成字符显示在页面上(即在网页上显示<br>)


常用特殊字符表


javafx bootstrapfx 好看的css样式表 java html css_javaweb_08

其他特殊字符表

javafx bootstrapfx 好看的css样式表 java html css_javaweb_09

通常情况下,html会对空格去重,例如果在文档中练习输入10个空格,在html中会去掉9个空格,如果使用&nbsp;,就可以增加空格

<!--常用的特殊字符:
< ===>>>> <
> ===>>>> >
空格 ===>>>>  
-->
<br>      网页显示<br/>

标题标签
标题标签是 h1 到 h6

<!-- 标题标签 -->
	h1 - h6 都是标题标签 ,h1 最大 ,h6 最小
	align 属性是对齐属性 ,left 左对齐(默认) ,center 居中 ,right 右对齐
	<h1 align="left">标题 1</h1>
	<h2 align="center">标题 2</h2>
	<h3 align="right">标题 3</h3>
	<h4>标题 4</h4>
	<h5>标题 5</h5>
	<h6>标题 6</h6>

超链接


在网页中所有点击之后可以跳转的内容都是超连接

<!-- 超链接 -->
	<!-- a 标签是超链接
		 href 属性设置链接的地址
		 target 属性设置哪个目标进行跳转
		 	_self 表示直接在当前页面(默认值)
		 	_blank 表示打开新页面来进行跳转
	-->
	<a href="http://localhost:8080">百度</a><br/>
	<a href="http://localhost:8080" target="_self">百度_self</a><br/>
	<a href="http://localhost:8080" target="_blank">百度_blank</a><br/>

列表标签

无序列表、有序列表

<!--
	ul是无序列表,ol是有序列表
	type属性可以修改列表项前面的符号
	li是列表项   

-->
	<ul type="none">
		<li>赵四</li>
		<li>刘能</li>
		<li>小沈阳</li>
		<li>宋小宝</li>
	</ul>

img标签

img 标签可以在 html 页面上显示图片。

<!--
    img 标签是图片标签,用来显示图片
        src 属性可以设置图片的路径
        width 属性设置图片的宽度
        height 属性设置图片的高度
        border 属性设置图片边框大小
        alt 属性设置当指定路径找不到图片时,用来代替显示的文本内容

    在JavaSE中路径也分为相对路径和绝对路径. 相对路径:从工程名开始算
                                          绝对路径:盘符:/目录/文件名
    在web中路径分为相对路径和绝对路径两种
        相对路径:
              . 表示当前文件所在的目录
              .. 表示当前文件所在的上一级目录
              文件名 表示当前文件所在目录的文件,相当于 ./文件名 ./ 可以省略
        绝对路径:
              正确格式是: http://ip:port/工程名/资源路径
              错误格式是: 盘符:/目录/文件名
-->
<img src="../imgs/111.jpg" width="100" height="200" border="1" alt="美女找不到">

表格标签

<!--
    table 标签是表格标签
        border 设置表格边框标签
        width 设置表格宽度
        height 设置表格高度
        align 设置表格相对于页面的对齐方式
        cellspacing 设置单元格间距
    tr 是行标签
    th 是表头标签,实现了加粗和居中
    td 是单元格标签
        align 设置单元格文本对齐方式
    b 是加粗标签
-->
<table align="center" border="1" width="300" height="300" cellspacing="0">
    <tr>
        <th>1.1</th>
        <th>1.2</th>
        <th>1.3</th>
    </tr>
    <tr>
        <td>1.1</td>
        <td>1.2</td>
        <td>1.3</td>
    </tr>
    <tr>
        <td>1.1</td>
        <td>1.2</td>
        <td>1.3</td>
    </tr>
</table>

跨行跨列表格


需求 1 :新建一个五行,五列的表格,第一行,第一列的单元格要跨两列,第二行第一列的单元格跨两行,第四行第四列的单元格跨两行两列


<!--
    colspan 属性设置跨列
    rowspan 属性设置跨行
-->
<table  border="1" width="500" height="500" cellspacing="0">
    <tr>
        <th colspan="2">1.1</th>

        <th>1.3</th>
        <th>1.2</th>
        <th>1.3</th>
    </tr>
    <tr>
        <th rowspan="2">1.1</th>
        <th>1.2</th>
        <th>1.3</th>
        <th>1.2</th>
        <th>1.3</th>
    </tr>
    <tr>

        <th>1.2</th>
        <th>1.3</th>
        <th>1.2</th>
        <th>1.3</th>
    </tr>
    <tr>
        <th>1.1</th>
        <th>1.2</th>
        <th>1.3</th>
        <th rowspan="2" colspan="2">1.2</th>

    </tr>
    <tr>
        <th>1.1</th>
        <th>1.2</th>
        <th>1.3</th>
        
    </tr>
</table>


javafx bootstrapfx 好看的css样式表 java html css_javaweb_10


iframe框架标签(内嵌窗口)

iframe标签它可以在一个html页面上,打开一个小窗口,去加载一个单独的页面.

<!--
   iframe标签可以在页面上开辟一个小区域显示一个单独的页面
        iframe和a标签组合使用的步骤:
            1 在iframe标签中使用name属性定义一个名称
            2 在a标签的target属性上设置iframe的name的属性值
-->
我在这
<iframe src="2.特殊字符.html" width="500" height="300" name="abc" ></iframe><br/>
<ul>
    <li><a href="1.font标签.html" target="abc">语法一</a> </li>
    <li><a href="3.标题标签.html" target="abc">语法一</a> </li>
</ul>

表单标签

表单就是html页面中,用来收集用户信息的所有元素集合.然后把这些信息发送给服务器.

javafx bootstrapfx 好看的css样式表 java html css_HTML_11

<!--
    form 标签就是表单
        input type=text 是文本输入框 value设置默认显示内容
        input type=password 是密码输入框 value 置默认显示内容
        input type=radio 是单选框 name属性可以对其进行分组 checked="checked"表示默认选中
        input type=checkbox 是复选框 checked="checked"表示默认选中
        input type=reset 是重置按钮 value属性修改按钮上的文本
        input type=submit 是提交按钮 value属性修改按钮上的文本
        input type=button 是按钮 value属性修改按钮上的文本
        input type=file 是文件上传域
        input type=hidden 是隐藏域 当我们要发送某些信息,而这些信息,不需要用户参与,就可以使用隐藏域(提交的
时候同时发送给服务器)
        select 标签是下拉列表框
            option 标签是下拉列表框中的选项 selected="selected"设置默认选中
        textarea 表示多行文本输入框 (起始标签和结束标签中的内容是默认值)
            rows 属性设置可以显示几行的高度
            cols 属性设置每行可以显示几个字符宽度
-->
<form>
    用户名称:<input type="text" value="1"/><br/>
    用户密码:<input type="password"/><br/>
    确认密码:<input type="password"/><br/>
    选择性别:<input type="radio" checked="checked" name="sex"/>男<input type="radio" name="sex"/>女<br/>
    选择爱好:<input type="checkbox">C<input type="checkbox"/>C++<input type="checkbox">Java<input type="checkbox"/>PHP<input type="checkbox"/>.net<br/>
    选择国家:<select>
                <option>--请选择国家</option>
                <option selected="selected">中国</option>
                <option>美国</option>
                <option>日本</option>
            </select><br/>
    自我评价:<textarea rows="5" cols="5">默认值</textarea><br/>
    <input type="submit" value="注册"/> <input type="reset" value="重置"/>
</form>

 表单格式化:

javafx bootstrapfx 好看的css样式表 java html css_javaweb_12

 上述表单页面显示不整齐,一般把表单放置在表格中显示。一般两列,第一个单元格放文字信息,第二个放表单项。

<form>
    <h1 align="center">用户注册</h1>
    <table align="center">
        <tr>
            <td>用户名称:</td>
            <td>
                <input type="text" value="1"/>
            </td>
        </tr>
        <tr>
            <td>用户密码:</td>
            <td>
                <input type="password"/>
            </td>
        </tr>
        <tr>
            <td>确认密码:</td>
            <td>
                <input type="password"/>
            </td>
        </tr>
        <tr>
            <td>性别:</td>
            <td>
                <input type="radio" checked="checked" name="sex"/>男
                <input type="radio" name="sex"/>女
            </td>
        </tr>
        <tr>
            <td>爱好:</td>
            <td>
                <input type="checkbox"/>C
                <input type="checkbox"/>C++
                <input type="checkbox"/>Java
                <input type="checkbox"/>PHP
                <input type="checkbox"/>.net
            </td>
        </tr>
        <tr>
            <td>选择国家:</td>
            <td>
                <select>
                    <option>--请选择国家</option>
                    <option selected="selected">中国</option>
                    <option>美国</option>
                    <option>日本</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>自我评价:
            <td>
            <textarea rows="10" cols="20">默认值</textarea></td>
            </td>
        </tr>
        <tr>
            <td><input type="submit" value="注册"/></td>
            <td align="center"><input type="reset" value="重置"/></td>
        </tr>
    </table>
</form>

javafx bootstrapfx 好看的css样式表 java html css_html_13

 表单提交的细节

<!--
   form 标签是表单标签
        action属性设置提交的服务器地址
        method属性设置提交的方式 GET(默认值)或 POST
   表单提交的时候,数据没有发送给服务器的三种情况:
   1、表单项没有name属性值
   2、单选、复选(下拉列表中的 option 标签)都需要添加value属性,以便发送给服务器
   3、表单项不在提交的form标签中

   GET请求的特点是:
    1、浏览器地址栏中的地址是:action属性(url)[+?+请求参数]
       请求参数的格式是:name=value&name=value
    2、不安全
    3、它有数据长度的限制
   POST 请求的特点是:
    1、浏览器地址栏中只有action属性值
    2、相对于GET请求要安全
    3、理论上没有数据长度的限制
-->
<form action="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="1"/>
            </td>
        </tr>
        <tr>
            <td>用户密码:</td>
            <td>
                <input type="password" name="password" value="abc"/>
            </td>
        </tr>
        <tr>
            <td>确认密码:</td>
            <td>
                <input type="password"/>
            </td>
        </tr>
        <tr>
            <td>性别:</td>
            <td>
                <input type="radio" checked="checked" name="sex" value="boy"/>男
                <input type="radio" name="sex" value="girl"/>女
            </td>
        </tr>
        <tr>
            <td>爱好:</td>
            <td>
                <input name="hobby" value="C" type="checkbox"/>C
                <input name="hobby" value="C++" type="checkbox"/>C++
                <input name="hobby" value="java" type="checkbox"/>Java
                <input name="hobby" value="php" type="checkbox"/>PHP
                <input name="hobby" value=".net" type="checkbox"/>.net
            </td>
        </tr>
        <tr>
            <td>选择国家:</td>
            <td>
                <select name="country">
                    <option value="none">--请选择国家</option>
                    <option value="zh" selected="selected">中国</option>
                    <option value="usa">美国</option>
                    <option value="jap">日本</option>
                </select>
            </td>
        </tr>
        <tr>
            <td>自我评价:
            <td>
            <textarea name="desc" rows="10" cols="20">默认值</textarea></td>
            </td>
        </tr>
        <tr>
            <td><input type="submit" value="注册"/></td>
            <td align="center"><input type="reset" value="重置"/></td>
        </tr>
    </table>
</form>

 其他标签

<!--
    div 标签 默认独占一行
    span 标签 它的长度是封装数据的长度
    p 段落标签 默认会在段落的上方或下方各空出一行来(如果已有就不再空)
-->
<div>div标签1</div>
<div>div标签2</div>
<span>span标签1</span>
<span>span标签2</span>
<p>p标签1</p>
<p>p标签2</p>

CSS技术

css简介


CSS 是「层叠样式表单cascading style sheet」。是用于 ( 增强 ) 控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。



CSS语法规则        


javafx bootstrapfx 好看的css样式表 java html css_前端_14


选择器 :浏览器根据“选择器”决定受 CSS 样式影响的 HTML 元素(标签)。


属性 (property) 是你要改变的样式名,并且每个属性都有一个值。属性和值被冒号分开,并


由花括号包围,这样就组成了一个完整的样式声明( declaration ),例如: p {color: blue}


多个声明: 如果要定义不止一个声明,则需要用分号将每个声明分开。虽然最后一条声明的


最后可以不加分号 ( 但尽量在每条声明的末尾都加上分号 )


p{
    color:red;
    font-size:30px;
}

注:一般每行只描述一个属性CSS 
注释:/*注释内容*/

CSS和HTML的结合方式

第一种


在标签的style属性上设置”key:value1 value2 ...;”,修改标签样式。



分别定义两个 div 、 span 标签,分别修改每个 div 标签的样式为:边框 1 个像素,实线,红色。


<div style="border: 1px solid red">div 标签 1</div>
<div style="border: 1px solid #ff0000">div 标签 2</div>
<span style="border: 1px solid red">span 标签 1</span>
<span style="border: 1px solid red">span 标签 2</span>


问题:这种方式的缺点?


1. 如果标签多了。样式多了。代码量非常庞大。


2. 可读性非常差。


3.Css 代码没什么复用性可方言。


第二种


在 head 标签中,使用 style 标签来定义各种自己需要的 css 样式。


格式如下:


       

xxx {
            Key : value value;
        }


<!--style标签专门用来定义css样式代码-->
<style type="text/css">
    div{
        border: red solid 1px;
    }
    span{
        border: red solid 1px;
    }
</style>
</head>

<body>
    <div>div 标签 1</div>
    <div>div 标签 2</div>
    <span>span 标签 1</span>
    <span>span 标签 2</span>
</body>

问题:这种方式的缺点。

        1.只能在同一页面内复用代码,不能在多个页面中复用 css 代码。

        2.维护起来不方便,实际的项目中会有成千上万的页面,要到每个页面中去修改。工作量太大了。

第三种


把 css 样式写成一个单独的 css 文件,再通过 link 标签引入即可复用。


使用 html 的 < link rel = "stylesheet" type = "text/css" href = "./styles.css" / > 标签 导入 css 样 式文件。



1 、 css 文件内容:


div{
    border: 1px solid yellow;
}
span{
    border: 1px solid red;
}


2.html 文件代码:


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--link 标签专门用来引入 css 样式代码-->
    <link rel="stylesheet" type="text/css" href="1.css"/>
</head>
<body>
    <div>div 标签 1</div>
    <div>div 标签 2</div>
    <span>span 标签 1</span>
    <span>span 标签 2</span>
    </body>
</html>


CSS选择器

标签名选择器


标签名选择器的格式是:


标签名{
    属性:值;
}


标签名选择器,可以决定哪些标签被动的使用这个样式。



需求 1 :在所有 div 标签上修改字体颜色为蓝色,字体大小 30 个像素。边框为 1 像素黄色实线。


并且修改所有 span 标签的字体颜色为黄色,字体大小 20 个像素。边框为 5 像素蓝色虚线。


<style type="text/css">
    div{
        border: yellow 1px solid;
        color: blue;
        font-size: 30px;
    }
    span{
        color: yellow;
        font-size: 20px;
        border: 5px dashed blue;
    }
</style>


id选择器


id 选择器的格式是:


#id属性值{
    属性:值;
}


id选择器,可以让我们通过id属性选择性的去使用这个样式。



练习:


需求 1:分别定义两个 div 标签,第一个 div 标签定义 id 为 id001 ,然后根据 id 属性定义 css 样式修改字体颜色为蓝色,字体大小 30 个像素。边框为 1 像素黄色实线。第二个 div 标签定义 id 为 id002 ,然后根据 id 属性定义 css 样式 修改的字体颜色为红色,字体大小 20 个像素。


边框为 5 像素蓝色点线。


<head>
<meta charset="UTF-8">
<style type="text/css">
    #id001{
        color: blue;
        font-size: 30px;
        border: 1px yellow solid;
    }
    
    #id002{
        color: red;
        font-size: 20px;
        border: 5px blue dotted ;
    }
</style>
</head>

<body>
<div id="id001">div 标签 1</div>
<div id="id002">div 标签 2</div>
</body>

class选择器(类选择器) 


class 类型选择器的格式是:



.class 属性值{
    属性:值;
}


class 类型选择器,可以通过 class 属性有效的选择性地去使用这个样式。



练习:需求 1:修改 class 属性值为 class01 的 span 或 div 标签,字体颜色为蓝色,字体大小 30 个像素。边框为 1 像素黄色实线。需求 2:修改 class 属性值为 class02 的 div 标签,字体颜色为灰色,字体大小 26 个像素。边框为 1 像素红色实线。


<head>
<meta charset="UTF-8">
<style type="text/css">
    .class01{
        color: blue;
        font-size: 30px;
        border: 1px yellow solid;
    }

    .class02{
        color: red;
        font-size: 20px;
        border: 5px blue dotted ;
    }
</style>
</head>

<body>
<div class="class01">div 标签 1</div>
<div class="class02">div 标签 2</div>
<span class="class01">span标签1</span>
<span>span标签2</span>
</body>

class选择器可以重复,id选择器不能重复

组合选择器


组合选择器的格式是:


选择器 1,选择器 2,选择器 n{
    属性:值;
}


组合选择器可以让多个选择器共用同一个 css 样式代码。


<style type="text/css">
.class01 , #id01{
color: blue;
font-size: 20px;
border: 1px yellow solid;
}
</style>


常用样式


1 、字体颜色


color : red ;


颜色可以写颜色名如: black, blue, red, green 等


颜色也可以写 rgb 值和十六进制表示值:如 rgb(255,0,0) , #00F6DE ,如果写十六进制值必 须加



2 、宽度


width:19px;


宽度可以写像素值:19px;也可以写百分比值:20%;



3、高度


height:20px;


高度可以写像素值:19px;也可以写百分比值:20%;



4、背景颜色


background-color:#0F2D4C



5、字体样式:


color:#FF0000 ;字体颜色红色


font-size:20px; 字体大小




6、边框红色1像素实线


border:1px solid red;



7、 DIV 居中


margin-left: auto;


margin-right: auto;



8、文本居中:


text-align: center;



9、超连接去下划线


text-decoration: none;



10、表格细线
table {
    border: 1px solid black; /*设置边框*/
    border-collapse: collapse; /*将边框合并*/
}

td,th {
        border: 1px solid black; /*设置边框*/
}


11、列表去除修饰


ul {


        list-style: none;


}