Web安全——HTML基础

HTML

  • 一、对于前端以及后端的认识以及分析
  • 二、HTML认知
    • 1、网页的组成
    • 2、浏览器
    • 3、Web标准
  • 三、简单的HTML页面架构
  • 四、HTML常见标签
    • 1、meta标签
    • 2、标题标签
    • 3、文本属性
    • 4、form表单
    • 5、a 标签
    • 6、锚文本
    • 7、img 标签
    • 8、table 表格
    • 9、列表标签
      • 9.1、无序列表
      • 9.2、有序列表
    • 10、框架的使用

一、对于前端以及后端的认识以及分析

1、前端与后端的认识

  • 前端: 客户端开发
  • 后端: 服务器端开发

2、前端后端区别

  • 技能
    前端:Web开发者余姚掌握HTML,CSSJavaScript
    后端:开发者需要懂数据库,服务器,API等等
  • 职责
    前端:开发者负责设计网站的外观
    后端:开发者负责构建数据库架构,为前端提供支持
  • 独立性
    前端:不能作为单独的服务提供,除非它是一个静态的网站
    后端:可以作为BaaS(后端即服务,Backend as a Service)提供
  • 目标
    前端:开发者的目标是确保所有用户都可以访问网站或App
    后端:开发者的目标是围绕前端开发应用程序,并为前端提供支持,并确保整个网站或App正常运行
  • 编程语言
    前端:HTML,CSS,JavaScript
    后端:PHP,Python,SQL,Java,Ruby,NET,Perl
  • 开发框架
    前端:Angular.JS、React.JS、Backbone.JS、Vue.JS、Sass、Ember.JS、NPM
    后端:Laravel、CakePHP、Epress、Codelgnier、Ruby on Rails、Pylon、ASP.NET
  • 数据库
    前端:本地存储、核心数据、SQLite、Cookie、会话
    后端:MySQL、Casandra、PostgreSQL、MongoDB、Oracle、Sybase、SQL Server
  • 服务器
    后端:Ubuntu、Apache、Nginx、Linux、Windows

二、HTML认知

1、网页的组成

网页由文字,图片,音频,视频,超链接组成
网页背后的本质为前端程序员写的代码,通过浏览器进行译处理,浏览器转化(解析以及渲染)

2、浏览器

1、浏览器的定义
	浏览器:是网页显示以及运行的平台,是前端开发的必备利器
2、五大浏览器:IE、火狐、谷歌、Safari浏览器、Opera浏览器
3、浏览器市场份额为谷歌占由率高,60-70%
4、渲染引擎(了解)
	(1)、渲染引擎(浏览器内核):浏览器中专门对代码进行解析渲染的部分
	(2)、浏览器以及其内核
		浏览器IE,内核Trident,IE、猎豹安全、360极速浏览器、百度浏览器
		浏览器FireFox、内核Gecko、火狐浏览器内核
		浏览器Safari、内核Webkit、苹果浏览器内核
		浏览器Chrome、内核Blink、Blink其实是Webkit的分支
	(3)、渲染引擎不同,导致解析相同代码时的速度、性能、效果也不同

3、Web标准

1、构成以及标准
	(1)、结构
		HTML
			页面元素和内容
	(2)、表现
		CSS
			页面元素的外观和位置等页面样式(如:颜色、大小等)
	(3)、行为
		JavaScript
			页面模型的定义与页面交互
2、要求页面实现
	结构、表现、行为三层分离

三、简单的HTML页面架构

HTML超文本标记语言)模板框架是用于构建网页的标准模板。
全称:Hyper Text Markup Language

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
	</body>
</html>

charset 编码 gbk gbk2312 utf-8

保存内容的快捷方式为 ctrl+s
同时,我这里使用的开发工具HBuilder
开发工具有:
Visual Studio Code、Webstorm、Sublime、Dreamweaver、Hbuilder
新建HTML文件即可加载出模板,或者输入h然后输出8回车。
在这里插入图片描述
网页的整体

  • html标签

网页的头部

  • head标签

网页的身体

  • body标签

网页的标题

  • title标签

对HTML模板的解读:
文档类型声明DOCTYPE):HTML文件始于文档类型声明,它指示浏览器当前页面使用的HTML版本。例如,HTML5版本的声明为:<!DOCTYPE html>。
html 标签: 此标签是HTML文档的根元素,包含整个HTML文件的内容。

  • head 标签:在html标签内,head标签包含关于页面的元信息,如文档标题、字符编码、样式表链接等。对于浏览器显示页面时的非主要内容。
    • meta 标签: 用于定义字符集(<meta charset="UTF-8">),SEO优化关键字(<meta name="keywords" content="your_keywords">),以及描述文本(<meta name="description" content="your_description">)
    • title 标签:定义文档的标题,显示在浏览器标签页上。
    • link 标签:用于引入外部资源,如样式表(<link rel="stylesheet" href="styles.css">)
    • script 标签:用于引入外部的JavaScript文件(<script src="myscripts.js"&gt;&lt;/script>)或直接插入JavaScript代码
  • body 标签:html标签内,body标签是主要内容部分,包含页面上可见的所有元素,如文本、图像、链接、表格等。
    • 结构性标签div、header、nav、section、article、aside、footer等):这些标签用于组织文档内容的结构,方便开发者和浏览器理解网页的布局。
    • 文本标签h1-h6、p、strong、em、ul、li等):这些标签用于格式化文本内容,增强页面的可读性。
    • 超链接a 标签):超链接用于导航到其他页面、文件或电子邮件地址。
    • 表单元素form、input、textarea、button等):这些标签用于创建用户输入表单,收集和发送用户数据。
    • 多媒体元素img、video、audio):这些标签可用于嵌入图像、视频、音频等内容,提升页面的交互性和多媒体体验。
    • 表格元素table、tr、td、th):用于显示数据表格。

为了获得更好的页面样式和布局,通常还需要引入CSS层叠样式表)和JavaScript技术。

四、HTML常见标签

1、HTML标签的构成

  • 标签由<、>、/、英文单词或字母组成,并且把标签中<>包括起来的英文单词或字母称为标签名。
  • 常见标签由两部分组成,我们称之为:双标签,前部分叫开始标签,后部分叫结束标签,两部分之间包裹内容。
  • 少数标签由一部分组成,我们称之为:单标签,自成一体,无法包裹内容。

2、HTML标签的关系

  • 嵌套关系
  • 并列关系

1、meta标签

<meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词。

设置网站关键字
meta name="keywords" content="网络安全,WEB渗透,数据安全,渗透测试,安全培训" />
<link> 标签定义文档与外部资源的关系。
<script> 引入js文件

常见用法:

  • <meta charset="UTF-8"> 指定网页的字符集为UTF-8,确保浏览器正确地显示和解析页面的文本内容。
  • <meta name="viewport" content="width=device-width,initial-scale=1.0"> 用于响应式网页设计,定义页面在不同设备上的视口大小和缩放比例。
  • <meta name="keywords"content="关键词,关键短语,关键列表" />指定网页的关键词,用于搜索引擎优化(SEO)。这些关键词描述了网页内容的主题和关联性,有助于提高网页在搜索引擎结果中的排名。
  • <meta name="description"content="网页描述"/>提供对网页内容的简要描述,这个描述通常在搜索引擎结果中显示,帮助用户了解网页的内容。
  • <meta name="robots"content="noindex,nofollow" /> 用于告诉搜索引擎不要索引和追踪当前页面。
  • <meta name="author"content="作者姓名" />用于指定网页的作者。
  • <meta http-equiv="refresh"content="秒数;URL=重定向地址” />通过设置一个指定的时间间隔,自动将用户重定向到另一个网页。

注释
<!--这是一段注释。注释不会在浏览器中显示。-->
<p>这是一段普通的段落。</p>
实践:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<meta name="viewport"content="width=device-width,initial-scale=1.0">
		<meta name="keywords"content="关键词,关键短语,关键列表"/>
		<meta name="description"content="网页描述"/>
		<meta name="robots"content="noindex,nofollow" />
		<meta name="author"content="作者姓名" />
		<title></title>
	</head>
	<body>
		<p>这个是一个段落</p>
		<!--这是一个注释-->
	</body>
</html>

输出结果:
输出方法
在这里插入图片描述
HBuilder右边有Web浏览器预览界面,进行CTRL+S可直接保存看到输出结果。
输出方法
在这里插入图片描述
这里在代码输出框的上方可进行跳转浏览器界面进行输出查看。
在这里插入图片描述
这里我选择的是edge浏览器进行输出查看结果。
这里显然易见第一行段落进行了显示,而第二行未进行显示。

2、标题标签

由大到小

<h1>h1</h1>
<h2>h2</h2>
<h3>h3</h3>
<h4>h4</h4>
<h5>h5</h5>
<h6>6</h6>
</br> 换行标签
<hr>换行线标签

实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<meta name="viewport"content="width=device-width,initial-scale=1.0">
		<meta name="keywords"content="关键词,关键短语,关键列表"/>
		<meta name="description"content="网页描述"/>
		<meta name="robots"content="noindex,nofollow" />
		<meta name="author"content="作者姓名" />
		<title></title>
	</head>
	<body>
		<p>这个是一个段落</p>
		<!--这是一个注释-->
		<p>这个是标题大小</p>
		<h1>h1</h1>
		<h2>h2</h2>
		<h3>h3</h3>
		<h4>h4</h4>
		<h5>h5</h5>
		<h6>h6</h6>
		
		<p>这里是CSDN论坛<br>梦开始的地方<hr>后浪前驱</p>
	</body>
</html>

输出结果:
在这里插入图片描述

3、文本属性

<strong>加粗</strong>
<b></b>加粗
<i></i>斜体
<u></u> 下划线
<sup></sup>上标
<sub></sub>下标
<del></del> 删除线
<font></font> 规定字体属性
	size 字体的大小
	color 字体颜色
代码样式原样输出
<pre></pre>

实践:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<meta name="viewport"content="width=device-width,initial-scale=1.0">
		<meta name="keywords"content="关键词,关键短语,关键列表"/>
		<meta name="description"content="网页描述"/>
		<meta name="robots"content="noindex,nofollow" />
		<meta name="author"content="作者姓名" />
		<title>技术分享</title>
	</head>
	<body>
		<p>这个是一个段落</p>
		<!--这是一个注释-->
		<p>这个是标题大小</p>
		<h1>h1</h1>
		<h2>h2</h2>
		<h3>h3</h3>
		<h4>h4</h4>
		<h5>h5</h5>
		<h6>h6</h6>
		
		<p>这里是CSDN论坛<br>梦开始的地方<hr>后浪前驱</p>
		<p>
			<strong>加粗</strong><br>
			<b>加粗</b><br>
			<i>斜体</i><br>
			<u>下划线</u><br>
			<sup>上标</sup><br>
			<sub>下标</sub><br>
			<del>删除线</del> <br>
			<font size="5px" color="red">规定字体属性</font> 
		</p>
		<p>
			wwww
		</p>
		<pre>	wwww</pre>
	</body>
</html>

输出结果:
在这里插入图片描述
这里我们可以来看下字体的默认大小:
在这里插入图片描述
以及我们最终将文字的属性,颜色包括字体的大小的设定:
在这里插入图片描述

4、form表单

form表单:规定当提交表单时向何处发送表单数据
method 提交的方法get、post

规定在发送表单数据之前如何对其进行编码。
enctype 属性可能的值:
application/x-www-form-urlencoded
multipart/form-data
text/plain

input的标签
name:同样是表示的该文本输入框名称
size:输入框的长度大小
maxlength:输入框中允许输入字符的最大数
value:输入框中的默认值
readonly:表示该框中只能显示,不能添加修改。

input的类型
1、文本输入框(Text Input):

  • 类型(type):text
  • 示例代码:input type="text" name="username">

2、密码输入框(Password Input

  • 类型(type):password
  • 示例代码:<input type="password" name="password" />

3、文件上传(File Upload):

  • 类型:file
  • 示例代码:<input type="file" name="file" />

3、隐藏域:

  • 示例代码:<input type="hidden" value="1"/>

button 按钮
1、复选框(checkbox

  • 类型:checkbox
  • 示例代码:<input type="submit" vale="提交"/>

2、单选框(radio

  • 类型:radio
  • 示例代码:
    男<input type="radio" value="1" name="sex">
    女<input type="radio" name="sex" value="2">

3、提交按钮(Submit Button

  • 类型:submit
  • 示例代码:<input type="submit" vale="提交"/>

实际应用:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>求职界面</title>
	</head>
	<body>
		<p>求职界面</p>
		<form action="" method="post" >
			<label>用户名:</label><input type="text" name="username" size="30" maxlength="4" value="admin" readonly/></br>
			<label>&nbsp;码:</label><input type="password" name="password" /></br>
			<label for="email">&nbsp;箱:</label><input type="text" name="email" id="email" /></br>
			<label>&nbsp;能:</label>安全开发<input type="checkbox"><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;渗透测试<input type="checkbox"></br>
			<label>&nbsp;别:</label><input type="radio" value="1" name="sex"><input type="radio" name="sex" value="2"></br>
			<input type="hidden" value="1"/>
			<input type="submit" vale="提交"/>
			<input type="reset" value="重置" />
			<input type="button" value="button" />
		</form>
		
		<hr>
		
		<form method="post" enctype="multipart/form-data">
			<input type="file" name="file" />
			<input type="submit" />
		</form>
	</body>
</html>

输出结果:
在这里插入图片描述
在这里插入图片描述

5、a 标签

a标签的作用: 就是用于控制界面与页面之间的跳转

默认就是self
self:用于在当前选项卡中跳转,也就是不新建页面跳转
_blank :用于在新的选项卡中跳转,也就是新建页面跳转

<a href="http://www.baidu.com" target="self">百度</a>
<a href="http://www.baidu.com" target="_blank">百度</a>

_blank 在新窗口中打开被链接文档。
_self 默认。在相同的框架中打开被链接文档。
_parent父框架集中打开被链接文档。
_top整个窗口中打开被链接文档。

实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<a href="http://www.baidu.com">百度</a>
		<a href="http://www.baidu.com"target="_self">百度</a>
		<a href="http://www.baidu.com"target="_blank">百度</a>
	</body>
</html>

输出结果:
在这里插入图片描述

好的,我们下面来看这三个a标签:
首先点击第一个:
在这里插入图片描述
点击第二个:
在这里插入图片描述
点击第三个:
在这里插入图片描述
我们可以看到只有第三个标签进行了创建新的标签页进行访问,而第一个以及第二个标签只进行了全标签页的跳转。

6、锚文本

锚文本(Anchor Text)是指在超链接(HTML中使用<a>标签创建的链接)中显示的可点击文本或词语。
它通常是以蓝色(或其他指定的链接色)并带有下划线的形式展现,用于吸引用户点击以跳转到目标网页或位置。

<a href="#2">锚点</a>
<a name="2">锚点</a>

锚文本的使用:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<p name="top">xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<a href="http://www.baidu.com">百度</a>
		<a href="http://www.baidu.com"target="_self">百度</a>
		<a href="http://www.baidu.com"target="_blank">百度</a>
		<a href="#top">返回顶部</a></br>
	</body>
</html>

输出结果:
这里我们首先滑到底部:
在这里插入图片描述
然后点击返回顶部:
在这里插入图片描述
即可完成跳转。

7、img 标签

<img> 标签是HTML中用于插入图像的标签。它是一个自闭合标签,不需要闭合标签。
<img> 标签使用一个必需的属性 src 来指定图像的来源(即图像的URL)。除此之外,还可以使用其他属性来控制图像的显示和行为。
img 元素向网页中嵌入一幅图像。
<img src="/i/eg_tulip.jpg" alt="上海鲜花港 - 郁金香" />
alt 规定图像的替代文本。
src 规定显示图像的url
width 规定图片的高度
height 规定图片的宽度
title:为图像添加标题,当用户将鼠标悬停在图像上时显示。
classid:用于应用 CSS 样式或 JavaScript 操作图像。
img标签的使用:
1、首先我们将需要显示的图片保存在项目的img文件里面:
在这里插入图片描述
2、实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<img src="img/web1.jpg"">
	</body>
</html>

3、输出结果:
在这里插入图片描述
4、同时,我们也可以进行设置图片显示的大小:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<img src="img/web1.jpg"width="1000" height="500">
	</body>
</html>

5、输出结果:
在这里插入图片描述
6、这里我们尝试去掉图片地址看会显示什么
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<img src=""width="1000" height="500">
	</body>
</html>

7、输出结果:
在这里插入图片描述
8、在未能正常显示的画面上加上阐述:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<img src=""width="1000" height="500"alt="web1">
	</body>
</html>

9、输出结果:
在这里插入图片描述
a标签,img标签以及锚文本的配置使用:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<p name="top">xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<p>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx</p>
		<a href="http://www.baidu.com">百度</a>
		<a href="http://www.baidu.com" target="_self">百度</a>
		<a href="http://www.baidu.com" target="_blank">百度</a>
		<a href="#top">返回顶部</a></br>
	</hr>
	<img src="img/web1.jpg" width="100" height="100" alt="logo">
	</body>
</html>

输出结果:
在这里插入图片描述

8、table 表格

<caption>我的标题</caption>表格带标题
border 边框
width 宽度
height 高度
colspan
rowspan

<th></th>
<tr></tr>
<td>表格</td>

cellpadding 单元边与内容的空白
cellspacing 单元格的空白
案例区分:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<table border="1" cellpadding='10' cellspacing='10' >
			<caption>姓名 图</caption>
			<tr><th>\</th><th>姓名</th><th>年龄</th></tr>
			<tr><td>1</td><td>张三</td><td>18</td></tr>
			<tr><td>2</td><td>李四</td><td>19</td></tr>
		</table>
		<hr />
		<br />
		<table border="1" cellpadding='10'>
			<caption>姓名 图</caption>
			<tr><th>\</th><th>姓名</th><th>年龄</th></tr>
			<tr><td>1</td><td>张三</td><td rowspan='2'>18</td></tr>
			<tr><td>2</td><td>王五</td></tr>
			<tr><td>3</td><td>李四</td><td>19</td></tr>
			<tr><td>4</td><td>赵六</td><td rowspan='2'>20</td></tr>
			<tr><td>5</td><td>魏七</td></tr>
			<tr><td>总数</td><td colspan="2">5</td></tr>
		</table>
	</body>
</html>

输出结果:
在这里插入图片描述
这里可以明显的区分出以上的代码功能。

9、列表标签

<ul>
	<li></li>
	<li></li>
	<li></li>
	<li></li>
</ul>

9.1、无序列表

项目符号 square circle disc

<ul>
	<li></li>
	<li></li>
	<li></li>
	<li></li>
</ul>

9.2、有序列表

数字列表 默认 数字

小写字母列表
大写字母列表 A
罗马字母列表 I
小写罗马字母列表 i

<ol type="1"> <!--有序列表-->
			<li>暗月实战项目九 不出网的情况下的内网多域控渗透</li>
			<li>xp/2003开关3389指令</li>
			<li>一条命令修改windows注册表</li>
</ol>

列表的使用案例:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>ZY技术分享</title>
	</head>
	<body>
		<ul type="disc"> <!--无序列表-->
            <p>RIP的数据包</p>           
			<li>request——请求数据包</li>
			<li>response——响应数据包</li>
		</ul>
		<hr />
		<ol type="1"> <!--有序列表-->
			<p>OSPF的数据包</p>
			<li>Hello包</li>
			<li>DBD包</li>
			<li>LSA包</li>
			<li>LSR包</li>
			<li>LSU包</li>
		</ol>
	</body>
</html>

输出结果:
在这里插入图片描述

10、框架的使用

frameset 元素可定义一个框架集。它被用来组织多个窗口(框架)。每个框架存有独立的文档。在其最简单的应用中,frameset 元素仅仅会规定在框架集中存在多少列或多少行。您必须使用 colsrows 属性。

frameset 在一个页面中设置一个或多个框架,不能嵌套在body标签里
iframe 是在html页面内嵌入框架,框架内可以连接另一个页面

frameset 不能body内使用
frame 一般都是frameset中使用
cols 定义框架集中的数目和尺寸
rows 定义框架集中的数目和尺寸

scrolling 滚动条
auto 在需要的情况下出现滚动条(默认值)。
yes 始终显示滚动条(即使不需要)。
no 从不显示滚动条(即使需要

案例,制作如下格式框架:
在这里插入图片描述
1、首先我们先创建一个新的项目。
2、创建top,main,left三个html并输入名称:
top.html
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		top
	</body>
</html>

main.html
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		main
	</body>
</html>

left.html
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		left
	</body>
</html>

3、对文件index.html进行配置,并赋入框架:
实现代码·:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
	</head>
	<frameset rows="20%,*">
		<frame src="top.html" />
		<frameset cols="20%,*">
			<frame src="left.html" />
			<frame src="main.html" />
		</frameset>
	</frameset>
	<body>
	</body>
</html>

输出结果:
在这里插入图片描述
4、对left.html进行修改并配置无序列表:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<ul>
			<li><a href="#">添加文章</a></li>
			<li><a href="#">文章列表</a></li>
			<li><a href="#">系统信息</a></li>
			<li><a href="#">备份</a></li>
		</ul>
	</body>
</html>

输出结果:
在这里插入图片描述
以及此时index.html的输出结果:
在这里插入图片描述
5、给left.html里面功能添加文章配置功能代码,此时,重新创建add.html并配置:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<form method="post">
			标题:<input type="text" /><br>
			内容:<textarea cols="40" rows="20"></textarea>
			<input type="submit" />
		</form>
	</body>
</html>

输出结果:
在这里插入图片描述
6、在left.html上进行配置连接:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<ul>
			<li><a href="add.html" target="add">添加文章</a></li>
			<li><a href="#">文章列表</a></li>
			<li><a href="#">系统信息</a></li>
			<li><a href="#">备份</a></li>
		</ul>
	</body>
</html>

7、将add.html界面放于main.html框架界面上:index.html进行配置:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>ZY技术分享</title>
	</head>
	<frameset rows="20%,*">
		<frame src="top.html" />
		<frameset cols="20%,*">
			<frame src="left.html" />
			<frame src="main.html" name="add"/>
		</frameset>
	</frameset>
	<body>
	</body>
</html>

输出结果:
点击主页的添加文章即可在main框架中弹出界面:
在这里插入图片描述
8、给left.html中文章列表创建界面,这里首先创建一个artlist.html文件并配置:
实现代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<ol>
			<li><a href="#">第一天</a></li>
			<li><a href="#">第二天</a></li>
			<li><a href="#">第三天</a></li>
			<li><a href="#">第四天</a></li>
		</ol>
	</body>
</html>

输出结果:
在这里插入图片描述
然后我们利用index.html进行打开left框架的文章列表:
在这里插入图片描述
9、这里界面就补充这么多,剩下的原理都一样。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/30934.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java性能权威指南-总结14

Java性能权威指南-总结14 堆内存最佳实践对象生命周期管理对象重用 堆内存最佳实践 对象生命周期管理 在很大程度上&#xff0c;Java会尽量减轻开发者投入到对象生命周期管理上的精力&#xff1a;开发者在需要的时候创建对象&#xff0c;当不再需要这些对象时&#xff0c;它们…

Java 被挤出前三。。

TIOBE 2023 年 06 月份的编程语言排行榜已经公布&#xff0c;官方的标题是&#xff1a;Python 还会保持第一吗&#xff1f;&#xff08;Will Python remain number 1?&#xff09; 在过去的 5 年里&#xff0c;Python 已经 3 次获得 TIOBE 指数年度大奖&#xff0c;这得益于…

浅谈C++|引用篇

目录 引入 一.引用的基本使用 (1)引用的概念&#xff1a; (2)引用的表示方法 (3)引用注意事项 (4)引用权限 二.引用的本质 三.引用与函数 (1)引用做函数参数 (2)引用做函数返回值 四.常量引用 五.引用与指针 引入 绰号&#xff0c;又称外号&#xff0c;是人的本名以外…

【k8s系列】一分钟搭建MicroK8s Dashboard

本文基于上一篇文章的内容进行Dashboard搭建&#xff0c;如果没有看过上一篇的同学请先查阅上一篇文章 k8s系列】使用MicroK8s 5分钟搭建k8s集群含踩坑经验 使用MicroK8s搭建Dashboard很简单&#xff0c;只需要在Master节点按照以下几步操作 1.启用Dashboard插件 microk8s en…

【软件工程】软件工程期末考试复习题

软件工程期末考试试题及参考答案 一、单向选择题 1、软件的发展经历了&#xff08;D&#xff09;个发展阶段。 一二三四 2、需求分析的任务不包括&#xff08;B&#xff09;。 问题分析系统设计需求描述需求评审。 3、一个软件的宽度是指其控制的&#xff08;C&#xff0…

[进阶]TCP通信综合案例:群聊

代码演示如下&#xff1a; 客户端&#xff1a; public class Client {public static void main(String[] args) throws Exception{System.out.println("客户端开启&#xff01;");//1.创建Socket对象&#xff0c;并同时请求与服务端程序的连接。Socket socket new…

新人拿到一个web项目如何使用idea发布运行

本文描述的是一个新手&#xff0c;拿到一个web项目&#xff0c;使用idea如何发布运行。项目中没有非常复杂的元素&#xff0c;只是试着描述应该如何配置相关内容。 内容描述前提&#xff0c;首先请您确认tomcat已经安装&#xff0c;其次确认jdk已经安装&#xff0c;并明确他们在…

STM32速成笔记—GPIO

文章目录 一、什么是GPIO二、GPIO的输入/输出模式三、GPIO初始化配置四、Boot引脚五、一些特殊的GPIO六、点亮LED1. 硬件电路2. 拉高/拉低GPIO3. 程序设计 七、GPIO的位带操作 一、什么是GPIO GPIO(英语:General-purpose input/output)&#xff0c;通用型之输入输出的简称&…

Java与SpringBoot对redis的使用方式

目录 1.Java连接redis 1.1 使用Jedis1.2 使用连接池连接redis1.3 java连接redis集群模式 2.SpringBoot整合redis 2.1 StringRedisTemplate2.2 RedisTemplate 1.Java连接redis redis支持哪些语言可以操作 &#xff08;去redis官网查询&#xff09; 1.1 使用Jedis (1)添加jedis…

【数字图像处理】2.几何变换

目录 什么是几何变换&#xff1f; 为什么要对图像进行几何变换&#xff1f; 2.1 仿射变换&#xff08;二维&#xff09; 2.2 投影变换&#xff08;三维&#xff09; 2.3 极坐标变换 2.3.1 将笛卡尔坐标转化为极坐标 2.3.2 将极坐标转换为笛卡尔坐标 2.3.3 利用极坐标变…

汇编学习教程:寻址大总结

前言 在上篇博文中&#xff0c;我们主要学习了一个全新的寄存器&#xff1a;bp。bp 寄存器在功能和使用上与 bx 有着异曲同工之妙&#xff0c;只不过两人绑定的服务对象不同&#xff1a;bx 默认绑定的是 DS 段寄存器&#xff0c;而 bp 默认绑定的是 SS 段寄存器。bx 和 bp 有着…

Unity之透明度混合与ps的透明度混合计算结果不一致

一、问题 前段时间学习shader时发现了一个问题&#xff0c;一张纯红色透明度为128的图片叠加在一张纯绿色的图片上得出的结果与ps中的结果不一致。网上查找了ps中的透明混合的公式为 color A.rgb*A.alpha B.rgb*(1-A.alpha)。自己使用代码在unity中计算了一下结果总是不对。…

【Java基础学习打卡09】JRE与JDK

目录 前言一、JRE二、JDK三、JDK、JRE和JVM关系总结 前言 本文将介绍JRE、JDK是什么&#xff0c;以及JDK、JRE和JVM关系三者之间的关系。 一、JRE JRE全称为Java Runtime Environment&#xff0c;是Java应用程序的运行时环境。JRE包括Java虚拟机&#xff08;JVM&#xff09;、…

车辆救援道路救援预约汽修托运小程序

道路救援&#xff1a;指汽车道路紧急救援&#xff0c;为故障车主提供包括诸如&#xff1a;拖吊、换水、充电、换胎、送油以及现场小修等服务(Road-Side Service)&#xff1b; 同时也指交通事故道路救援&#xff0c;包括伤员救治、道路疏导等。 随着我国巨大的汽车拥有量&…

基础篇:新手使用vs code新建go项目(从0开始到运行)

学习新语言&#xff0c;搭建新环境。在网上找了一些教程&#xff0c;感觉还是写一个比较详细的方便以后自己使用。其实vs code没有新建项目这个功能&#xff0c;具体怎么运行go语言的项目请看下文。 一、下载GO安装包 1.点击go安装包下载链接下载相应的版本&#xff08;本次下…

了解 Dockerfile 和搭建 Docker 私有仓库:让容器化部署变得更简单

目录 1、Dockerfile 1.1什么是Dockerfile 1.2常用命令 1.3使用脚本创建镜像 2、Docker私有仓库 2.1私有仓库介绍&#xff1a; 2.2私有仓库搭建与配置 2.3上传镜像到私有仓库&#xff1a; 1、Dockerfile 1.1什么是Dockerfile Dockerfile是由一些列命令和参数构成的脚本…

《网络安全0-100》安全事件案例

网络安全事件案例分析 2017年Equifax数据泄露事件 Equifax是美国一家信用评级机构&#xff0c;2017年9月&#xff0c;该公司披露发生了一起重大的数据泄露事件&#xff0c;涉及1.43亿美国人的个人信息&#xff0c;包括姓名、出生日期、社会安全号码等敏感信息。经过调查&#…

【数据分析】如何使用docker部署程序并移植(算法、接口)

原文作者&#xff1a;我辈李想 版权声明&#xff1a;文章原创&#xff0c;转载时请务必加上原文超链接、作者信息和本声明。 文章目录 前言一、Docker的基本使用1.安装Docker2.列出本地镜像3.获取镜像,创建本地ubuntu:13.10镜像4.查找镜像5.删除本地镜像6.创建自定义镜像7.镜像…

第一章 基础算法(二)——高精度,前缀和与差分

文章目录 高精度运算高精度加法高精度减法高精度乘法高精度除法 前缀和二维前缀和 差分二维差分 高精度练习题791. 高精度加法792. 高精度减法793. 高精度乘法794. 高精度除法 前缀和练习题795. 前缀和796. 子矩阵的和 差分练习题797. 差分798. 差分矩阵 高精度运算 两个大数做…

【Unity Shader】从入门到感慨(2)用C#画一个立方体

文章目录 一、构成一个立方需要多少个顶点?二、定义三角面的索引数组:三、定义UV坐标数组:四、最后构建Mesh:五、完整代码:一、构成一个立方需要多少个顶点? 这个问题是面试经常被问到的题。如上图,我们知道在几何中立方体有6个面,8个顶点。但在图形学中,顶点指的是模…