前端开发

一、前端简介

1.前端与后端

前端:与用户直接打交道的操作界面

后端:不直接与用户打交道的内部真正执行核心业务逻辑的代码程序

2.前端核心基础

  • HTML:网页的骨架
  • CSS:网页的样式
  • JS:网页的动态

二、HTML超文本传输协议

1.前戏

  1. 手写一个服务端程序
  2. 使用浏览器充当服务器
  3. 浏览器端无法直接展示服务端的响应数据
  4. 由于浏览器需要兼容很多服务端软件,为了实现无障碍沟通交流有了一些协议
    • HTTP协议、HTTPS协议、FTP协议
  5. 浏览器发送的请求数据格式肯定没有问题因为是别人封装好的,问题出在我们自己写的服务端的响应数据格式

2.四大特性

  1. 基于请求响应
  2. 基于TCP / IP之上作用应用层的协议
  3. 无状态
  4. 无连接/短连接

3.请求数据格式

  1. 请求首行
    • 请求方式:有很多种,协议名称及版本
  2. 请求头
    • 一堆k:v键值对
  3. 换行
  4. 响应体
    • 一般情况下就是浏览器想要展示给用户看的数据

4.响应状态码

利用数字来表示一些复杂的情况说明(类似于暗号)

  • 1XX:服务端已经接收到请求正在处理,可以继续提交或等待
  • 2XX:200 OK 服务端给出了相应响应
  • 3XX:重定向
  • 4XX:403请求不符合条件,404请求资源不存在
  • 5XX:服务端内部错误

注意:在公司还会自定义更多的状态码,一般情况下从10000开始

三、HTML简介

1.概念

HTML:超文本标记语言,是所有浏览器展示的页面必备的

浏览器展示页面:也称之为HTML页面

  • 存储HTML语言文件的后缀一般是.html
  • HTML没有任何逻辑,所见即所得

2.HTML注释语法

<!--注释内容-->

3.HTML文件结构

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body></body>
</html>
  1. < !DOCTYPE html >:声明为HTML5文档
  2. < html >< /html>:是文档的开始标记和结束的标记。是HTML页面的根元素,在它们之间是文档的头部(head)和主体(body),所有代码都必须写在html标签内部
  3. < head >< /head >:定义了HTML文档的开头部分。它们之间的内容不会在浏览器的文档窗口显示(一般都不是给用户看的)。包含了文档的元(meta)数据。
  4. < title >< /title >:定义了网页标题,在浏览器标题栏显示
  5. < body >< /body >:之间的文本是可见的网页主体内容(展示给用户看的)

四、HTML常用标签

1.标签简介

1.1.标签语法

  • <标签名 属性1=“属性值1” 属性2=“属性值2”……>内容部分</标签名>
  • <标签名 属性1=“属性值1” 属性2=“属性值2”…… />

1.2.标签属性

属性 描述
id 类似于身份证号,在同一个html页面上,id值不能重复
class 类似于分组,多个标签可以拥有相同的class值
style 规定元素的CSS样式

2.标签分类

标签 描述 常见标签
单标签 只有一个标签 < hr />、< br />、< meta />、< img />、< link />、< input />…
多标签 有开始和结束标签 < html>< /html>、< head>< /head>、< title>< /title>、< body>< /body>、< h1~h6>< /h1~h6>、< p>< /p>、< div>< /div>…

HTML标签关系可以是嵌套关系,也可以是并列关系

3.head内常见标签

标签 描述
title 定义网页标题
style 定义内部样式表(CSS)
link 引入外部CSS文件
script 内部支持编写JS代码,还可以通过src属性引入外部JS文件
meta 通过内部属性的不同可以有很多功能

meta标签

1.meta标签介绍
  • meta标签可提供有关页面的元信息,针对搜索引擎和更新频度的描述和关键词
  • meta标签位于文档的头部,不包含任何内容
  • meta标签提供的信息是用户不可见的
2.meta标签组成

meta标签共有两个属性,它们分别是http-equiv属性和name 属性,不同的属性又有不同的参数值,这些不同的参数值就实现了不同的网页功能

  1. http-equiv属性:相当于http的文件头作用,它可以向浏览器传回一些有用的信息,以帮助正确地显示网页内容,与之对应的属性值为content,content中的内容其实就是各个参数的变量值

    <!--指定文档的编码类型(需要知道)-->
    <meta http-equiv="content-Type" charset=UTF8">  
    
    <!--2秒后跳转到对应的网址,注意引号(了解)-->
    <meta http-equiv="refresh" content="2;URL=https://www.oldboyedu.com">
    
    <!--告诉IE以最高级模式渲染文档(了解)-->
    <meta http-equiv="x-ua-compatible" content="IE=edge">
    
  2. name属性: 主要用于描述网页,与之对应的属性值为content,content中的内容主要是便于搜索引擎机器人查找信息和分类信息用的

    <meta name="keywords" content="填写一些关键字 提升网页被搜索的概率">
    <meta name="description" content="填写一些网页的简介">
    

4.body内基本标签

标签 属性
h1~h6 标题标签
p 段落标签
hr 水平分割线
br 换行
u 下划线
i 斜体
s 删除线
b 加粗

注意:有很多样式,可能存在多种标签可以实现

5.块级标签和行内标签

标签 描述
块级标签 一个标签独占一行 h1~h6、p、hr、br…
行内标签 内部文本多大自身就多大 u、i、s、b…

注意:

  1. 块级标签是可以通过CSS调整为不独占一行

  2. 标签之间很多时候可以嵌套

    • 块级可以嵌套任何类型的标签
    • 行内标签只能嵌套行内标签
    • p标签是块级标签,但是p标签不能包含块级标签,p标签也不能包含p标签

6.body内基本符号

内容 对应代码
空格 & nbsp;
> & gt;
< & lt;
& & amp;
& yen;
版权© & copy;
注册® & reg;

7.body内布局标签

布局标签 描述
div标签 用来定义一个块级标签,并无实际的意义。主要通过CSS样式为其赋予不同的表现
span标签 用来定义内联(行内)标签,并无实际的意义。主要通过CSS样式为其赋予不同的表现

8.body内常见标签

8.1.a标签

a标签:链接标签。所谓的超链接是指从一个网页指向一个目标的连接关系,这个目标可以是另一个网页,也可以是相同网页上的不同位置,还可以是一个图片,一个电子邮件地址,一个文件,甚至是一个应用程序

<a href="http://www.oldboyedu.com" target="_blank" >点我</a>
  1. href属性:指定目标网页地址
    • 绝对URL - 指向另一个站点(比如 href="http://www.jd.com
    • 相对URL - 指当前站点中确切的路径(href="index.htm")
    • 锚URL - 指向页面中的锚(href="#top")
  2. target属性:控制是否新建页面跳转
    • _blank表示在新标签页中打开目标网页
    • _self表示在当前标签页中打开目标网页

8.2.img标签

img标签:图片标签

<img src="图片的路径" alt="图片未加载成功时的提示" title="鼠标悬浮时提示信息" width="宽" height="高(宽高两个属性只用一个会自动等比缩放)">
  • src:图片的路径
  • alt:图片未加载成功时的提示
  • title:鼠标悬浮时提示信息
  • width:宽(宽高两个属性只用一个会自动等比缩放)
  • height:高(宽高两个属性只用一个会自动等比缩放)

9.列表标签

9.1.无序列表

<ul type="disc">
  <li>第一项</li>
  <li>第二项</li>
</ul>

type属性:

  • disc:实心圆点,默认值
  • circle:空心圆圈
  • square:实心方块
  • none:无样式

9.2.有序列表

<ol type="1" start="2">
  <li>第一项</li>
  <li>第二项</li>
</ol>

type属性:

  • 1:数字列表,默认值
  • A:大写字母
  • a:小写字母
  • Ⅰ:大写罗马
  • ⅰ:小写罗马

9.3.标题列表

<dl>
  <dt>标题1</dt>
  <dd>内容1</dd>
  <dt>标题2</dt>
  <dd>内容1</dd>
  <dd>内容2</dd>
</dl>

10.表格标签

表格是一个二维数据空间,一个表格由若干行组成,一个行又有若干单元格组成,单元格里可以包含文字、列表、图案、表单、数字符号、预置文本和其它的表格等内容。表格最重要的目的是显示表格类数据。表格类数据是指最适合组织为表格格式(即按行和列组织)的数据

表格基本结构

<table>
    <thead>
        <tr>
            <th>序号</th>
            <th>姓名</th>
            <th>爱好</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>1</td>
            <td>jason</td>
            <td>杠娘</td>
        </tr>
        <tr>
            <td>2</td>
            <td>Yuan</td>
            <td>日天</td>
        </tr>
    </tbody>
</table>

属性:

  • border: 表格边框.
  • cellpadding: 内边距
  • cellspacing: 外边距.
  • width: 像素 百分比.(最好通过css来设置长宽)
  • rowspan: 单元格竖跨多少行
  • colspan: 单元格横跨多少列(即合并单元格)

11.表单标签

能够获取用户输入(输入、选择、上传)的数据并发送给后端服务器

<form action="" method=""></form>
  • action属性:用于控制数据的提交地址 不写的话就是朝当前页面所在的地址提交
  • method属性:用于控制请求的方式(get\post)

11.1.表单功能

  • 表单用于向服务器传输数据,从而实现用户与Web服务器的交互

  • 表单能够包含input系列标签,比如文本字段、复选框、单选框、提交按钮等等。

  • 表单还可以包含textarea、select、fieldset和 label标签

11.2.表单属性

属性 描述
accept-charset 规定在被提交表单中使用的字符集(默认:页面字符集)
action 规定向何处提交表单的地址(URL)(提交页面)
autoconplete 规定浏览器应该自动完成表单(默认:开启)
enctype 规定被提交数据的编码(默认:url-encoded)
method 规定在提交表单时所用的 HTTP 方法(默认:GET)
name 规定识别表单的名称(对于 DOM 使用:document.forms.name)
novalidate 规定浏览器不验证表单
target 规定 action 属性中地址的目标(默认:_self)

11.3.input

input元素会根据不同的 type 属性,变化为多种形态

type属性 表现形式 对应代码
text 单行输入文本 < input type="text" />
password 密码输入框 < input type="password" />
date 日期输入框 < input type="date" />
checkbox 复选框(多选框) < input type="checkbox" checked="checked" />
radio 单选框 < input type="radio" />
submit 提交按钮 < input type="submit" value="提交" />
reset 重置按钮 < input type="reset" value="重置" />
button 普通按钮 < input type="button" value="普通按钮" />
hidden 隐藏输入框 < input type="hidden" />
file 文件选择框 < input type="file" />

属性说明:

  • name:表单提交时的“键”,注意和id的区别
  • value:表单提交时对应项的值
    • type="button", "reset", "submit"时,为按钮上显示的文本年内容
    • type="text","password","hidden"时,为输入框的初始值
    • type="checkbox", "radio", "file",为输入相关联的值
  • checked:radio和checkbox默认被选中的项
  • readonly:text和password设置只读
  • disabled:所有input均适用

11.4.select标签

<form action="" method="post">
  <select name="city" id="city">
    <option value="1">北京</option>
    <option selected="selected" value="2">上海</option>
    <option value="3">广州</option>
    <option value="4">深圳</option>
  </select>
</form>

属性说明:

  • multiple:布尔属性,设置后为多选,否则默认单选
  • disabled:禁用
  • selected:默认选中该项
  • value:定义提交时的选项值

11.5.label标签

定义:label标签为 input 元素定义标注(标记)
说明:

  1. label 元素不会向用户呈现任何特殊效果
  2. label标签的 for 属性值应当与相关元素的 id 属性值相同
<form action="">
    <label for="username">用户名</label>
    <input type="text" id="username" name="username">
</form>

11.6.textarea多行文本

<textarea name="memo" id="memo" cols="30" rows="10">
    默认内容
</textarea>

属性说明:

  • name:名称
  • rows:行数
  • cols:列数
  • disabled:禁用
 posted on 2022-08-22 19:07  念白SAMA  阅读(103)  评论(0编辑  收藏  举报