1、视图–标尺:可测量像素尺寸感叹号
2、吸管工具可吸取颜色值
3、左侧移动工具–点击侧边标尺,按住不放拖至图片边缘-----方便测量
ul>li*4{$}
得到如下
- 1
- 2
- 3
- 4
ctrl+g 输入1 定位到第一行代码 输入末尾数字到最后一行
ctrl+F 搜索代码关键词
< 表示小于号
> 表示大于号
空格
“工欲善其事,必先利其器”
Chrome浏览器不仅可以调试页面、JS、请求、资源、cookie,还可以模拟手机进行调试。我们现在只是使用html和css,我们先讲一下现在常用的调试。
可以鼠标点击后面的数值, 按下键盘 上箭头 是 调大 数值, 下箭头是 调小数值
用下图所示的黑色箭头,点击我们需要的 html 元素。
声明类名和html调用名不一致 或者 css文件引入不对 或者 这个样式的前面 多余了一些符号影响的
左侧 展开可以看到html 标签是否匹配
1、当页面中图片太多的时候不要对图片进行操作,尽量将图片放进一个个盒子div,对盒子进行操作
基础班学习目标
目标: 能根据psd文件,用HTML+CSS 布局出符合W3C规范的网页。
网站首页
列表页、详情页、登录页、 注册页等等。。。。
能够写出基本的html页面(里面包含图片、链接、文字等网页元素标签)
网页主要由文字、图像和超链接等元素构成。当然,除了这些元素,网页中还可以包含音频、视频以及Flash等。
思考:
网页是如何形成的呢?
网页有图片、链接、文字等元素组成,我们后面的任务就是要把这部分网页元素用代码写出来。。。
浏览器是网页显示、运行的平台,常用的浏览器有IE、火狐(Firefox)、谷歌(Chrome)、Safari和Opera等。我们平时称为五大浏览器。
可能你最熟悉的是 IE浏览器,但是。。。
查看网站: http://tongji.baidu.com/data/browser
2008年,大名鼎鼎的互联网巨头Google公司发布了它的首款浏览器Chrome浏览器。
跟王思聪一样,没办法,生下来人家就是富二代官二代啊,后台太强,而且确实先天能力得天独厚。
pink老师 一句话说出他们:
出自谷歌,唯我不败;一统江湖,千秋万代。
首先解释一下浏览器内核是什么东西。英文叫做:Rendering Engine,中文翻译很多,排版引擎、解释引擎、渲染引擎,现在流行称为浏览器内核.
负责读取网页内容,整理讯息,计算网页的显示方式并显示页面.
因为浏览器太多啦, 但是现在主要流行的就是下面几个:
浏览器 | 内核 | 备注 |
---|---|---|
IE | Trident | IE、猎豹安全、360极速浏览器、百度浏览器 |
firefox | Gecko | 可惜这几年已经没落了,打开速度慢、升级频繁、猪一样的队友flash、神一样的对手chrome。 |
Safari | webkit | 现在很多人错误地把 webkit 叫做 chrome内核(即使 chrome内核已经是 blink 了)。苹果感觉像被别人抢了媳妇,都哭晕再厕所里面了。 |
chrome | Chromium/Blink | 在 Chromium 项目中研发 Blink 渲染引擎(即浏览器核心),内置于 Chrome 浏览器之中。Blink 其实是 WebKit 的分支。大部分国产浏览器最新版都采用Blink内核。二次开发 |
Opera | blink | 现在跟随chrome用blink内核。 |
拓展阅读:
移动端的浏览器内核主要说的是系统内置浏览器的内核。
Android手机而言,使用率最高的就是Webkit内核,大部分国产浏览器宣称的自己的内核,基本上也是属于webkit二次开发。
iOS以及WP7平台上,由于系统原因,系统大部分自带浏览器内核,一般是Safari或者IE内核Trident的
目标
Web标准不是某一个标准,而是由W3C组织和其他标准化组织制定的一系列标准的集合。
W3C 万维网联盟是国际最著名的标准化组织。1994年成立后,至今已发布近百项相关万维网的标准,对万维网发展做出了杰出的贡献。
w3c就类似于现实世界中的联合国。
通过以上浏览器不同内核不同,我们知道他们显示页面或者排版就有些许差异。
遵循web标准可以让不同我们写的页面更标准更统一外,还有许多优点
1、让Web的发展前景更广阔
2、内容能被更广泛的设备访问
3、更容易被搜寻引擎搜索
4、降低网站流量费用
5、使网站更易于维护
6、提高页面浏览速度
构成: 主要包括结构(Structure)、表现(Presentation)和行为(Behavior)三个方面。
标准 | 说明 | 备注 |
---|---|---|
结构 | 结构用于对网页元素进行整理和分类,咱们主要学的是HTML。 | |
表现 | 表现用于设置网页元素的版式、颜色、大小等外观样式,主要指的是CSS | |
行为 | 行为是指网页模型的定义及交互的编写,咱们主要学的是 Javascript |
理想状态我们的源码: .HTML .css .js
结合人来记忆web标准:
结构标准: 是你天然的身体
表现标准: 决定你是否打扮的美丽外观(衣服?化妆?)
行为标准: 决定你是否有吸引人的行为(动作)
介绍一下你对浏览器内核的理解?常见的浏览器内核有哪些?
浏览器内核包括两部分,渲染引擎和js引擎。渲染引擎负责读取网页内容,整理讯息,计算网页的显示方式并显示页面,js引擎是解析执行js获取网页的动态效果。 后来 JS 引擎越来越独立,内核就倾向于只指渲染引擎。
IE:Trident
firefox:Gecko
chrom、safari:webkit
Opera:Presto
Microsoft Edge:EdgeHTML
深度阅读:五大主流浏览器内核的源起以及国内各大浏览器内核总结
pink老师 一句话说出html作用:
网页是由网页元素组成的 , 这些元素是利用html标签描述出来,然后通过浏览器解析,就可以显示给用户了。
所谓超文本,有2层含义:
<img src="timg.jpg" />
门外汉眼中的效果页面
我们要做的html页面
html 总结:
日常生活的书信,我们要遵循共同的约定。
同理:HTML 有自己的语言语法骨架格式:(要遵循,要专业) 要求务必非常流畅的默写下来。。
<html>
<head>
<title>title>
head>
<body>
body>
html>
标签名 | 定义 | 说明 |
---|---|---|
HTML标签 | 页面中最大的标签,我们成为 根标签 | |
文档的头部 | 注意在head标签中我们必须要设置的标签是title | |
文档的标题 | 让页面拥有一个属于自己的网页标题 | |
文档的主体 | 元素包含文档的所有内容,页面内容 基本都是放到body里面的 |
**课堂练习1: **
书写我们的第一个HTML 页面。
新建一个 01-html骨架标签 的 TXT 文件。
里面写入刚才的HTML 骨架。
把后缀名改为 .HTML。
右击–谷歌浏览器打开。
<html>
<head>
<title>我的第一个页面title>
head>
<body>
你我之间 黑马洗练 月薪过万 一飞冲天
body>
html>
为了便于记忆,我们请出刚才要辞职回家养猪的二师兄来帮忙, 我称之为 猪八戒记忆法
HTML标签名、类名、标签属性和大部分属性值统一用小写
推荐:
我的第一个页面
不推荐:
我的第一个页面
标签:
在HTML页面中,带有“< >”符号的元素被称为HTML标签,如上面提到的 、
、都是HTML骨架结构标签。分类:
<标签名> 内容 标签名> 比如 <body> 我是文字 body>
<标签名 /> 比如 <br />
pink老师 一句话说出他们:
世界上单身狗毕竟是少数的, 大部分还是喜欢成双成对,不要拉下你的另外一半,对待一个双标签要有始有终。
主要针对于双标签 的相互关系分为两种: 请大家务必熟悉记住这种标签关系,因为后面我们标签嵌套特别多,很容易弄混他们的关系。
<head>
<title> title>
head>
2.并列关系
<head>head>
<body>body>
倡议:
如果两个标签之间的关系是嵌套关系,子元素最好缩进一个tab键的身位(一个tab是4个空格)。如果是并列关系,最好上下对齐。
pink老师 一句话说出他们:
html双标签 可以分为 有 一种是 父子级 包含关系的标签 一种是 兄弟级 并列关系的标签
**请问下列哪组标签关系是错误的? **
为了提高我们的开发效率
减少代码的出错我们不提倡用记事本开发,我们有更好的犀利哥。
Dreamweaver
SublimeText
WebStorm
HBuilder
VScode
有人说:
普通青年 Dreamweaver
文艺青年 sublime
高手和傻子 用记事本
其实。。。。
感觉: 这个feel 倍儿爽 feel feel倍儿爽 爽爽爽爽!
sublime有非常多的优点, 最开心的就是非常轻量级,打开速度超快,后面更高的功能,后面再接触。
sublime生成html骨架小技巧
用法:
DOCTYPE html>
作用:
声明位于文档中的最前面的位置,处于 标签之前。此标签可告知浏览器文档使用哪种 HTML 或 XHTML 规范。pink老师 一句话说出他们:
就是告诉浏览器按照HTML5 规范解析页面.团队约定:
HTML文件必须加上 DOCTYPE 声明,并统一使用 HTML5 的文档声明
<html lang="en"> 指定html 语言种类
最常见的2个:
en
定义语言为英语zh-CN
定义语言为中文pink老师 一句话说出他们:
指定该html标签 内容 所用的语言为中文
团队约定:
考虑浏览器和操作系统的兼容性,目前仍然使用 zh-CN 属性值
@拓展阅读:
简单来说,可能对于程序来说没有太大的作用,但是它可以告诉浏览器,搜索引擎,一些处理Html的程序对页面语言内容来做一些对应的处理或者事情。
比如可以
<meta charset="UTF-8" />
字符集(Character set)是多个字符的集合。
计算机要准确的处理各种字符集文字,需要进行字符编码,以便计算机能够识别和存储各种文字。
utf-8是目前最常用的字符集编码方式,常用的字符集编码方式还有gbk和gb2312。
pink老师 一句话说出他们:
这句话是让 html 文件是以 UTF-8 编码保存的, 浏览器根据编码去解码对应的html内容。
团队约定:
一般情况下统一使用 "UTF-8" 编码, 请尽量统一写成标准的 "UTF-8",不要写成 "utf-8" 或 "utf8" 或 "UTF8"。
白话: 所谓标签语义化,就是指标签的含义。
pink老师 一句话说出语义化目的:
根据标签的语义,在合适的地方给一个最为合理的标签,让结构更清晰。
语义是否良好: 当我们去掉CSS之后,网页结构依然组织有序,并且有良好的可读性。( 裸奔起来一样好看 )
遵循的原则:先确定语义的HTML ,再选合适的CSS。所以,我们接下来学习html标签,要根据语义去记忆。 HTML网页中任何元素的实现都要依靠HTML标签。
首先 HTML和CSS是两种完全不同的语言,我们学的是结构,就只写HTML标签,认识标签就可以了。 不会再给结构标签指定样式了。
HTML标签有很多,这里我们学习最为常用的,后面有些较少用的,我们可以查下手册就可以了。
排版标签主要和css搭配使用,显示网页结构的标签,是网页布局最常用的标签。
单词缩写: head 头部. 标题 title 文档标题
为了使网页更具有语义化,我们经常会在页面中用到标题标签,HTML提供了6个等级的标题,即
标题标签语义: 作为标题使用,并且依据重要性递减
其基本语法格式如下:
<h1> 标题文本 h1>
<h2> 标题文本 h2>
<h3> 标题文本 h3>
<h4> 标题文本 h4>
<h5> 标题文本 h5>
<h6> 标题文本 h6>
显示效果如下:
小结 :
传智播客学前端,
前端入门亦简单。
简单知识简单看,
重点勤练写三遍。
标题一共六级选,
具体效果刷新见。
------pink老师
单词缩写: paragraph 段落 [ˈpærəgræf] 无须记这个单词
作用语义:
可以把 HTML 文档分割为若干段落
在网页中要把文字有条理地显示出来,离不开段落标签,就如同我们平常写文章一样,整个网页也可以分为若干个段落,而段落的标签就是
<p> 文本内容 p>
是HTML文档中最常见的标签,默认情况下,文本在一个段落中会根据浏览器窗口的大小自动换行。
单词缩写: horizontal 横线 [ˌhɔrəˈzɑntl] 同上
在网页中常常看到一些水平线将段落与段落之间隔开,使得文档结构清晰,层次分明。这些水平线可以通过插入图片实现,也可以简单地通过标签来完成,
<hr />是单标签
在网页中显示默认样式的水平线。
课堂练习:新闻页面
单词缩写: break 打断 ,换行
在HTML中,一个段落中的文字会从左到右依次排列,直到浏览器窗口的右端,然后自动换行。如果希望某段文本强制换行显示,就需要使用换行标签
<br />
这时如果还像在word中直接敲回车键换行就不起作用了。
此处有练习题
div span 是没有语义的 是我们网页布局主要的2个盒子 想必你听过 css+div
div 就是 division 的缩写 分割, 分区的意思 其实有很多div 来组合网页。
span 跨度,跨距;范围
语法格式:
<div> 这是头部 div> <span>今日价格span>
他们两个都是盒子,用来装我们网页元素的, 只不过他们有区别,现在我们主要记住使用方法和特点就好了
后面后面讲显示模式的时候,会告诉大家
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-54ZJQllc-1627969734254)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\div&span.png)]
标签名 | 定义 | 说明 |
---|---|---|
(x表示级数) | 标题标签 | 作为标题使用,并且依据重要性递减 |
段落标签 | 可以把 HTML 文档分割为若干段落 | |
|
水平线标签 | 没啥可说的,就是一条线 |
换行标签 | ||
div标签 | 用来布局的,但是现在一行只能放一个div | |
span标签 | 用来布局的,一行上可以放好多个span |
在网页中,有时需要为文字设置粗体、斜体或下划线效果,这时就需要用到HTML中的文本格式化标签,使文字以特殊的方式显示。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LqIKN5vn-1627969734255)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\文本格式化标签.png)]
所谓属性就是外在特性 比如 手机的颜色 手机的尺寸 ,总结就是手机的。。
使用HTML制作网页时,如果想让HTML标签提供更多的信息,可以使用HTML标签的属性加以设置。其基本语法格式如下:
<标签名 属性1="属性值1" 属性2="属性值2" …> 内容 标签名>
<手机 颜色="红色" 大小="5寸"> 手机>
单词缩写: image 图像
要想在网页中显示图像就需要使用图像标签,接下来将详细介绍图像标签以及和他相关的属性。(单标签)
语法如下:
<img src="图像URL" />
该语法中src属性用于指定图像文件的路径和文件名,他是img标签的必需属性。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IWr3Hbgv-1627969734256)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\图像属性.png)]
<img src="" alt="这是替代文字" title="这是提示文本" width="300" border="15"/>
注意:宽和高一般设定一个就行了,另一个等比例缩放
**注意: **
比如:
正常的<br />
<img src="cz.jpg" width="300" height="300" /><br />
带有边框的<br />
<img src="cz.jpg" width="300" height="300" border="3" /><br />
有提示文本的<br />
<img src="cz.jpg" width="300" height="300" border="3" title="这是个小蒲公英" /><br />
有替换文本的<br />
<img src="cz.jpg" width="300" height="300" border="3" alt="图片不存在" />
单词缩写: anchor 的缩写 [ˈæŋkə®] 。基本解释 锚, 铁锚 的
在HTML中创建超链接非常简单,只需用标签把文字包括起来就好。
语法格式:
<a href="跳转目标" target="目标窗口的弹出方式">文本或图像a>
属性 | 作用 |
---|---|
href | 用于指定链接目标的url地址,(必须属性)当为标签应用href属性时,它就具有了超链接的功能 |
target | 用于指定链接页面的打开方式,取值有_self和_blank两种,其中_self为默认值,__blank为在新窗口中打开方式。 |
注意:
外部链接 需要添加 http:// www.baidu.com
内部链接 直接链接内部页面名称即可 比如 < a href=“index.html”> 首页
空连接:如果没有确定链接目标时,可将链接标签的href属性值定义为“#”(即href="#"),表示该链接暂时为空链接。
下载链接:如果href里面地址是一个文件或者压缩包,会下载这个文件
不仅可以创建文本超链接,在网页中各种网页元素,如图像、表格、音频、视频等都可以添加超链接。
锚点链接(在同一个页面上点击一处时能跳转另一处)
第5点示例:
<a href="http://www.baidu.com"><img src="img.jpg">a>
第6点示例:
<a href="#live">个人生活a> (要点击的地方)
<h3 id="live">个人生活h3> (点完跳转的地方)
如果需要在HTML文档中添加一些便于阅读和理解但又不需要显示在页面中的注释文字,就需要使用注释标签。
简单解释:
注释内容不会显示在浏览器窗口中,但是作为HTML文档内容的一部分,也会被下载到用户的计算机上,查看源代码时就可以看到。
语法格式:
快捷键是: ctrl + / 或者 ctrl +shift + /
注释重要性:
pink老师 一句话说出他们:
注释是给人看的,目的是为了更好的解释这部分代码是干啥的, 程序是不执行这个代码的
一般用于简单的描述,如某些状态描述、属性描述等
注释内容前后各一个空格字符,注释位于要注释代码的上面,单独占一行
推荐:
...
不推荐:
...
...
实际工作中,我们的文件不能随便乱放,否则用起来很难快速的找到他们,因此我们需要一个文件夹来管理他们。
**目录文件夹: **
就是普通文件夹,里面只不过存放了我们做页面所需要的 相关素材,比如 html文件, 图片 等等。
**根目录 **
打开目录文件夹的第一层 就是 根目录
页面中的图片会非常多, 通常我们再新建一个文件夹专门用于存放图像文件(images),这时再插入图像,就需要采用“路径”的方式来指定图像文件的位置。路径可以分为: 相对路径和绝对路径
以引用文件之网页所在位置为参考基础,而建立出的目录路径。因此,当保存于不同目录的网页引用同一个文件时,所使用的路径将不相同,故称之为相对路径。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EPf0vvIK-1627969734257)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\相对路径.png)]
路径分类 | 符号 | 说明 |
---|---|---|
同一级路径 | 只需输入图像文件的名称即可,如。 | |
下一级路径 | “/” | 图像文件位于HTML文件同级文件夹下(例如文件夹名称为:images) 如。 |
上一级路径 | “…/” | 在文件名之前加入“…/” ,如果是上两级,则需要使用 “…/ …/”,以此类推, 如。 |
我们所说的 上一级 下一级 同一级 是 图片 相对于 HTML 页面的位置而言的
绝对路径以Web站点根目录为参考基础的目录路径。之所以称为绝对,意指当所有网页引用同一个文件时,所使用的路径都是一样的。
“D:\web\img\logo.gif”,或完整的网络地址,例如“http://www.itcast.cn/images/logo.gif”。
注意:
绝对路径用的较少(因为不同的电脑里有不同的路径)
但是要注意,它的写法 特别是符号 \ 并不是 相对路径的 /
HTML第一天的主题: <认识标签>
能用常用标签,写出最简单的页面s
总结今天的思路贯穿线:
通过创建锚点链接,用户能够快速定位到目标内容。
创建锚点链接分为两步:
1. 使用相应的id名标注跳转目标的位置。 (找目标)
<h3 id="two">第2集h3>
2. 使用<a href="#id名">链接文本a>创建链接文本(被点击的) (拉关系) 我也有一个姓毕的姥爷..
<a href="#two">
快速记忆法:
好比找个人办事, 首先找到他,然后拉关系,最后看效果。
语法:
<base target="_blank" />
**总结: **
pink老师 一句话说出他们:
全体链接~ 到 ~ 全体集合 所有链接 以新窗口打开页面 ~ 是
标签可定义预格式化的文本。 被包围在标签 元素中的文本通常会保留空格和换行符。而文本也会呈现为等宽字体。 ```html此例演示如何使用 pre 标签 对空行和 空格 进行控制
**pink老师 一句话说出他们:**
> 所谓的预格式化文本就是 ,按照我们预先写好的文字格式来显示页面, 保留空格和换行等。
有了这个标签,里面的文字,会按照我们书写的模式显示,不需要段落和换行标签了。但是,比较少用,因为不好整体控制。
#### 5.4 特殊字符 (理解)
一些特殊的符号,我们再html 里面很难或者 不方便直接 使用, 我们此时可以使用下面的替代代码。
**虽然有很多,但是我们平时用的比较较少, 大家重点记住 空格 大于号 小于号 就可以了,剩下的回来查阅。**
**总结:**
1. 是以**运算符**`&`开头,以**分号运算符**`;`结尾。
2. 他们不是标签,而是符号。
3. HTML 中不能使用小于号 “<” 和大于号 “>”特殊字符,浏览器会将它们作为标签解析,若要正确显示,在 HTML 源代码中使用字符实体
**团队约定**
*推荐:*
more >>
*不推荐:*
more >>
#### 5.5 html5发展之路
#### 5.6 什么是XHTML
XHTML 是更严格更纯净的 HTML 代码。
- XHTML 指**可扩展超文本标签语言**(EXtensible HyperText Markup Language)。
- XHTML 的目标是取代 HTML。
- XHTML 与 HTML 4.01 几乎是相同的。
- XHTML 是更严格更纯净的 HTML 版本。
- XHTML 是作为一种 XML 应用被重新定义的 HTML。
- XHTML 是一个 W3C 标准。
#### 5.7 HTML和 XHTML之间有什么区别?
- XHTML 指的是可扩展超文本标记语言
- XHTML 与 HTML 4.01 几乎是相同的
- XHTML 是更严格更纯净的 HTML 版本
- XHTML 是以 XML 应用的方式定义的 HTML
- XHTML 是 2001 年 1 月发布的 W3C 推荐标准
- XHTML 得到所有主流浏览器的支持
- XHTML 元素是以 XML 格式编写的 HTML 元素。XHTML是严格版本的HTML,例如它要求标签必须小写,标签必须被正确关闭,标签顺序必须正确排列,对于属性都必须使用双引号等。
# 6. @深入阅读
[HTML5的崛起之路](http://www.chinaz.com/manage/2015/0720/424831.shtml)
# 7. 预习内容
- 表格标签
- 能够通过表格标签能够写出一个简版表格数据展示
例如:
可以把你今天学习的内容放在表格内,再次作为总结
# ------------------------------------------
# 表格
# HTML 第二天目标
能够利用表格、列表和表单完成注册页面的综合案例
- 能出说表格用来做什么的
- 能说出列表用来做什么的
- 能说出表单用来做什么的
为了让我们页面显示的更加整齐,我们需要学习三个表(表格、表单、列表)
# 表格 table(会使用)
目标:
- 理解:
- 能说出表格用来做什么的
- 表格的基本结构组成
- 应用:
- 能够熟练写出n行n列的表格
- 能简单的合并单元格
**表格作用:**
存在即是合理的。 表格的现在还是较为常用的一种标签,但不是用来布局,**常见显示、展示表格式数据。**
因为它可以让数据显示的非常的规整,可读性非常好。
**特别是后台展示数据的时候表格运用是否熟练就显得很重要**,一个清爽简约的表格能够把繁杂的数据表现得很有条理,虽然 div 布局也可以做到,但是总没有表格来得方便。
## 1. 创建表格
在HTML网页中,要想创建表格,就需要使用表格相关的标签。
**创建表格的基本语法:**
```html
(表示行)
单元格内的文字
...
...
要深刻体会表格、行、单元格他们的构成。
在上面的语法中包含基本的三对HTML标签,分别为 table、tr、td,他们是创建表格的基本标签,缺一不可,下面对他们进行具体地解释
table用于定义一个表格标签。
tr标签 用于定义表格中的行,必须嵌套在 table标签中。
td 用于定义表格中的单元格,必须嵌套在标签中。
字母 td 指表格数据(table data),即数据单元格的内容,现在我们明白,表格最合适的地方就是用来存储数据的。
**总结: **
表格有部分属性我们不常用,这里重点记住 cellspacing 、 cellpadding。
注意这些属性要写到table里面去
后面CSS会学,这里了解下就行
我们经常有个说法,是三参为0, 平时开发的我们这三个参数 border cellpadding cellspacing 为 0
案例1:
<table width="500" height="300" border="1" cellpadding="20" cellspacing="0" align="center">
<tr> <th>姓名th> <th>性别th> <th>年龄th> tr>
<tr> <td>刘德华td> <td>男td> <td>55td> tr>
<tr> <td>郭富城td> <td>男td> <td>52td> tr>
<tr> <td>张学友td> <td>男td> <td>58td> tr>
<tr> <td>黎明td> <td>男td> <td>18td> tr>
<tr> <td>刘晓庆td> <td>女td> <td>63td> tr>
table>
案例2:
效果图
代码:
<table width="500" border="1" align="center" cellspacing="0" cellpadding="0">
<tr>
<th>姓名th>
<th>性别th>
<th>电话th>
tr>
<tr>
<td>小王td>
<td>女td>
<td>110td>
tr>
<tr>
<td>小明td>
<td>男td>
<td>120td>
tr>
table>
pink老师 一句话说出他们:
th 也是一个单元格 只不过和普通的 td单元格不一样,它会让自己里面的文字居中且加粗
<thead>
<tr>
<th>
th>
tr>
thead>
<tbody>
<tr>
<td>
td>
tr>
tbody>
对于比较复杂的表格,表格的结构也就相对的复杂了,所以又将表格分割成三个部分:题头、正文和脚注。而这三部分分别用:thead,tbody,tfoot来标注, 这样更好的分清表格结构
注意:
以上标签都是放到table标签中。
定义和用法
<table>
<caption>我是表格标题caption>
table>
**注意: **
案例3:
根据要求完成以下案例:
合并单元格是我们比较常用的一个操作,但是不会合并的很复杂。
**合并的顺序我们按照 先上 后下 先左 后右 的顺序 **
跟我们以前学习汉字的书写顺序完全一致。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WfoCTvo4-1627969734258)(F:\01-03 前端开发基础\01-HTML资料\02.HTML-Day02\笔记\media\目标单元格选择.png)]
标签名 | 定义 | 说明 | |
---|---|---|---|
|
表格标签 | 就是一个四方的盒子 | |
表格行标签 | 行标签要再table标签内部才有意义 | ||
单元格标签 | 单元格标签是个容器级元素,可以放任何东西 | ||
表头单元格标签 | 它还是一个单元格,但是里面的文字会居中且加粗 | ||
表格标题标签 | 表格的标题,跟着表格一起走,和表格居中对齐 | ||
clospan 和 rowspan | 合并属性 | 用来合并单元格的 | |
表格结构标签 | 将表格分为两大块 |
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bGuk1ip3-1627969734259)(F:\01-03 前端开发基础\01-HTML资料\02.HTML-Day02\笔记\media\表格相关属性.png)]
问?
前面我们知道表格一般用于数据展示的,但是网页中还是有很多跟表格类似的布局,如下图~~ 我们用什么做呢?
答:
答案是列表, 那什么是列表? 表格是用来显示数据的,那么列表就是用来布局的。 因为非常整齐和自由
概念:
容器里面装载着结构,样式一致的文字或图表的一种形式,叫列表
特点:
列表最大的特点就是 整齐 、整洁、 有序,跟表格类似,但是他可组合自由度会更高。
无序列表的各个列表项之间没有顺序级别之分,是并列的。其基本语法格式如下:
<ul>
<li>列表项1li>
<li>列表项2li>
<li>列表项3li>
......
ul>
比如下面这些,新闻是没有顺序的,不用排队,先到先得,后发布先显示。
注意:
1. <ul>ul>中只能嵌套<li>li>,直接在<ul>ul>标签中输入其他标签或者文字的做法是不被允许的。
2. <li>与li>之间相当于一个容器,可以容纳所有元素。
3. 无序列表会带有自己样式属性,放下那个样式,一会让CSS来!
有序列表即为有排列顺序的列表,其各个列表项按照一定的顺序排列定义,有序列表的基本语法格式如下:
<ol>
<li>列表项1li>
<li>列表项2li>
<li>列表项3li>
......
ol>
所有特性基本与ul 一致。 但是实际中比 无序列表 用的少很多。
定义列表常用于对术语或名词进行解释和描述,定义列表的列表项前没有任何项目符号。其基本语法如下:
<dl>
<dt>名词1dt>
<dd>名词1解释1dd>
<dd>名词1解释2dd> (dt和dd是并列关系)
...
<dt>名词2dt>
<dd>名词2解释1dd>
<dd>名词2解释2dd>
...
dl>
标签名 | 定义 | 说明 |
---|---|---|
|
无序标签 | 里面只能包含li 没有顺序,我们以后布局中最常用的列表 |
|
有序标签 | 里面只能包含li 有顺序, 使用情况较少 |
|
自定义列表 | 里面有2个兄弟, dt 和 dd |
我们现在还没有学布局,现在只要保证2个点:
目标:
现实中的表单,类似我们去银行办理信用卡填写的单子。 如下图
**作用: **
表单目的是为了收集用户信息。
在我们网页中, 我们也需要跟用户进行交互,收集用户资料,此时也需要表单。
在HTML中,一个完整的表单通常由表单控件(也称为表单元素)、提示信息和表单域3个部分构成。
**表单控件: **
包含了具体的表单功能项,如单行文本输入框、密码输入框、复选框、提交按钮、重置按钮等。
提示信息:
一个表单中通常还需要包含一些说明性的文字,提示用户进行填写和操作。
表单域:
表单域就是form
他相当于一个容器,用来容纳所有的表单控件和提示信息,可以通过他定义处理表单数据所用程序的url地址,以及数据提交到服务器的方法。如果不定义表单域,表单中的数据就无法传送到后台服务器。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lyZHDnge-1627969734260)(F:\01-03 前端开发基础\01-HTML资料\02.HTML-Day02\笔记\media\表单域.png)]
语法:
<input type="属性值" value="你好">
常用属性:
文本输入: <input type="text" />
密 码:<input type="password" />
提交按钮:<input type="submit" value="免费注册"> (将表单域中的内容发送给服务器)
普通按钮不传输数据,使用场景如:获取手机验证码
一组单选按钮和复选框要有相同的name值
文件域file:用于上传文件
用户名:<input type="text" name="username" value="请输入用户名">
用户名:<input type="text" name=“username” />
name表单的名字, 这样,后台可以通过这个name属性找到这个表单。 页面中的表单很多,name主要作用就是用于区别不同的表单。
<input type="radio" name="sex" />男
<input type="radio" name="sex" />女
性 别:
<input type="radio" name="sex" value="男" checked="checked" />男
<input type="radio" name="sex" value="女" />女
上面这个,表示就默认选中了 男 这个单选按钮
属性 | 说明 | 作用 |
---|---|---|
type | 表单类型 | 用来指定不同的控件类型 |
value | 表单值 | 表单里面默认显示的文本 |
name | 表单名字 | 页面中的表单很多,name主要作用就是用于区别不同的表单。 |
checked | 默认选中 | 表示那个单选或者复选按钮一开始就被选中了 |
maxlength | 指定输入最大长度 | 指定输入最大长度 |
目标:
label标签主要目的是为了提高用户体验。 为用户提高最优秀的服务。
概念:
label 标签为 input 元素定义标注(标签)。
作用:
用于绑定一个表单元素, 当点击label标签的时候, 被绑定的表单元素就会获得输入焦点。
如何绑定元素呢?
<label> 用户名: <input type="radio" name="usename" value="请输入用户名"> label>
适合单个表单选择
<label for="sex">男label>
<input type="radio" name="sex" id="sex">
pink老师 一句话说出他们:
当我们鼠标点击 label标签里面的文字时, 光标会定位到指定的表单里面
<textarea >
文本内容
textarea>
作用:
通过textarea控件可以轻松地创建多行文本输入框.
cols=“每行中的字符数” rows=“显示的行数” 放在控件中 我们实际开发不用,用CSS
表单 | 名称 | 区别 | 默认值显示 | 用于场景 |
---|---|---|---|---|
input type=“text” | 文本框 | 只能显示一行文本 | 单标签,通过value显示默认值 | 用户名、昵称、密码等 |
textarea | 文本域 | 可以显示多行文本 | 双标签,默认值写到标签中间 | 留言板 |
目的:
如果有多个选项让用户选择,为了节约空间,我们可以使用select控件定义下拉列表.
语法:
<select>
<option>选项1option>
<option>选项2option>
<option>选项3option>
...
select>
在option 中定义selected =" selected "时,当前项即为默认选中项。
<option selected="selected">默认显示内容option>
但是我们实际开发会用的比较少
收集的用户信息怎么传递给服务器?
通过form表单域
目的:
在HTML中,form标签被用于定义表单域,以实现用户信息的收集和传递,form中的所有内容都会被提交给服务器。
**语法: **
<form action="url地址" method="提交方式" name="表单名称">
各种表单控件
form>
常用属性:
属性 | 属性值 | 作用 |
---|---|---|
action | url地址 | 用于指定接收并处理表单数据的服务器程序的url地址。 |
method | get/post | 用于设置表单数据的提交方式,其取值为get或post。 |
name | 名称 | 用于指定表单的名称,以区分同一个页面中的多个表单。 |
注意:
每个表单都应该有自己表单域。我们现在做页面,不写看不到效果,但是 如果后面学 ajax 后台交互的时候,必须需要 form表单域。
推荐:
<input type="text" />
<input type="radio" name="name" checked="checked" />
不推荐:
<input type=text />
<input type='text' />
<input type="radio" name="name" checked />
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Documenttitle>
head>
<body>
<h3>青春不常在,抓紧谈恋爱h3> <br>
<table width="600" border="1" align="center">
<tr>
<td>性别td> <td> <input type="radio" name="sex" id="nan"> <label for="nan"><img src="up.jpg">男label> <input type="radio" name="sex" id="nv"> <label for="nv"><img src="down.jpg">女label> td>
tr>
<tr>
<td>生日td>
<td>
<select>
<option>2019option>
<option>2020option>
<option>2021option>
<option selected="selected">--请选择年--option>
select>
<select>
<option>1option>
<option>2option>
<option>2option>
<option selected="selected">--请选择月--option>
select>
<select>
<option>1option>
<option>2option>
<option>2option>
<option selected="selected">--请选择日--option>
select>
td>
tr>
<tr>
<td><label for="dizhi">所在地区label>td>
<td> <input type="text" value="请输入您的详细地址" id="dizhi">td>
tr>
<tr>
<td>婚姻状况td>
<td> <input type="radio" id="weihun" name="marriage"><label for="weihun">未婚label>
<input type="radio" id="yihun" name="marriage"><label for="yihun">已婚label>
<input type="radio" id="lihun" name="marriage"><label for="lihun">离婚label>
td>
tr>
<tr>
<td>喜欢的类型td>
<td>
<input type="checkbox" id="1" name="class"> <label for="1">妩媚label>
<input type="checkbox" id="2" name="class"> <label for="2">可爱label>
<input type="checkbox" id="3" name="class"> <label for="3">淑女label>
td>
tr>
<tr>
<td>自我介绍td>
<td>
<textarea>
自我介绍
textarea>
tr>
<tr>
<td>td>
<td>
<input type="submit" value="免费注册">
td>
tr>
<tr>
<td>td>
<td>
<input type="checkbox" checked="checked"> 我同意注册条款和会员加入标准
td>
tr>
<tr>
<td>td>
<td><a href="http://www.baidu.com" target="_blank">我是会员,立即登录a>td>
tr>
<tr>
<td>td>
<td><h3>我承诺h3>td>
tr>
<tr>
<td>td>
<td>
<u1>
<li>年满18岁,单身li>
<li>抱着严肃的态度li>
<li>真诚寻找另一半li>
u1>
td>
tr>
table>
body>
html>
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3Dztpoyw-1627969734261)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\相亲网注册 练习.png)]
经常查阅文档是一个非常好的学习习惯。
W3C : http://www.w3school.com.cn/
MDN: https://developer.mozilla.org/zh-CN/
终结了所有盒子都叫div
新增标签:
标签 | 描述 |
---|---|
|
头部标签 |
导航标签 | |
内容标签 | |
定义文档某个区域 | |
侧边栏标签 | |
尾部标签 |
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-X1Prrgwb-1627969734261)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626140099302.png)]
注意:
新增的多媒体标签主要包含两个:
使用它们可以很方便的在页面中嵌入音频和视频,而不再去使用 flash 和其他浏览器插件。
<video src="文件地址" controls="controls">video>
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7BiIQVrv-1627969734262)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141629907.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ygb75U74-1627969734263)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141799036.png)]
支持音频格式:mp3(支持的最多) ,wav,ogg
语法规范:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ziquUMIj-1627969734263)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141961939.png)]
google禁用音频只能通过js来解决
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pu2GskkI-1627969734264)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626142669350.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PRXlewgj-1627969734265)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626143720198.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gOPNTB5c-1627969734266)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145254529.png)]
注:如果用手机打开链接,则会适配手机显示和输入格式
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-puvBV3Rd-1627969734272)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145636165.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R6ULoo4K-1627969734272)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145916567.png)]
更改placeholder里文字的颜色:
input::placeholder { 伪元素,后面解释
color: skyblue;
}
说起HTML,这其实是个非常单纯的家伙, 他只关注内容的语义,
比如
表明这是一个段落,用 表明这儿有一个图片, 用 表示此处有链接。
很早的时候,世界上的网站虽然很多,但是他们都有一个共同的特点: 丑。
这个是一个外国比较早的购物网站
有些人就忍受不了了,你就不能把自己打扮得漂亮一点吗?
HTML说,我试试…
如果要改变下 高度或者变一个颜色,就需要大量重复操作
总结:
我们理想中的结果: 结构(html)与样式(css)相分离 这句话要记住
概念:
CSS(Cascading Style Sheets) ,通常称为CSS样式表或层叠样式表(级联样式表)
作用:
要书写css样式,那css样式书写的位置在哪呢?
css代码风格
概念:
称行内样式、行间样式.
是通过标签的style属性来设置元素的样式
其基本语法格式如下:
<标签名 style="属性1:属性值1; 属性2:属性值2; 属性3:属性值3;"> 内容 标签名>
实际上任何HTML标签都拥有style属性,用来设置行内式。
"color: red; font-size: 12px;">青春不常在,抓紧谈恋爱
:
;
隔开。概念:
称内嵌式
是将CSS代码集中写在HTML文档的head头部标签中,并且用style标签定义
其基本语法格式如下:
<head>
<style type="text/CSS">
选择器(选择的标签) {
属性1: 属性值1;
属性2: 属性值2;
属性3: 属性值3;
}
style>
head>
注意:
缺点:
没有彻底分离,只能将相同标签的内容全部改为目标格式
思考:
1. 如何实现结构与样式完全分离?
2. 如何实现css样式共享?
概念:
称链入式
是将所有的样式放在一个或多个以**.CSS**为扩展名的外部样式表文件中,
通过link标签将外部样式表文件链接到HTML文档中
其基本语法格式如下:
<head>
<link rel="stylesheet" type="text/css" href="css文件路径">
head>
属性 | 作用 |
---|---|
rel | 定义当前文档与被链接文档之间的关系,在这里需要指定为“stylesheet”,表示被链接的文档是一个样式表文件。 |
type | 定义所链接文档的类型,在这里需要指定为“text/CSS”,表示链接的外部文件为CSS样式表。我们都可以省略 |
href | 定义所链接外部样式表文件的URL,可以是相对路径,也可以是绝对路径。 |
样式表 | 优点 | 缺点 | 使用情况 | 控制范围 |
---|---|---|---|---|
行内样式表 | 书写方便,权重高 | 没有实现样式和结构相分离 | 较少 | 控制一个标签(少) |
内部样式表 | 部分结构和样式相分离 | 没有彻底分离 | 较多 | 控制一个页面(中) |
外部样式表 | 完全实现结构和样式相分离 | 需要引入 | 最多,强烈推荐 | 控制整个站点(多) |
样式书写一般有两种:
h3 { color: deeppink;font-size: 20px;}
h3 {
color: deeppink;
font-size: 20px;
}
样式选择器,属性名,属性值关键字全部使用小写字母书写,属性字符串允许使用大小写。
/* 推荐 */
h3{
color: pink;
}
/* 不推荐 */
H3{
COLOR: PINK;
}
使用HTML时,需要遵从一定的规范。CSS亦如此,要想熟练地使用CSS对网页进行修饰,首先需要了解CSS样式规则,
具体格式如下:
总结:
CSS的发展史
学习目标:
如上图所以,要把里面的小黄人分为2组,最快的方法怎办?
很多, 比如 一只眼睛的一组,剩下的一组
找到特定的HTML页面元素
pink老师一句话说出他们: ※※※※
**CSS选择器干啥的? 选择标签用的, 把我们想要的标签选择出来 ** 必须记住的
css 就是 分两件事, 选对人, 做对事。
h3 {
color: red;
}
这段代码就是2件事, 把 h3选出来, 然后 把它变成了 红色。 以后我们都这么干。
选择器分为基础选择器和 复合选择器,我们这里先讲解一下 基础选择器。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-F62o0vbv-1627969734273)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day01\笔记\media\选择器思维导图.png)]
概念:
标签选择器(元素选择器)是指用HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。
语法:
标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
作用:
标签选择器 可以把某一类标签全部选择出来 比如所有的div标签 和 所有的 span标签
优点:
是能快速为页面中同类型的标签统一样式
缺点:
不能设计差异化样式。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Cw9ZcrBE-1627969734274)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day01\笔记\media\css书写范例-1624674159343.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IwjXZuUB-1627969734275)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day01\笔记\media\空格规范-1624674051962.png)]
思考: 如果想要差异化选择不同的标签,怎么办呢? 就是说 我想单独选一个或者某几个标签呢?
类选择器使用“.”(英文点号)进行标识,后面紧跟类名.
语法:
.类名 {
属性1:属性值1;
属性2:属性值2;
属性3:属性值3;
}
优点:
注意
命名规范: 见附件(Web前端开发规范手册.doc)
命名是我们通俗约定的,但是没有规定必须用这些常用的命名。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8Ir0b0Cu-1627969734275)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day01\笔记\media\类命名.png)]
课堂案例:
<head>
<meta charset="utf-8">
<style>
.blue {
color: blue;
font-size: 100px;
}
.red {
color: red;
font-size: 100px;
}
.orange {
color: orange;
font-size: 100px;
}
.green {
color: green;
font-size: 100px;
}
style>
head>
<body>
<span class="blue">Gspan>
<span class="red">ospan>
<span class="orange">ospan>
<span class="blue">gspan>
<span class="green">lspan>
<span class="red">espan>
body>
我们可以给标签指定多个类名,从而达到更多的选择目的。
注意:
<div class="pink fontWeight font20">亚瑟div>
<div class="font20">刘备div>
<div class="font14 pink">安其拉div>
<div class="font14">貂蝉div>
如果一个DOM元素包含多个类名,其中的两个类名的属性产生冲突,并不是根据html中类名的顺序来决定DOM元素的属性,而是根据css样式中的顺序来决定DOM元素的属性,它取决于css样式表中后读取到的属性!---------也即覆盖
注意:类选择器还可以结合元素选择器来使用,如:
p.leiming {}
或
div.leiming{}
id选择器使用#
进行标识,后面紧跟id名
其基本语法格式如下:
id选择器
#id名 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
标签
元素的id值是唯一的,只能对应于文档中某一个具体的元素。
即一个id只能被调用一次,并且id中只能有一个样式
用法基本和类选择器相同。
pink老师 总结他们
类选择器我们在修改样式中,用的最多。
id选择器和类选择器最大的不同在于 使用次数上。
id选择器一般用于页面唯一性的元素身上,经常和我们后面学习的javascript 搭配使用。
概念
通配符选择器用*
号表示, * 就是 选择所有的标签 他是所有选择器中作用范围最广的,能匹配页面中所有的元素。
其基本语法格式如下:
* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }
例如下面的代码,使用通配符选择器定义CSS样式,清除所有HTML标记的默认边距。
* {
margin: 0; /* 定义外边距*/
padding: 0; /* 定义内边距*/
}
注意:
会匹配页面所有的元素,降低页面响应速度,不建议随便使用
选择器 | 作用 | 缺点 | 使用情况 | 用法 |
---|---|---|---|---|
标签选择器 | 可以选出所有相同的标签,比如p | 不能差异化选择 | 较多 | p { color:red;} |
类选择器 | 可以选出1个或者多个标签 | 可以根据需求选择 | 非常多 | .nav { color: red; } |
id选择器 | 一次只能选择器1个标签 | 只能使用一次 | 不推荐使用 | #nav {color: red;} |
通配符选择器 | 选择所有的标签 | 选择的太多,有部分不需要 | 不推荐使用 | * {color: red;} |
基础选择器我们一共学了4个, 每个都有自己的价值, 可能再某个地方都能用到。但是如果说,一定要找个最常用的,那么,肯定是类选择器。
选择器
*
/* 推荐 */
.jdc {}
li {}
p{}
/* 不推荐 */
*{}
#jdc {}
div{} 因为div 没有语义,我们尽量少用
目标
作用:
font-size属性用于设置字号
p {
font-size:20px;
}
注意:
作用:
font-family属性用于设置哪一种字体。
p{ font-family:"微软雅黑";}
p{font-family: Arial,"Microsoft Yahei", "微软雅黑";}
常用技巧:
1. 各种字体之间必须使用英文状态下的逗号隔开。
2. 中文字体需要加英文状态下的引号,英文字体一般不需要加引号。当需要设置英文字体时,英文字体名必须位于中文字体名之前。
3. 如果字体名中包含空格、#、$等符号,则该字体必须加英文状态下的单引号或双引号,例如font-family: "Times New Roman";。
4. 尽量使用系统默认字体,保证在任何用户的浏览器中都能正确显示。
为什么使用 Unicode字体
解决:
方案一: 你可以使用英文来替代。 比如font-family:"Microsoft Yahei"
。
方案二: 在 CSS 直接使用 Unicode 编码来写字体名称可以避免这些错误。使用 Unicode 写中文字体名称,浏览器是可以正确的解析的。
font-family: "\5FAE\8F6F\96C5\9ED1"; 表示设置字体为“微软雅黑”。
字体名称 | 英文名称 | Unicode 编码 |
---|---|---|
宋体 √ | SimSun | \5B8B\4F53 |
新宋体 | NSimSun | \65B0\5B8B\4F53 |
黑体 | SimHei | \9ED1\4F53 |
微软雅黑 √ | Microsoft YaHei | \5FAE\8F6F\96C5\9ED1 |
楷体_GB2312 | KaiTi_GB2312 | \6977\4F53_GB2312 |
隶书 | LiSu | \96B6\4E66 |
幼园 | YouYuan | \5E7C\5706 |
华文细黑 | STXihei | \534E\6587\7EC6\9ED1 |
细明体 | MingLiU | \7EC6\660E\4F53 |
新细明体 | PMingLiU | \65B0\7EC6\660E\4F53 |
为了照顾不同电脑的字体安装问题,我们尽量只使用宋体和微软雅黑中文字体
属性值 | 描述 |
---|---|
normal | 默认值(不加粗的)400 |
bold | 定义粗体(加粗的)700 |
100~900 | 400 等同于 normal,而 700 等同于 bold 我们重点记住这句话 |
提倡:
我们平时更喜欢用数字来表示加粗和不加粗。
font-style属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值如下:
属性 | 作用 |
---|---|
normal | 默认值,浏览器会显示标准的字体样式 font-style: normal; |
italic | 浏览器会显示斜体的字体样式。 |
小技巧:
平时我们很少给文字加斜体,反而喜欢给斜体标签(em,i)改为普通模式。
font属性用于对字体样式进行综合设置
选择器 { font: font-style font-weight font-size/line-height font-family;}
属性 | 表示 | 注意点 |
---|---|---|
font-size | 字号 | 我们通常用的单位是px 像素,一定要跟上单位!!!!!!!! |
font-family | 字体 | 实际工作中按照团队约定来写字体 |
font-weight | 字体粗细 | 记住加粗是 700 或者 bold 不加粗 是 normal 或者 400 记住数字不要跟单位!!!!! |
font-style | 字体样式 | 记住倾斜是 italic 不倾斜 是 normal 工作中我们最常用 normal |
font | 字体连写 | 1. 字体连写是有顺序的 不能随意换位置 2. 其中字号 和 字体 必须同时出现 |
作用:
color属性用于定义文本的颜色,
其取值方式有如下3种:
表示表示 | 属性值 |
---|---|
预定义的颜色值 | red,green,blue,还有我们的御用色 pink |
十六进制 | #FF0000,#FF6600,#29D794 |
RGB代码(可用吸管工具吸取) | rgb(255,0,0)或rgb(100%,0%,0%) |
注意
我们实际工作中, 用 16进制的写法是最多的,而且我们更喜欢简写方式比如 #f00 代表红色
<style>
.red {
color :#FF0000;
}
style>
作用:
text-align属性用于设置文本内容的水平对齐,相当于html中的align对齐属性
其可用属性值如下:
属性 | 解释 |
---|---|
left | 左对齐(默认值) |
right | 右对齐 |
center | 居中对齐 |
注意:
是让盒子里面的内容水平居中, 而不是让盒子居中对齐
<style>
h1 {
text-align: center;
}
style>
作用:
line-height属性用于设置行间距,就是行与行之间的距离,即字符的垂直间距,一般称为行高。
单位:
技巧:
一般情况下,行距比字号大7.8像素左右就可以了。
line-height: 24px;
作用:
text-indent属性用于设置首行文本的缩进,
属性值
1em 就是一个字的宽度 如果是汉字的段落, 1em 就是一个汉字的宽度
p {
/*行间距*/
line-height: 25px;
/*首行缩进2个字 em 1个em 就是1个字的大小*/
text-indent: 2em;
}
text-decoration 通常我们用于给链接修改装饰效果
值 | 描述 |
---|---|
none | 默认。定义标准的文本。 取消下划线(最常用) |
underline | 定义文本下的一条线。下划线 也是我们链接自带的(常用) |
overline | 定义文本上的一条线。(不用) |
line-through | 定义穿过文本下的一条线。(不常用) |
属性 | 表示 | 注意点 |
---|---|---|
color | 颜色 | 我们通常用 十六进制 比如#ff0000 而且是简写形式 #fff |
line-height | 行高 | 控制行与行之间的距离 |
text-align | 水平对齐 | 可以设定文字水平的对齐方式 |
text-indent | 首行缩进 | 通常我们用于段落首行缩进2个字的距离 text-indent: 2em; |
text-decoration | 文本修饰 | 记住 添加 下划线 underline 取消下划线 none |
此工具是我们的必备工具,以后代码出了问题
我们首先第一反应就是:
小技巧:
Emmet的前身是Zen coding,它使用缩写,来提高html/css的编写速度。
生成标签 直接输入标签名 按tab键即可 比如 div 然后tab 键, 就可以生成
如果想要生成多个相同标签 加上 * 就可以了 比如 div*3 就可以快速生成3个div
如果有父子级关系的标签,可以用 > 比如 ul > li就可以了
如果有兄弟关系的标签,用 + 就可以了 比如 div+p
如果生成带有类名或者id名字的, 直接写 .demo 或者 #two tab 键就可以了
如果生成的div 类名是有顺序的, 可以用 自增符号 $
如果想要在生成的标签中写内容{ }表示
.demo$*3
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bznChxo8-1627969734276)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\emmet快捷语法.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CXGazLZv-1627969734277)(F:\01-03 前端开发基础\01-HTML资料\01.HTML-Day01\笔记\media\快速格式化代码.png)]
也可以右键格式化文档
第01阶段.前端基础
今天我们围绕一个 导航栏案例进行学习知识点。
今日重点:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-S2fqmGXz-1627969734277)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\选择器.png)]
目标
为什么要学习css复合选择器
CSS选择器分为 基础选择器 和 复合选择器 ,但是基础选择器不能满足我们实际开发中,快速高效的选择标签。
概念:
后代选择器又称为包含选择器
作用:
用来选择元素或元素组的子孙后代
其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔,先写父亲爷爷,在写儿子孙子。
父级 子级{属性:属性值;属性:属性值;}
.class h3{color:red;font-size:16px;}
当标签发生嵌套时,内层标签就成为外层标签的后代。
子孙后代都可以这么选择。 或者说,它能选择任何包含在内 的标签。
无需一级一级选,可以跳级选
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qBACRPTn-1627969734278)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\后代选择器.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wDy5gk4Q-1627969734278)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\后代选择器1.png)]
作用:
子元素选择器只能选择作为某元素**子元素(亲儿子)**的元素。
其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 >
进行连接
语法:
.class>h3{color:red;font-size:14px;}
pink老师一句话说出他们
这里的子 指的是 亲儿子 不包含孙子 重孙子之类。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IlWfj2HK-1627969734279)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\子选择器.png)]
条件
交集选择器由两个选择器构成,找到的标签必须满足:既有标签一的特点,也有标签二的特点。
记忆技巧:
交集选择器 是 并且的意思。 即…又…的意思
比如: p.one 选择的是: 类名为 .one 的 段落标签。
用的相对来说比较少,不太建议使用。
,
连接而成的,通常用于集体声明。任何形式的选择器(包括标签选择器、class类选择器id选择器等),都可以作为并集选择器的一部分。
记忆技巧:
并集选择器通常用于集体声明 ,逗号隔开的,所有选择器都会执行后面样式,逗号可以理解为 和的意思。
比如 .one, p , #test {color: #F00;}
表示 .one 和 p 和 #test 这三个选择器都会执行颜色为红色。
通常用于集体声明。
div,p { 自带标签
color :red;
}
.nav,.header { 定义的类
color :red;
}
<div class="nav">
<ul>
<li><a href="#">公司首页a>li>
<li><a href="#">公司简介a>li>
<li><a href="#">公司产品a>li>
<li><a href="#">联系我们a>li>
ul>
div>
<div class="sitenav">
<div class="site-l">左侧侧导航栏div>
<div class="site-r"><a href="#">登录a>div>
div>
在不修改以上结构代码的前提下,完成以下任务:
伪类选择器:
为了和我们刚才学的类选择器相区别
类选择器是一个点 比如 .demo {}
而我们的伪类 用 2个点 就是 冒号 比如 :link{} 伪娘
作用:
用于向某些选择器添加特殊的效果。比如给链接添加特殊效果, 比如可以选择 第1个,第n个元素。
因为伪类选择器很多,比如链接伪类,结构伪类等等。我们这里先给大家讲解链接伪类选择器。
"#">未知的网站
a:link /* 未访问的链接 */
a:visited /* 已访问的链接 */
a:hover /* 鼠标移动到链接上 */
a:active /* 选定的链接 */(鼠标按下但还没弹起的那个链接)
注意
写的时候,他们的顺序尽量不要颠倒 按照 lvha 的顺序。否则可能引起错误。
记忆法
因为叫链接伪类,所以都是 利用交集选择器 a:link a:hover
因为a链接浏览器具有默认样式,所以我们实际工作中都需要给链接单独指定样式。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6RhVsjHl-1627969734279)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\链接伪类选择器.png)]
实际工作开发中,我们很少写全四个状态,一般我们写法如下:
a { /* a是标签选择器 所有的链接 */
font-weight: 700;
font-size: 16px;
color: gray;
}
a:hover { /* :hover 是链接伪类选择器 鼠标经过 */
color: red; /* 鼠标经过的时候,由原来的 灰色 变成了红色 */
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-w5UNRe69-1627969734280)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\focus伪类选择器2.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YCJzjPam-1627969734281)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\focus伪类选择器.png)]
选择器 | 作用 | 特征 | 使用情况 | 隔开符号及用法 |
---|---|---|---|---|
后代选择器 | 用来选择元素后代 | 是选择所有的子孙后代 | 较多 | 符号是空格 .nav a |
子代选择器 | 选择 最近一级元素 | 只选亲儿子 | 较少 | 符号是**>** .nav>p |
交集选择器 | 选择两个标签交集的部分 | 既是 又是 | 较少 | 没有符号 p.one |
并集选择器 | 选择某些相同样式的选择器 | 可以用于集体声明 | 较多 | 符号是逗号 .nav, .header |
链接伪类选择器 | 给链接更改状态 | 跟链接相关 | 较多 | 重点记住 a{} 和 a:hover 实际开发的写法 |
focus选择器 | 选择获得光标的表单 | 跟表单相关 | 较少 | input:focus 记住这个写法 |
目标:
什么是标签的显示模式?
标签以什么方式进行显示,比如div 自己占一行, 比如span 一行可以放很多个
作用:
我们网页的标签非常多,再不同地方会用到不同类型的标签,以便更好的完成我们的网页。
标签的类型(分类)
HTML标签一般分为块标签和行内标签两种类型,它们也称块元素和行内元素。
常见的块元素有~、
、
、、、- 等,其中标签是最典型的块元素。
- 块级元素的特点
(1)比较霸道,自己独占一行
(2)高度,宽度、外边距以及内边距都可以控制。
(3)宽度默认是容器(父级/浏览器宽度)的100%
(4)是一个容器及盒子,里面可以放行内或者块级元素。
- 注意:
- 只有 文字才 能组成段落 因此 p 里面不能放块级元素,特别是 p 不能放div
- 文字类的元素内不能放块元素
- 同理还有这些标签h1,h2,h3,h4,h5,h6,dt,他们都是文字类块级标签,里面不能放其他块级元素。
2.3 行内元素(inline-level)
- 例:
常见的行内元素有、、、、、、、、、、
- 行内元素的特点:
(1)相邻行内元素在一行上,一行可以显示多个。
(2)高、宽直接设置是无效的。
(3)默认宽度就是它本身内容的宽度。
(4)行内元素只能容纳文本或则其他行内元素。
注意:
-
链接a里面不能再放链接。
-
特殊情况:但是a里面可以放块级元素,但是给a转换一下块级模式最安全。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SiPq2z6w-1627969734281)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\行内元素注意.png)]
2.4 行内块元素(inline-block)
- 例:
在行内元素中有几个特殊的标签——图像、表单、单元格,他们同时具有块元素和行内元素的特点,可以对它们设置宽高和对齐属性,有些资料可能会称它们为行内块元素。
-
行内块元素的特点:
(1)和相邻行内元素(行内块)在一行上,但是之间会有空白缝隙。一行可以显示多个(行内元素特点)
(2)默认宽度就是它本身内容的宽度。(行内元素特点)
(3)高度,行高、外边距以及内边距都可以控制。(块级元素特点)
2.5 三种模式总结区别
元素模式
元素排列
设置样式
默认宽度
包含
块级元素
一行只能放一个块级元素
可以设置宽度高度
容器的100%
容器级可以包含任何标签
行内元素
一行可以放多个行内元素
不可以直接设置宽度高度
它本身内容的宽度
容纳文本或则其他行内元素
行内块元素
一行放多个行内块元素
可以设置宽度和高度
它本身内容的宽度
2.6 标签显示模式转换 display
-
块转行内:display:inline; (此时设定宽度高度是无效的)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-NvuOMKWO-1627969734282)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\1624781200043.png)]
-
行内转块:display:block;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MheXrZ2s-1627969734283)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day02\笔记\media\行内转块.png)]
-
块、行内元素转换为行内块: display: inline-block;
第二种和第三种用的比较多,特别是第二种行内转块
3. 行高那些事(line-height)
目标
- 理解
- 能说出 行高 和 高度 三种关系
- 能简单理解为什么行高等于高度单行文字会垂直居中
- 应用
- 使用行高实现单行文字垂直居中
- 能会测量行高
3.1 行高测量
行高的测量方法:
3.2 单行文本垂直居中
行高我们利用最多的一个地方是: 可以让单行文本在盒子中垂直居中对齐。
文字的行高等于盒子的高度。
这里情况些许复杂,开始学习,我们可以先从简单地方入手学会。
行高 = 上距离 + 内容高度 + 下距离
上距离和下距离总是相等的,因此文字看上去是垂直居中的。
行高和高度的三种关系
- 如果 行高 等 高度 文字会 垂直居中
- 如果行高 大于 高度 文字会 偏下
- 如果行高小于高度 文字会 偏上
4. CSS 背景(background)
目标
- 理解
- 背景的作用
- css背景图片和插入图片的区别
- 应用
- 通过css背景属性,给页面元素添加背景样式
- 能设置不同的背景图片位置
4.1 背景颜色(color)
-
语法:
background-color:颜色值; 默认的值是 transparent 透明的
4.2 背景图片(image)
- 实际开发常见于logo或者一些装饰性的小图片或超大图片,优点是便于控制位置(精灵图也是一种应用场景)
- 语法:
background-image : none | url (url)
参数
作用
none
无背景图(默认的)
url
使用绝对或相对地址指定背景图像
background-image : url(images/demo.png);
- 小技巧: 我们提倡 背景图片后面的地址,url不要加引号。
4.3 背景平铺(repeat)
- 背景图片和背景平铺可以同时添加,但是图片会压住背景颜色
- 语法:
background-repeat : repeat | no-repeat | repeat-x | repeat-y
参数
作用
repeat
背景图像在纵向和横向上平铺(默认的)
no-repeat
背景图像不平铺
repeat-x
背景图像在横向上平铺
repeat-y
背景图像在纵向平铺
4.4 背景位置(position) 重点!
- 语法:
background-position : length || length
background-position : position || position
参数
值
length
百分数 | 由浮点数字和单位标识符组成的长度值
position
top | center | bottom | left | center | right 方位名词
- 注意:
- 必须先指定background-image属性
- position 后面是x坐标和y坐标。 可以使用方位名词或者 精确单位。
- 如果指定两个值,两个值都是方位名字,则两个值前后顺序无关,比如left top和top left效果一致
- 如果只指定了一个方位名词,另一个值默认居中对齐。
- 如果position 后面是精确坐标, 那么第一个,肯定是 x 第二的一定是y,要带上单位px
- 如果只指定一个数值,那该数值一定是x坐标,另一个默认垂直居中
- 如果指定的两个值是 精确单位和方位名字混合使用,则第一个值是x坐标,第二个值是y坐标
实际工作用的最多的,就是背景图片居中对齐了。
练习1:
背景大图(大图放入body中,并居中显示 )
练习2:
小图片在盒子左侧垂直居中
4.5 背景附着
-
背景附着就是解释背景是滚动的还是固定的
-
语法:
background-attachment : scroll | fixed ;
参数
作用
scroll(默认)
背景图像是随对象内容滚动
fixed
背景图像固定
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-a5i0Psci-1627969734283)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624792530828.png)]
4.6 背景简写(和font类似)
- background:属性的值的书写顺序官方并没有强制标准的。为了可读性,建议大家如下写:
- background: 背景颜色 背景图片地址 背景平铺 背景滚动 背景位置;
- 语法:
background: transparent url(image.jpg) repeat-y scroll center top ;
案例:
导航栏案例
4.7 背景透明(CSS3)
- 语法:
background: rgba(0, 0, 0, 0.3);
- 最后一个参数是alpha 透明度 取值范围 0~1之间
- 我们习惯把0.3 的 0 省略掉 这样写 background: rgba(0, 0, 0, .3);
- 注意: 背景半透明是指盒子背景半透明, 盒子里面的内容不受影响
- 因为是CSS3 ,所以 低于 ie9 的版本是不支持的。
4.8 背景总结
属性
作用
值
background-color
背景颜色
预定义的颜色值/十六进制/RGB代码
background-image
背景图片
url(图片路径)
background-repeat
是否平铺
repeat/no-repeat/repeat-x/repeat-y
background-position
背景位置
length/position 分别是x 和 y坐标, 切记 如果有 精确数值单位,则必须按照先X 后Y 的写法
background-attachment
背景固定还是滚动
scroll/fixed
背景简写
更简单
背景颜色 背景图片地址 背景平铺 背景滚动 背景位置; 他们没有顺序
背景透明
让盒子半透明
background: rgba(0,0,0,0.3); 后面必须是 4个值
综合案例
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nAV28yv2-1627969734284)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624798452493.png)]
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Documenttitle>
<style>
.nav a {
display: inline-block;
width: 120px;
height: 58px;
background-color: rgb(37, 226, 78);
text-align: center;
line-height: 48px;
color: rgb(248, 244, 244);
text-decoration: none;
;
}
.nav .bg1 {
background: url(bg2.png) no-repeat;
}
.nav .bg1:hover {
background-image: url(bg4.png);
}
.nav .bg2 {
background: url(bg3.png) no-repeat;
}
.nav .bg2:hover {
background-image: url(bg5.png);
}
.nav .bg3 {
background: url(bg5.png) no-repeat;
}
.nav .bg3:hover {
background-image: url(bg7.png);
}
.nav .bg4 {
background: url(bg6.png) no-repeat;
}
.nav .bg4:hover {
background-image: url(bg1.png);
}
style>
head>
<body>
<div class="nav">
<a href="#" class="bg1">五彩导航a>
<a href="#" class="bg2">五彩导航a>
<a href="#" class="bg3">五彩导航a>
<a href="#" class="bg4">五彩导航a>
div>
body>
html>
5. CSS 三大特性
目标:
- 理解
- 能说出css样式冲突采取的原则
- 能说出那些常见的样式会有继承
- 应用
- 能写出CSS优先级的算法
- 能会计算常见选择器的叠加值
5.1 CSS层叠性
-
概念:
所谓层叠性是指多种CSS样式的叠加(覆盖)。
是浏览器处理冲突的一个能力,如果一个属性通过两个相同选择器设置到同一个元素上,那么这个时候一个属性就会将另一个属性层叠掉
-
原则:
- 样式冲突,遵循的原则是就近原则。 那个样式离着结构近,就执行那个样式。
- 样式不冲突,不会层叠
CSS层叠性最后的执行口诀: 长江后浪推前浪,前浪死在沙滩上。
5.2 CSS继承性
-
概念:
子标签会继承父标签的某些样式,如文本颜色和字号。
想要设置一个可继承的属性,只需将它应用于父元素即可。
简单的理解就是: 子承父业。
-
注意:
-
恰当地使用继承可以简化代码,降低CSS样式的复杂性。比如有很多子级孩子都需要某个样式,可以给父级指定一个,这些孩子继承过来就好了。
-
子元素可以继承父元素的样式(text-,font-,line-这些元素开头的可以继承,以及color属性)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DREbfG7w-1627969734284)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624799744990.png)]
CSS继承性口诀: 龙生龙,凤生凤,老鼠生的孩子会打洞。
5.3 CSS优先级(重点)!!!
-
概念:
定义CSS样式时,经常出现两个或更多规则应用在同一元素上,此时,
- 选择器相同,则执行层叠性
-
选择器不同,就会出现优先级的问题。
1). 权重计算公式
关于CSS权重,我们需要一套计算公式来去计算,这个就是 CSS Specificity(特殊性) 权重由低到高
标签选择器
计算权重公式
继承或者 *(通配符选择器)
0,0,0,0
每个元素(标签选择器)
0,0,0,1
类/伪类选择器
0,0,1,0
ID选择器
0,1,0,0
行内样式 style=""(直接把样式写在行内)
1,0,0,0
!important 重要的[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Zfmrex9y-1627969734285)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624859898104.png)]
∞ 无穷大 权重最大
- 值从左到右依次 进行比较,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。
- 关于CSS权重,我们需要一套计算公式来去计算,这个就是 CSS Specificity(特殊性)
- div {
color: pink!important;
}
2). 权重叠加!!!!
我们经常用复合选择器等,是有多个基础选择器组合而成,那么此时,就会出现权重叠加。
就是一个简单的加法计算
- div ul li ------> 0,0,0,3
- .nav ul li ------> 0,0,1,2
- a:hover (a属于标签选择器,:hover为伪类选择器) -----—> 0,0,1,1
- .nav a ------> 0,0,1,1
- [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VXb0s2l7-1627969734286)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624862606493.png)]
注意:
- 数位之间没有进制 比如说: 0,0,0,5 + 0,0,0,5 =0,0,0,10 而不是 0,0, 1, 0, 所以不会存在10个div能赶上一个类选择器的情况。
3). 继承的权重是0!
这个不难,但是忽略很容易绕晕。其实,我们修改样式,一定要看该标签有没有被选中。
1) 如果选中了,那么以上面的公式来计权重。谁大听谁的。
2) 如果没有选中,那么权重是0,因为继承的权重为0.
注意:对于a链接浏览器默认制定了一个样式 蓝色带下划线!所以不会继承其他父辈样式 ,要想更改样式必须单独定义
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-a8RTOLEr-1627969734286)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624860546595.png)]
CSS注释
CSS注释规则:
/* 需要注释的内容 */ 进行注释的,即在需要注释的内容前使用 "/*" 标记开始注释,在内容的结尾使用 "*/"结束。
例如:
p {
/* 所有的字体是14像素大小*/
font-size: 14px;
}
7. 今日总结
-------------------------------------------------------------
第01阶段.前端基础.盒子模型
第三天-盒子模型(CSS重点)❗❗❗
css学习三大重点: css 盒子模型 、 浮动 、 定位
主题思路:
目标:
- 理解:
- 能说出盒子模型有那四部分组成
- 能说出内边距的作用以及对盒子的影响
- 能说出padding设置不同数值个数分别代表的意思
- 能说出块级盒子居中对齐需要的2个条件
- 能说出外边距合并的解决方法
- 应用:
- 能利用边框复合写法给元素添加边框
- 能计算盒子的实际大小
- 能利用盒子模型布局模块案例
1.看透网页布局的本质
网页布局中,我们是如何把里面的文字,图片,按照美工给我们的效果图排列的整齐有序呢?
- 看透网页布局的本质:
- 首先利用CSS设置好盒子的大小,然后摆放盒子的位置。(CORE!)
- 最后把网页元素比如文字图片等等,放入盒子里面。
- 以上两步 就是网页布局的本质
我们明白了,盒子是网页布局的关键点,所以我们更应该弄明白 这个盒子有什么特点。
2. 盒子模型(Box Model)
-
所谓盒子模型:
- 就是把HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。
pink老师总结:
- 盒子模型有元素的内容、边框(border)、内边距(padding)、和外边距(margin)组成。
- 盒子里面的文字和图片等元素是 内容区域
- 盒子的厚度 我们成为 盒子的边框
- 盒子内容与边框的距离是内边距(类似单元格的 cellpadding)
- 盒子与盒子之间的距离是外边距(类似单元格的 cellspacing)
标准盒子模型
3. 盒子边框(border)
- 语法:
border : border-width || border-style || border-color
属性
作用
border-width
定义边框粗细,单位是px
border-style
边框的样式(如虚线实线)
border-color
边框颜色(默认为黑色)
- 边框的样式:
- none:没有边框即忽略所有边框的宽度(默认值)
- solid:边框为单实线(最为常用的)
- dashed:边框为虚线
- dotted:边框为点线
3.1 边框综合设置
border : border-width || border-style || border-color
例如:
border: 1px solid red; 没有顺序
如:
div {
width: 100px;
height: 40px;
border: 1px solid red;
}
3.2 盒子边框写法总结表
很多情况下,我们不需要指定4个边框,我们是可以单独给4个边框分别指定的。
上边框
下边框
左边框
右边框
border-top-style:样式;
border-bottom-style:样式;
border-left-style:样式;
border-right-style:样式;
border-top-width:宽度;
border- bottom-width:宽度;
border-left-width:宽度;
border-right-width:宽度;
border-top-color:颜色;
border- bottom-color:颜色;
border-left-color:颜色;
border-right-color:颜色;
border-top:宽度 样式 颜色;
border-bottom:宽度 样式 颜色;
border-left:宽度 样式 颜色;
border-right:宽度 样式 颜色;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-P8sNxFzc-1627969734287)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day03\笔记\media\1624867709060.png)]
3.3 表格的细线边框border-collapse
-
通过表格的cellspacing="0"
,将单元格与单元格之间的距离设置为0,
-
但是两个单元格之间的边框会出现重叠,从而使边框变粗
-
通过css属性:
table{ border-collapse:collapse; }
- collapse 单词是合并的意思
- border-collapse:collapse; 表示相邻边框合并在一起。
注意:盒子加上边框后总体大小会变大
4. 内边距(padding)
4.1 内边距:
padding属性用于设置内边距。 是指 边框与内容之间的距离。
4.2 设置
属 性
作用
padding-left
左内边距
padding-right
右内边距
padding-top
上内边距
padding-bottom
下内边距
当我们给盒子指定padding值之后, 发生了2件事情:
- 内容和边框 有了距离,添加了内边距。
- 盒子会变大了。所以为了让盒子加了内边距后大小不变,可以让盒子宽高减小一个内边距
- [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-i1gnZpzq-1627969734288)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624869516087.png)]
注意: 后面跟几个数值表示的意思是不一样的。
我们分开写有点麻烦,我们可以不可以简写呢?
padding后面跟的值的个数
表达意思
1个值(padding:5px)
padding:上下左右内边距;
2个值(padding:5px 10px)
padding: 上下内边距 左右内边距 ;
3个值(padding:5px 10px 20px)
padding:上内边距 左右内边距 下内边距;
4个值(padding:5px 10px 20px 30px)
padding: 上内边距 右内边距 下内边距 左内边距 ;
练习:导航栏
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tmCnB8Qi-1627969734288)(C:\Users\28897\Desktop\QQ录屏20210628202752 00_00_00-00_00_30.gif)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BggOOtRo-1627969734289)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624884281799.png)]
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Documenttitle>
<style>
.nav {
height: 41px;
border-top: 3px solid orange;
border-bottom: 1px solid #edeef0;
line-height: 41px;
}
.nav a {
text-decoration: none;
color: #4c4c4c;
/* height: 41px; */
padding: 0 20px;
display: inline-block;
}
.nav a:hover {
background-color: #eee;
color: darkcyan;
style>
<body>
<div class="nav">
<a href="#">设为首页a>
<a href="#">手机新浪网a>
<a href="#">博客a>
<a href="#">关注我a>
<a href="#">新浪导航a>
div>
body>
html>
课堂一练:
请写出如下内边距:
- 要求盒子有一个左边内边距是 5像素
- 要求简写的形式写出 一个盒子上下是 25像素 左右是15像素。
- 要求简写的形式写出 一个盒子 上内边距是 12像素 下内边距是 0 左内边距是 25像素 右内边距是 10像素
4.3 课堂案例: 新浪导航
新浪导航栏的核心就是因为里面的字数不一样多,所以我们不方便给宽度,还是给padding ,撑开盒子的。
4.4 内盒尺寸计算(元素实际大小)
-
宽度
Element Height = content height + padding + border (Height为内容高度)
-
高度
Element Width = content width + padding + border (Width为内容宽度)
-
盒子的实际的大小 = 内容的宽度和高度 + 内边距 + 边框
4.5 内边距产生的问题
-
问题
会撑大原来的盒子
-
解决:
通过给设置了宽高的盒子,减去相应的内边距的值,维持盒子原有的大小
课堂一练
- 一个盒子宽度为100, padding为 10, 边框为5像素,问这个盒子实际的宽度的是()
-
(A) 130
-
(B) 135
-
© 125
-
(D) 115
100 + 20 + 10
- 关于根据下列代码计算 盒子宽高下列说法正确的是()
div {
width: 200px;
height: 200px;
border: 1px solid #000000;
border-top: 5px solid blue;
padding: 50px;
padding-left: 100px;
}
- (A) 宽度为200px 高度为200px
- (B) 宽度为352px 高度为306px
- © 宽度为302px 高度为307px
- (D) 宽度为302px 高度为252px
w 200 + 150 + 2 = 352
h 200 + 100 + 6 = 306
4.6 padding不影响盒子大小情况
如果没有给一个盒子指定宽度,那么他将继承父辈body的宽度(屏幕宽度), 此时,如果给这个盒子指定padding, 则不会撑开盒子。
5. 外边距(margin)
5.1 外边
margin属性用于设置外边距。 margin就是控制盒子和盒子之间的距离
5.2 设置:
属性
作用
margin-left
左外边距
margin-right
右外边距
margin-top
上外边距
margin-bottom
下外边距
margin值的简写 (复合写法)代表意思 跟 padding 完全相同。
可以通过F12+computed查看盒子模型
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-y9duff99-1627969734290)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624887231384.png)]
5.3 块级盒子水平居中
- 可以让一个块级盒子实现水平居中必须:
- 盒子必须指定了宽度(width)
- 然后就给左右的外边距都设置为auto,
实际工作中常用这种方式进行网页布局,示例代码如下:
.header{ width:960px; margin:0 auto;
常见的写法,以下下三种都可以。
- margin-left: auto; margin-right: auto;
- margin: auto;
- margin: 0 auto;
5.4 文字居中和盒子居中区别
-
盒子内的文字水平居中是 text-align: center, 而且还可以让 行内元素和行内块居中对齐
-
块级盒子水平居中 左右margin 改为 auto
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Nd7cXVh5-1627969734290)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624954987829.png)]
text-align: center; /* 文字 行内元素 行内块元素水平居中 */
margin: 10px auto; /* 块级盒子水平居中 左右margin 改为 auto 就阔以了 上下margin都可以 */
5.5 插入图片和背景图片区别
- 插入图片 我们用的最多 比如产品展示类 移动位置只能靠盒模型 padding margin
- 背景图片我们一般用于小图标背景 或者 超大背景图片 背景图片 只能通过 background-position
img {
width: 200px;/* 插入图片更改大小 width 和 height */
height: 210px;
margin-top: 30px; /* 插入图片更改位置 可以用margin 或padding 盒模型 */
margin-left: 50px; /* 插入当图片也是一个盒子 */
}
div {
width: 400px;
height: 400px;
border: 1px solid purple;
background: #fff url(images/sun.jpg) no-repeat;
background-position: 30px 50px; /* 背景图片更改位置 我用 background-position */
}
5.6 清除元素的默认内外边距(重要)
为了更灵活方便地控制网页中的元素,制作网页时,我们需要将元素的默认内外边距清除
代码:
* {
padding:0; /* 清除内边距 */
margin:0; /* 清除外边距 */
}
注意:
- 行内元素为了照顾兼容性, 尽量只设置左右内外边距, 不要设置上下内外边距。
5.7 外边距合并
使用margin定义块元素的垂直外边距时,可能会出现外边距的合并。
(1). 相邻块元素垂直外边距的合并
- 当上下相邻的两个块元素相遇时,如果上面的元素有下外边距margin-bottom
- 下面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom与margin-top之和
- 取两个值中的较大者这种现象被称为相邻块元素垂直外边距的合并(也称外边距塌陷)。
解决方案:尽量给只给一个盒子添加margin值。
(2). 嵌套块元素垂直外边距的合并(塌陷)
- 对于两个嵌套关系的块元素,如果父元素没有上内边距及边框
- 父元素的上外边距会与子元素的上外边距发生合并
- 合并后的外边距为两者中的较大者
三种解决方案:
-
可以为父元素定义上边框。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Hn1Us8uc-1627969734291)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624956434899.png)]
-
可以为父元素定义上内边距
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XrSpixRT-1627969734291)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624956561544.png)]
-
可以为父元素添加overflow:hidden
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-quzrI2kA-1627969734292)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624956632276.png)]
还有其他方法,比如浮动、固定、绝对定位的盒子不会有问题,后面咱们再总结。。。
6. 盒子模型布局稳定性
- 学习完盒子模型,内边距和外边距,什么情况下用内边距,什么情况下用外边距?
- 大部分情况下是可以混用的。 就是说,你用内边距也可以,用外边距也可以。 你觉得哪个方便,就用哪个。
我们根据稳定性来分,建议如下:
按照 优先使用 宽度 (width) 其次 使用内边距(padding) 再次 外边距(margin)。
width > padding > margin
- 原因:
- margin 会有外边距合并 还有 ie6下面margin 加倍的bug(讨厌)所以最后使用。
- padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。
- width 没有问题(嗨皮)我们经常使用宽度剩余法 高度剩余法来做。
7. ps基本操作以及常用快捷键:
因为网页美工大部分效果图都是利用ps 来做的,所以,以后我们大部分切图工作都是在ps里面完成。
- 文件–打开 – 可以打开 我们要测量的图片
- ctrl+r 可以打开标尺 或者 视图 – 标尺
- 右击标尺, 把里面的单位改为 像素
- ctrl+ 加号 键 可以 放大 视图 ctrl+ 减号 缩小视图
- 按住空格键, 鼠标可以 变成小手 ,拖动 ps 视图
- 用选区 拖动 可以 测量 大小
- ctrl+ d 可以取消选区 或者旁边空白处点击一下也可以取消选区
8. 综合案例
1、
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GI7A6BzU-1627969734293)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day03\素材\案例1(2)] 00_00_00-00_00_30.gif)
Document
"box">
最新文章/New Articles
-
"tb.png" alt="">
"#">北京招聘网页设计,平面设计,php
-
"tb.png" alt="">
"#">体验javascript的魅力
-
"tb.png" alt="">
"#">jquery世界来临
-
"tb.png" alt="">
"#">网页设计师的梦想
-
"tb.png" alt="">
"#">jquery中的链式编程是什么
2、
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4BM7AgWV-1627969734294)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\案例1 00_00_00-00_00_30.gif)]
Document
"box">
"title">品优购快报
/*这里直接用ul,不需要加div,用ul也是很多大厂网页的做法*/
- "#">【特惠】爆款耳机五折秒!
- "#">【特惠】母亲节,健康好礼低至五折!
- "#">【特惠】9.9元洗100张照片
- "#">【特惠】长虹智能空调立省1000
3、
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TE8rYIvC-1627969734294)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1624970441112.png)]
Document
"box">
"1.png" alt="">
红米蓝牙耳机不错,蓝牙秒连米蓝牙耳机不错,蓝牙秒连
"appraise">来自用户193347的评价
"info">
Redmi AirDots真无线蓝...
"shuxian">|
99.9元
9. 今日总结
拓展@
以下我们讲的CSS3部分新属性, 但是我们遵循的原则是,以下内容,不会影响我们页面布局, 只是样式更好看了而已。
1.圆角边框(CSS3)
- 语法:
border-radius:length;
-
其中每一个值可以为 数值或百分比的形式。
-
技巧: 让一个正方形 变成圆圈
border-radius: 50%;
-
-
以上效果图矩形的圆角, 就不要用 百分比了,因为百分比会是表示高度和宽度的一半。
-
而我们这里矩形就只用 用 高度的一半就好了。精确单位。
-
可对四个角设置不同的圆度值:
1个数值
四个角相同弧度
2个数值
角1、3 ,角2、4
3个数值
角1,角2、4,角3
4个数值
顺时针角1 2 3 4
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Am9RXm4T-1627969734295)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625292731552.png)]
-
也可对每个圆角单独设置。但是注意方位词顺序不可以颠倒,如top-left
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nokNMLCJ-1627969734295)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625293058240.png)]
2. 盒子阴影(CSS3)
- 语法:
box-shadow: h-shadow v-shadow blur spread color inset;
box-shadow:水平阴影 垂直阴影 模糊距离(虚实) 阴影尺寸(影子大小) 阴影颜色 内/外阴影;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8eKBFRrn-1627969734296)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625293712038.png)]
- 前两个属性是必须写的。其余的可以省略。
- 外阴影 (outset) 是默认的 但是不能写 ,否则会导致阴影无效。 想要内阴影可以写 inset
- 盒子阴影不占用空间,不会影响其他盒子排列
- 可以使用.box:hover{}实现鼠标经过盒子产生阴影效果
div {
width: 200px;
height: 200px;
border: 10px solid red;
box-shadow: 0 15px 30px rgba(0, 0, 0, .4);
}
3.文字阴影
div {
text-shadow:5px 5px 6px rgba(0, 0, 0, .3)
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jADNIHGZ-1627969734296)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625295176226.png)]
CSS书写规范
开始就形成良好的书写规范,是你专业的开始。
空格规范
【强制】 选择器 与 { 之间必须包含空格。
示例:
.selector {
}
【强制】 属性名 与之后的 : 之间不允许包含空格, : 与 属性值 之间必须包含空格。
示例:
font-size: 12px;
选择器规范
【强制】 并集选择器,每个选择器声明必须独占一行。
示例:
.post,
.page,
.comment {
line-height: 1.5;
}
【建议】 一般情况情况下,选择器的嵌套层级应不大于 3 级,位置靠后的限定条件应尽可能精确。
示例:
/* good */
#username input {}
.comment .avatar {}
/* bad */
.page .header .login input {}
.comment div * {}
属性规范
【强制】 属性定义必须另起一行。
示例:
/* good */
.selector {
margin: 0;
padding: 0;
}
/* bad */
.selector { margin: 0; padding: 0; }
【强制】 属性定义后必须以分号结尾。
示例:
/* good */
.selector {
margin: 0;
}
/* bad */
.selector {
margin: 0
}
-------------------------------------------------------------
第四天
1. 浮动(float)
目标
- 记忆
- 能够说出 CSS 的布局的三种机制
- 理解
- 能够说出普通流在布局中的特点
- 能够说出我们为什么用浮动
- 能够说出我们为什么要清除浮动
- 应用
- 能够利用浮动完成导航栏案例
- 能够清除浮动
- 能够使用PS切图工具
1.1 CSS 布局的三种机制
网页布局的核心——就是用 CSS 来摆放盒子。
CSS 提供了 3 种机制来设置盒子的摆放位置,分别是普通流(标准流)、浮动和定位,其中:
-
普通流(标准流/文档流)
所谓的标准流:就是标签按照规定好默认方式排列,它是最基本的布局方式。
- 块级元素会独占一行,从上向下顺序排列;
- 常用元素:div、hr、p、h1~h6、ul、ol、dl、form、table
- 行内元素会按照顺序,从左到右顺序排列,碰到父元素边缘则自动换行;
- 常用元素:span、a、i、em等
-
浮动
- 让盒子从普通流中浮起来,主要作用让多个块级盒子一行显示。
-
定位
- 将盒子定在浏览器的某一个位置——CSS 离不开定位,特别是后面的 js 特效。
1.2 为什么需要浮动?
我们首先要思考以下2个布局中最常见的问题?
-
如何让多个盒子(div)水平排列成一行?
-
如何实现盒子的左右对齐?
虽然我们前面学过行内块(inline-block) 但是他却有自己的缺陷:
- 它可以实现多个元素一行显示,但是中间会有空白缝隙,不能满足以上第一个问题。
- 它不能实现以上第二个问题,盒子左右对齐
总结
因为一些网页布局要求,标准流不能满足我们的需要了,因此我们需要浮动来完成网页布局。
网页布局第一准则:多个块级元素纵向排列找标准流,横向排列找浮动
1.3 什么是浮动(float)
概念:元素的浮动是指设置了浮动属性的元素会
- 脱离标准普通流的控制
- 移动到指定位置。
- float属性用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。
语法
选择器 { float: 属性值; }
属性值
描述
none
元素不浮动(默认值)
left
元素向左浮动
right
元素向右浮动
1.4浮动特性(重难点)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-L15sC3xK-1627969734297)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625299190784.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OQdhjsFc-1627969734298)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625299544795.png)]
脱离标准流。 俗称 “脱标”
.box1 {
width: 200px;
height: 200px;
background-color: rgba(255, 0, 0, 0.5);
float: left; /*贴着左边的浏览器边缘*/
}
.box2 {
width: 200px;
height: 200px;
background-color: rgba(255, 0, 0, 0.5);
float: left; /*贴着左边的box1边缘*/
}
- float 属性会让盒子漂浮在标准流的上面,所以第二个标准流的盒子跑到浮动盒子的底下了。
任何元素都可以浮动。而不论它原先是何种元素,添加浮动后和行内块元素的特性极其相似。
如果块级盒子没有设置宽度,默认宽度和父级一样宽,但是添加浮动后,它的大小根据内容来决定
div {
width: 200px;
height: 200px;
background-color: pink;
float: left;
}
.two {
background-color: hotpink;
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XTTwDQ3D-1627969734298)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625300085459.png)]
注意: 浮动的元素互相贴靠一起的,但是如果父级宽度装不下这些浮动的盒子, 多出的盒子会另起一行对齐
float —— 浮漏特
特点
说明
浮
加了浮动的盒子是浮起来的,漂浮在其他标准流盒子的上面。
漏
加了浮动的盒子是不占位置的,它原来的位置漏给了标准流的盒子。
特
特别注意:浮动元素会改变display属性, 类似转换为了行内块,但是元素之间没有空白缝隙
1.5 浮动(float)的应用(重要❗)
浮动和标准流的父盒子搭配
我们知道,浮动是脱标的,会影响下面的标准流元素,此时,我们需要给浮动的元素添加一个标准流的父亲,这样,最大化的减小了对其他标准流的影响。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sRlO25T0-1627969734299)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625302794291.png)]
pink老师说:
一个完整的网页,是 标准流 + 浮动 + 我们后面要讲的定位 一起完成的。
浮动应用案例
1、这个案例不需要做完整,只需要练习盒子浮动,将整体框架勾勒出来
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DHSBjxHx-1627969734299)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day04\素材\QQ录屏20210703180420.gif)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YKMsPinf-1627969734300)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625306759050.png)]
Document
- 1
- 2
- 3
- 4
2、
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-13XCzKkj-1627969734300)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625312119817.png)]
Document
效果如下图:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-82ZxsUds-1627969734300)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625312165801.png)]
导航栏案例
注意,实际重要的导航栏中,我们不会直接用链接a 而是用 li 包含链接(li+a)的做法。
- li+a 语义更清晰,一看这就是有条理的列表型内容。
- 如果直接用a,搜索引擎容易辨别为有堆砌关键字嫌疑(故意堆砌关键字容易被搜索引擎有降权的风险),从而影响网站排名
1.6 浮动的扩展
1). 浮动元素与父盒子的关系
- 子盒子的浮动参照父盒子对齐
- 不会与父盒子的边框重叠,也不会超过父盒子的内边距
2). 浮动元素与兄弟盒子的关系
在一个父级盒子中,如果前一个兄弟盒子是:
- 浮动的,那么当前盒子会与前一个盒子的顶部对齐;
- 普通流的,那么当前盒子会显示在前一个兄弟盒子的下方。
pink老师 要你记住:
浮动只会影响当前的或者是后面的标准流盒子,不会影响前面的标准流。
建议 :如果一个盒子里面有多个子盒子,其中一个盒子浮动,其他兄弟也应该浮动,防止引起问题
2. 清除浮动
2.1 为什么要清除浮动
因为父级盒子很多情况下(如淘宝产品列表),不方便给高度,但是子盒子浮动就不占有位置,最后父级盒子高度为0,就影响了下面的标准流盒子。
- 总结:
- 由于浮动元素不再占用原文档流的位置,所以它会对后面的元素排版产生影响
- 准确地说,并不是清除浮动,而是清除浮动后造成的影响
2.2 清除浮动本质和策略
**清除浮动本质:***清除浮动主要为了解决父级元素因为子级浮动引起内部高度为0 的问题。清除浮动之后, 父级就会根据浮动的子盒子自动检测高度。父级有了高度,就不会影响下面的标准流了
清除浮动的策略:闭合浮动:只让浮动在父盒子内部影响,不影响父盒子外面的其他盒子
2.3 清除浮动的方法
在CSS中,clear属性用于清除浮动,在这里,我们先记住清除浮动的方法,具体的原理,等我们学完css会再回头分析。
- 语法:
选择器{clear:属性值;} clear 清除
属性值
描述
left
不允许左侧有浮动元素(清除左侧浮动的影响)
right
不允许右侧有浮动元素(清除右侧浮动的影响)
both
同时清除左右两侧浮动的影响
但是我们实际工作中, 几乎只用 clear: both;
eg:
.box {
clear:both;
}
1).额外标签法(隔墙法)(不推荐)
是W3C推荐的做法是通过在浮动元素末尾添加一个空的标签例如 <div style=”clear:both”>div>,或则其他标签br等亦可。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eciGLtqf-1627969734301)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625314407277.png)]
- 优点: 通俗易懂,书写方便
- 缺点: 添加许多无意义的标签,结构化较差。
- 新添加的盒子必须是块级元素,不能是行内元素 ❗❗
2).父级添加overflow属性方法
“ 子不教 父之过 ”
可以给父级添加: overflow为 hidden| auto| scroll 都可以实现。
eg:
优点: 代码简洁
缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。(简单了解)
3).使用after伪元素清除浮动
(高级写法,直接复制和调用)
:after 方式为空元素额外标签法的升级版(在父元素后面插入一个空盒子),好处是不用单独加标签了
使用方法:
.clearfix:after {
content: "";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.clearfix {
*zoom: 1;
} /* IE6、7 专有(考虑兼容性) */
调用:
"box clearfix">
- 优点: 符合闭合浮动思想 结构语义化正确
- 缺点: 由于IE6-7不支持:after,使用 zoom:1触发 hasLayout。
- 代表网站: 百度、淘宝网、网易等
4).使用双伪元素清除浮动
使用方法:
.clearfix:before,
.clearfix:after {
content:"";
display:table;
}
.clearfix:after {
clear:both;
}
.clearfix {
*zoom:1;
} /*照顾IE6 IE7*/
- 优点: 代码比较简洁
- 缺点: 由于IE6-7不支持:after,使用 zoom:1触发 hasLayout。
- 代表网站: 小米、腾讯等
2.4 清除浮动总结
pink老师告诉你我们以后什么时候用清除浮动呢?
- 父级没高度
- 子盒子浮动了
- 影响下面布局了,我们就应该清除浮动了。
清除浮动的方式
优点
缺点
额外标签法(隔墙法)
通俗易懂,书写方便
添加许多无意义的标签,结构化较差。
父级overflow:hidden;
书写简单
溢出隐藏
父级after伪元素
结构语义化正确
由于IE6-7不支持:after,兼容性问题
父级双伪元素
结构语义化正确
由于IE6-7不支持:after,兼容性问题
后面两种伪元素清除浮动,大家暂且会使用就好, 深入原理,我们后面学完伪元素再讲。
3. Photoshop 切图
常见的图片格式
1. jpg图像格式:
JPEG(.JPG)对色彩的信息保留较好,高清,颜色较多,我们产品类的图片经常用jpg格式的
2. gif图像格式:
GIF格式最多只能储存256色,所以通常用来显示简单图形及字体,但是可以保存透明背景和动画效果
3. png图像格式
是一种新兴的网络图形格式,结合了GIF和JPEG的优点,具有存储形式丰富的特点,能够保持透明背景
4. PSD图像格式
PSD格式是Photoshop的专用格式,里面可以存放图层、通道、遮罩等多种设计草稿。可以复制文字,测量距离
PS切图 可以 分为 利用ps图层切图、利用切片工具切图以及 利用PS的插件快速切图。
1). PS
ps切图片,分两种方法:
方法一:用ps图层切图
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-F6EPthsf-1627969734302)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625318635995.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WZtBrUml-1627969734302)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625318558717.png)]
方法二:PS切片工具
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4tQ92xWb-1627969734303)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day04/%E7%AC%94%E8%AE%B0/media/1498466173246.png)]
- 利用切片工具手动划出
- 文件菜单 – 存储为web设备所用格式 ---- 选择图片格式 ---- 点存储 — 别忘了点选中的切片
辅助线和切片使用及清除
视图菜单-- 清除 辅助线/ 清除切片
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UdH3MrAj-1627969734303)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625320592216.png)]
2). 切图插件
Cutterman是一款运行在photoshop中的插件,能够自动将你需要的图层进行输出, 以替代传统的手工 “导出web所用格式” 以及使用切片工具进行挨个切图的繁琐流程。 它支持各种各样的图片尺寸、格式、形态输出,方便你在pc、ios、Android等端上使用。 它不需要你记住一堆的语法、规则,纯点击操作,方便、快捷,易于上手。
-------------------------------------------------------------
第五天 1. 学成在线页面制作
目标
- 理解
- 能够说写单页面我们基本的流程
- 能说出常见的css初始化语句
- 能说出我们CSS属性书写顺序
- 应用
- 能利用ps切图
- 能引入外部样式表
- 能把psd文件转换为html页面
学成在线的目的就是为了串联前面的所有知识。来一个春晚大联欢。
pink老师:
取义学有所成,为师之期望,君等成才者也,故曰学成网是也~~
1.1 前期准备素材
- 学成在线PSD源文件
- 开发工具 = PS(切图) + sublime(代码) + chrome(测试)
1.2 前期准备工作
欲先善其事,必先利其器。 先把我们的前期准备工作做好, 我们本次采取结构与样式相分离思想。
-
创建 study 目录文件夹 (用于存放我们这个页面的相关内容)
-
study目录内新建images 文件夹 用于保存图片。
-
新建index.html 首页html 文件(以后我们的网站首页统一规定为index.html)
-
新建style.css 样式文件。 我们本次采用外链样式表。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-S61x4lY9-1627969734304)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625402708969.png)]
-
将样式引入到我们HTML页面文件中。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Z6c0mWYI-1627969734304)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625402561853.png)]
-
样式表(style.css文件)写入 清除内外边距样式(padding:0 margin:0),来检测样式表是否引入成功。
1.2 CSS属性书写顺序(重点)
建议遵循以下顺序:
- 布局定位属性:display / position / float / clear / visibility / overflow(建议 display 第一个写,毕竟关系到模式)
- 自身属性:width / height / margin / padding / border / background
- 文本属性:color / font / text-decoration / text-align / vertical-align / white- space / break-word
- 其他属性(CSS3):content / cursor / border-radius / box-shadow / text-shadow / background:linear-gradient …
.jdc {
/*第一层:涉及布局、模式等*/
display: block;
position: relative;
float: left;
/*第二层:涉及盒子宽高、边距等自身属性*/
width: 100px;
height: 100px;
margin: 0 10px;
padding: 20px 0;
/*第三层:涉及文本字体等*/
font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
color: #333;
/*第一层:涉及CSS3内容*/
background: rgba(0,0,0,.5);
border-radius: 10px;
}
1.3 布局流程
为了提高网页制作的效率,布局时通常有以下的布局流程,具体如下:
1、必须确定页面的版心(可视区), 我们测量可得知。
2、分析页面中的行模块,以及每个行模块中的列模块。页面布局为第一准则
3、制作HTML结构。我们还是遵循,先有结构,后有样式的原则。结构永远最重要。
4、然后开始运用盒子模型的原理,通过DIV+CSS布局来控制网页的各个模块。
1.4 页面制作
这个页面的版心是 1200像素 每个版心都要水平居中对齐,所以,我们干脆把版心定义为:
.w {
width: 1200px;
margin: auto;
}
1) 头部制作
结构图如下:
- 1号是版心盒子header 1200 * 42 的盒子水平居中对齐, 上下给一个margin值就好了。
- 版心盒子 里面包含 2号盒子 logo
- 版心盒子 里面包含 3号盒子 nav导航栏
- 版心盒子 里面包含 4号盒子 search搜索框
- 版心盒子 里面包含 5号盒子 user个人信息
- 注意,要求里面的 4个盒子 必须都浮动
2)banner制作
结构图如下:
- 1号盒子是通栏的大盒子banner, 不给宽度,给高度,给一个蓝色背景。
- 2号盒子是版心, 要水平居中对齐。
- 3号盒子版心内,左对齐 subnav侧导航栏。
- 4号盒子版心内,右对齐 course 课程。
3)课程表模块
结构图如下:
- 1号盒子 是 228 * 300 的盒子 右浮动 注意 浮动的元素 不会有外边距塌陷的问题
- 1号盒子内 分为 上下 两个 子盒子
- 2号子盒子是 上部分 我们命名为 course-hd (hd 是 head 的简写 头部的意思,我们经常用)
- 3号子盒子是 下部分 我们命名为 course-bd (bd 是 body 的简写 主体的意思,我们经常用)
4)精品推荐小模块
结构图如下:
- 复习点: 因为里面三个盒子都要垂直居中,我们利用 继承性,给 最大的盒子 一个垂直居中的代码就好了,还记得 那些 样式可以继承吗??? font- line- text- color
- 大盒子水平居中 goods 精品 ,注意此处有个盒子阴影
- 1号盒子是标题 H3 左侧浮动
- 2号盒子 里面放链接 左侧浮动 goods-item 距离可以控制链接的 左右外边距(注意行内元素只给左右内外边距)
- 3号盒子 右浮动 mod 修改
5)精品推荐大模块
结构图如下:
- 1号盒子为最大的盒子 box 版心水平居中对齐
- 2号盒子为上面部分 box-hd – 里面 左侧标题H3 左浮动 右侧 链接 a 右浮动
- 3号盒子为底下部分 box-bd — 里面是无序列表 有 10个 小li 组成
- 小li 外边距的问题, 这里有个小技巧。 给box-hd 宽度为 1215 就可以一行装开5个 li了
- 复习点: 我们用到清除浮动 因为 box-hd 里面的盒子个数不一定多少,我们就不给高度了,但是里面的盒子浮动了, 影响下面的布局,此时需要浮动
6) 底部模块制作
结构图如下:
- 1号盒子通栏大盒子 底部 footer 给高度 底色是白色
- 2号盒子版心水平居中
- 3号盒子版权 copyright 左对齐
- 4号盒子 链接组 links 右对齐
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MTqYTf74-1627969734305)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625482842433.png)]
2效果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LqVrKVyC-1627969734306)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625744631924.png)]
3 代码
html部分
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>学成在线首页title>
<link rel="stylesheet" href="style.css">
head>
<body>
<div class="header w">
<div class="logo">
<img src="images/logo.png" alt="">
div>
<div class="nav">
<ul>
<li><a href="http://www.baidu.com">首页a>li>
<li><a href="#">课程a>li>
<li class="three"><a href="#">职业规划a>li>
ul>
div>
<div class="search">
<input type="text" value="输入关键字">
<button>button>
div>
<div class="user">
<img src="images/user.png" alt="">
qq-leishui
div>
div>
<div class="banner">
<div class="w">
<div class="subnav">
<ul>
<li><a href="#">前端开发<span>>span>a>li>
<li><a href="#">后端开发<span>>span>a>li>
<li><a href="#">移动开发<span>>span>a>li>
<li><a href="#">人工智能<span>>span>a>li>
<li><a href="#">商业预测<span>>span>a>li>
<li><a href="#">云计算&大数据<span>>span>a>li>
<li><a href="#">运维&测试<span>>span>a>li>
<li><a href="#">UI设计<span>>span>a>li>
<li><a href="#">产品<span>>span>a>li>
ul>
div>
<div class="course">
<h3>我的课程表h3>
<div class="bd">
<ul>
<li>
<h4>
<a href="#">继续学习 程序语言设计a>
h4>
<p>正在学习-使用对象p>
li>
<li>
<h4>
<a href="#">继续学习 程序语言设计a>
h4>
<p>正在学习-使用对象p>
li>
<li>
<h4>
<a href="#">继续学习 程序语言设计a>
h4>
<p>正在学习-使用对象p>
li>
<li class="last">
<a href="#">全部课程a>
li>
ul>
div>
div>
div>
div>
<div class="goods w">
<h3>精品推荐h3>
<ul>
<li><a href="#">JQuerya>li>
<li><a href="#">Sparka>li>
<li><a href="#">MySQLa>li>
<li><a href="#">JavaWeba>li>
<li><a href="#">Pythona>li>
<li><a href="#">Vuea>li>
ul>
<a href="#" class="mod">修改兴趣a>
div>
<div class="box w">
<div class="box-hd">
<h3>精品推荐h3>
<a href="#">查看全部a>
div>
<div class="box-bd">
<ul>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic2.png" alt="" class="pic">
<img src="images/new.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic3.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
<li>
<a href="#" class="adv—pic">
<img src="images/pic.png" alt="" class="pic">
<img src="images/hot.png" alt="" class="hot">
<h4>Think PHP 5.博客系统实战项目演练h4>
a>
<p>
<span>高级span>
• 1125人在学习
p>
li>
ul>
div>
div>
<div class="footer">
<div class="w">
<div class="copyright">
<img src="images/logo.png" alt="">
<p>
学成在线致力于普及中国最好的教育它与中国一流大学和机构合作提供在线课程。<br>
© 2017年XTCG Inc.保留所有权利。-沪ICP备15025210号
p>
<a href="#">下载APPa>
div>
<div class="links">
<dl>
<dt>关于学成网dt>
<dd><a href="#">如何注册a>dd>
<dd><a href="#">如何选课a>dd>
<dd><a href="#">如何拿到毕业证a>dd>
<dd><a href="#">学分是什么a>dd>
<dd><a href="#">考试未通过怎么办a>dd>
dl>
<dl>
<dt>关于学成网dt>
<dd><a href="#">如何注册a>dd>
<dd><a href="#">如何选课a>dd>
<dd><a href="#">如何拿到毕业证a>dd>
<dd><a href="#">学分是什么a>dd>
<dd><a href="#">考试未通过怎么办a>dd>
dl>
<dl>
<dt>关于学成网dt>
<dd><a href="#">如何注册a>dd>
<dd><a href="#">如何选课a>dd>
<dd><a href="#">如何拿到毕业证a>dd>
<dd><a href="#">学分是什么a>dd>
<dd><a href="#">考试未通过怎么办a>dd>
dl>
div>
div>
div>
body>
html>
css部分
* {
padding: 0;
margin: 0;
}
/* 每一个盒子版心都是居中对齐,宽度一致,所以可以用公类 */
.w {
width: 1200px;
margin: auto;
}
li {
list-style: none;
}
a {
text-decoration : none;
}
body {
background-color: #f3f5f7;
height: 3000px;
}
/* ----------------------------------------------------------------------------------------------------------------------------------- */
/* 标题栏开始 */
.header {
height: 42px;
/* background-color: pink; */
margin: 30px auto;
}
.logo {
width: 198px;
height: 42px;
float: left;
}
/* 导航栏 */
.nav {
float: left;
/* width: 343px; */
height: 42px;
margin-left: 67px;
}
.nav ul li {
/* background-color: plum; */
height: 42px;
line-height: 42px;
float: left;
margin-right: 26px;
}
.nav ul li a {
display: block;
/* width: 54px;无需指定a的宽度 */
height: 42px;
padding: 0 9px; /*用padding将a撑大!!*/
color: #050505;
font-size: 18px;
text-align: center;
}
.nav ul li a:hover {
border-bottom: 3px solid #00a4ff ; /*!!*/
}
/* search搜索模块 */
.search {
width: 412px;
height: 42px;
/* border:1px solid #00a4ff; */
float: left;
margin-left: 50px;
/* border: 1px solid red; */
}
.search input {
width: 340px;
height: 40px; /* input是行内块元素,可以设置宽高*/
border: 1px solid #00a4ff;
border-right: 0;
color: #bfbfbf;
font-size: 14px;
margin: 0;
border-radius: 0;
padding-left: 20px; /* input是行内块元素,有块元素属性 */
float: left;
}
.search button {
width: 50px;
height: 42px;
background-color: rgb(175, 43, 43);
/* 按钮的边框需要手动去掉 */
border: 0;
border-radius: 0;
/* 如果input和button不加浮动,那么因为这两个都是行内块元素,中间存在缝隙,会导致button放不下掉下来 */
float: left;
background: url(images/fa-search.png); /* 这里如果将图片设置为链接a的话,会使得图片和button对不齐 */
}
/* 用户模块 ,后面再优化*/
.user {
padding: 5px 30px;
float: left;
height: 32px;
line-height: 10px;
font-size: 14px;
color: #666;
}
/* 标题栏结束 */
/* ------------------------------------------------------------------------------------------------------------------------------ */
/* banner部分开始 */
/* 最大的蓝底盒子 */
.banner {
height: 420px;
width: 100%;
background-color:#033db2;
/* float: left; */
}
/* 中间的版心盒子 */
.banner .w {
height: 421px;
width: 1200px;
background-color: #00a4ff;
background :url(images/banner2.png) no-repeat top center;
}
/* 版心盒子中左边的侧边栏子盒子 */
.banner .w .subnav {
width: 190px;
height: 395px;
/* background-color: rgb(167, 86, 86); */
padding: 12px 0;
background: rgba(14, 13, 13,.4);
/* background: url(images/transprent.png); */
float: left;
}
/* 下面这两步多看看思路 */
.banner .subnav ul li {
height: 45px;
line-height: 45px;
padding: 0 20px; 左右边距,因为li没有定义宽度(和父亲subnav一样宽),所以加了padding后不会撑大盒子
}
.banner .subnav a {
font-size: 14px;
text-decoration: none;
color: cornsilk;
display:block;
}
.banner .subnav a:hover {
color: #00b4ff;
}
.banner .subnav ul li:hover {
background-color: rgba(0, 195, 250, 0.6);
}
.banner .subnav ul li span {
float: right;
}
/* 版心盒子右边课程表 */
.course {
width: 230px;
height: 300px;
/* background-color: rgb(225, 65, 177); */
float: right;
margin-top: 50px; /*浮动的盒子不会有外边距合并的问题*/
}
.banner .course h3 {
height: 45px;
/* h是块级元素 */
font-size: 18px;
color: seashell;
background-color: #9bceea;
font-weight: 700;
text-align: center;
line-height: 48px;;
}
.banner .course .bd {
height: 240px;
background-color: #ffffff;
padding: 0 20px;
}
.course .bd ul li {
padding:12px 0;
border-bottom: 2px solid #efefef ;
}
.course .bd ul li h4 {
font-size: 14px;
color: #080808;
font-weight: 400;
}
.course .bd ul li p {
color: #ababab;
font-size: 12px;
}
.course .bd ul li a:hover {
color: #11aaff;
}
.course .bd ul .last {
font-size: 16px;
font-weight: 700;
border-bottom: 0;
border :2px solid #11aaff;
text-align: center;
padding: 10px 0;
margin-top: 5px;
}
.course .bd ul .last a {
color: #11aaff;
}
/* banner部分结束 */
/* ------------------------------------------------------------------------------------------------------------------------- */
/* goods部分开始 */
.goods {
height: 60px;
margin-top: 10px;
background-color: #ffffff;
/* 添加阴影 */
box-shadow: 0 2px 3px rgba(0,0,0,.1);
line-height: 60px;
/* 行高会继承给三个孩子 */
}
.goods h3 {
font-size: 16px;
color: #00a4ff;
width: 133px;
text-align: center;
float: left;
}
.goods ul {
float: left;
}
.goods ul li {
float: left;
}
.goods ul li a {
font-size: 16px;
color: #050505;
font-family: "Microsoft Yahei";
text-align: center;
padding: 0 35px;
border-left: 1px solid #bfbfbf;
/* 注意padding和border都是加在a上 不是加在li上!! */
}
.goods ul li a:hover {
color: rgb(233, 119, 37);
}
.mod {
float: right;
margin-right: 26px;
color: #00a4ff;
font-size: 14px;
}
.mod:hover {
color: salmon;
}
/* goods部分结束 */
/* -------------------------------------------------------------------------------------------------------------------- */
/* 精品推荐部分开始 */
.box {
height: 600px;
margin-top: 37px;
}
.box .box-hd {
height: 25px;
}
.box .box-hd h3 {
float: left;
font-size: 20px;
color: #494949;
}
.box .box-hd a {
float: right;
margin-top: 10px;
margin-right: 31px;
font-size: 12px;
color: #a5a5a5;
}
.box .box-hd a:hover {
color: salmon;
}
.box .box-bd {
float: left;
}
/* 对十个精品推荐的盒子设置 */
.box-bd ul li {
width: 228px;
height: 271px;
margin-top: 15px;
margin-right: 15px;
float: left;
background-color:#ffffff;
}
/* 第五第十个消除右边距
.box .box-bd ul .rec {
margin-right: 0;
}*/
/* 如果页面中盒子很多那么一个个消除页边距很麻烦,可以把li的父亲ul修改得足够宽,一行能装开5个盒子就不会换行了,
虽然ul会多出一块,右边盒子的右边距也多出来,但是透明的看不见,如下:*/
.box .box-bd ul {
width: 1225px;
}
/* 精品推荐盒子阴影 */
.box-bd ul li:hover {
box-shadow: 0 2px 2px 2px rgba(0,0,0,.1);
}
.box-bd ul li .pic {
/* 因为图片宽度比盒子要大,所以要让图片匹配到盒子里 */
width: 100%;
float: left;
}
.box-bd ul li .hot {
float: right;
margin-top: -145px;
margin-right: -4px;
}
.box-bd ul li h4 {
margin: 20px 20px 20px 25px;
color: #050505;
font-size: 14px;
font-weight: 400;
font-family: "微软雅黑";
float: left;
}
.box-bd ul li h4:hover {
color: tomato;
}
.box-bd ul li a {
background-color:#ffffff;
}
.box-bd ul li p {
font-size: 12px;
color :#999999;
font-family: "微软雅黑";
margin: 0 20px 0 25px;
float: left;
}
.box-bd ul li span {
color :#ff7c2d
}
/* 精品推荐部分结束 */
/* ---------------------------------------------------------------------------------------------------------------------- */
/* footer部分 */
.footer {
height: 415px;
background-color: #fcfffb;
margin-top: 20px;
}
.footer .w {
padding-top: 35px;
}
.footer .copyright {
width: 472px;
height: 190px;
/* background-color: tomato; */
float: left;
margin-left: 18px;
}
.footer .copyright img {
margin-bottom: 10px;
}
.footer .copyright p {
font-size :12px;
font-family: "SongTi";
color: #666666;
}
.footer .copyright a {
display: inline-block;
font-size: 16px;
color: #00a4ff;
margin-top: 14px;
padding: 10px 28px;
border: 1px solid #00a4ff;
}
/* -------------------------------------links部分 我的方法 */
/* .footer .links {
width: 600px;
height: 200px;
float: right;
margin-right: -80px;
}
.footer .links .A>li {
float: left;
display: inline-block;
width: 200px;
}
.footer .links .A>li h3 {
font-size: 16px;
font-weight: 400;
color: #333333;
}
.footer .links .B {
margin-top: 10px;
float: left;
}
.footer .links a {
font-size: 12px;
color: #333333;
height: 21px;
line-height: 21px;
}
.footer .links a:hover {
color: #d88820;
} */
/* footer部分结束 */
/* ------------------------------------------------------------------------------------------------------------------- */
/* 老师方法links部分 */
.links {
float: right;
margin-right: 30px;
}
.links dl {
float: left;
margin-left: 100px;
}
.links dl dt {
font-size: 16px;
color: #333;
margin-bottom: 5px;
}
.links dl dd a {
display: inline-block;
font-size: 12px;
color: #333;
margin-bottom: 5px;
}
.links dl dd a:hover {
color: salmon;
}
/* 老师方法links部分 */
4 chrome调试工具
“工欲善其事,必先利其器”
Chrome浏览器不仅可以调试页面、JS、请求、资源、cookie,还可以模拟手机进行调试。我们现在只是使用html和css,我们先讲一下现在常用的调试。
4.1 怎样打开Chrome的开发者工具?
直接在页面上点击右键,然后选择 “检查” 快捷键 F12 或者 ctrl+shift+i
基本的结构布局是左边html 右边是 css
chrome调试数值
可以鼠标点击后面的数值, 按下键盘 上箭头 是 调大 数值, 下箭头是 调小数值
快速定位css所在行数
4.2 Chrome提示的常见布局错误
1). css单词书写错误提示
用下图所示的黑色箭头,点击我们需要的 html 元素。
2). css无显示
声明类名和html调用名不一致 或者 css文件引入不对 或者 这个样式的前面 多余了一些符号影响的
3). html 结构不匹配(重要)
左侧 展开可以看到html 标签是否匹配
4). 通过颜色判断盒子
蓝色是 盒子的 宽度高度 青色是 内边距 橙色 是外边距 通过这个很方便的看到盒子给的范围
5)看看你有如下错误吗
------------------------------------------------------------
第六天
定位(position)❗❕❕‼✅
目标
- 理解
- 能说出为什么要用定位
- 能说出定位的4种分类
- 能说出四种定位的各自特点
- 能说出我们为什么常用子绝父相布局
- 应用
- 能写出淘宝轮播图布局
1. CSS 布局的三种机制
网页布局的核心 —— 就是用 CSS 来摆放盒子位置。
CSS 提供了 3 种机制来设置盒子的摆放位置,分别是普通流、浮动和定位,其中:
- 普通流(标准流)
- 浮动
- 让盒子从普通流中浮起来 —— 让多个盒子(div)水平排列成一行。
- 定位
- 将盒子定在某一个位置 自由的漂浮在其他盒子的上面 —— CSS 离不开定位,特别是后面的 js 特效。
2. 为什么使用定位
我们先来看一个效果,同时思考一下用标准流或浮动能否实现类似的效果?
1. 小黄色块在图片上移动,吸引用户的眼球。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oHaGEefw-1627969734307)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day06/%E7%AC%94%E8%AE%B0/images/03_%E5%AE%9A%E4%BD%8D%E7%A4%BA%E4%BE%8B3.png)]
2. 当我们滚动窗口的时候,盒子是固定屏幕某个位置的
结论:要实现以上效果,标准流或浮动都无法快速实现
pink老师一句话说出定位:
将盒子定在某一个位置 自由的漂浮在其他盒子(包括标准流和浮动)的上面
所以,我们脑海应该有三种布局机制的上下顺序
标准流在最底层 (海底) ------- 浮动 的盒子 在 中间层 (海面) ------- 定位的盒子 在 最上层 (天空)
3. 定位详解
定位也是用来布局的,它有两部分组成:
定位 = 定位模式 + 边偏移
3.1 边偏移
简单说, 我们定位的盒子,是通过边偏移来移动位置的。
在 CSS 中,通过 top
、bottom
、left
和 right
属性定义元素的边偏移:(方位名词)
边偏移属性
示例
描述
top
top: 80px
顶端偏移量,定义元素相对于其父元素上边线的距离。
bottom
bottom: 80px
底部偏移量,定义元素相对于其父元素下边线的距离。
left
left: 80px
左侧偏移量,定义元素相对于其父元素左边线的距离。
right
right: 80px
右侧偏移量,定义元素相对于其父元素右边线的距离
定位的盒子有了边偏移才有价值。 一般情况下,凡是有定位地方必定有边偏移。
3.2 定位模式 (position)
在 CSS 中,通过 position
属性定义元素的定位模式,语法如下:
选择器 { position: 属性值; }
定位模式是有不同分类的,在不同情况下,我们用到不同的定位模式。
值
语义
static
静态定位
relative
相对定位
absolute
绝对定位
fixed
固定定位
3.2.1 静态定位(static) - 了解
- 静态定位是元素的默认定位方式,无定位的意思。它相当于 border 里面的none, 不要定位的时候用。
- 静态定位 按照标准流特性摆放位置,它没有边偏移。
- 静态定位在布局时我们几乎不用的
3.2.1 相对定位(relative) - 重要
- 相对定位是元素相对于它原来在标准流中的位置来说的。(自恋型)
效果图:
position:relative;
top:100px;
left:100px;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZRfIj6GS-1627969734307)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625750560434.png)]
相对定位的特点:(务必记住)
-
相对于 自己原来在标准流中位置来移动的
-
原来在标准流的区域继续占有,后面的盒子仍然以标准流的方式对待它。(不脱标)
3.2.3 绝对定位(absolute) - 重要
绝对定位是元素以带有定位的父级元素来移动位置 (拼爹型)
-
完全脱标 —— 完全不占位置; **(移动后所在地仍然不占位置)**❕
-
没有父元素或父元素没有定位,则以浏览器为准定位(Document 文档)。
-
父元素要有定位
- 将元素依据最近的已经定位(绝对、固定或相对定位,不能静态定位)的父元素(祖先)进行定位。
绝对定位的特点:(务必记住)❗❗❗
-
绝对是以带有定位的最近❗的父级元素来移动位置 (拼爹型) 如果父级都没有定位,则以浏览器文档为准移动位置
(解释:如果爸爸没定位,但是爷爷有定位,则以爷爷定位为准)
-
移动后不保留原来的位置,完全是脱标的。
因为绝对定位的盒子是拼爹的,所以要和父级搭配一起来使用。
定位口诀 —— 子绝父相
刚才咱们说过,绝对定位,要和带有定位的父级搭配使用,那么父级要用什么定位呢?
子绝父相 —— 子级是绝对定位,父级要用相对定位。
子绝父相是使用绝对定位的口诀,要牢牢记住!
疑问❓:为什么在布局时,子级元素使用绝对定位时,父级元素就要用相对定位呢?
观察下图,思考一下在布局时,左右两个方向的箭头图片以及父级盒子的定位方式。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ErYKfKXk-1627969734308)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day06/%E7%AC%94%E8%AE%B0/images/07_%E5%AD%90%E7%BB%9D%E7%88%B6%E7%9B%B8%E6%88%AA%E5%9B%BE.png)]
分析:
- 方向箭头叠加在其他图片上方,应该使用绝对定位,因为绝对定位完全脱标,完全不占位置。
- 父级盒子应该使用相对定位,因为相对定位不脱标,后续盒子仍然以标准流的方式对待它。
- ❗❗如果父级盒子也使用绝对定位,会完全脱标,那么下方的广告盒子会上移,这显然不是我们想要的。
结论:父级要占有位置,子级要任意摆放,这就是子绝父相的由来。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-loFi7HfW-1627969734308)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625800089228.png)]
3.2.4 固定定位(fixed) - 重要
固定定位是绝对定位的一种特殊形式: (认死理型)
- 只认浏览器的可视窗口 ——
浏览器可视窗口 + 边偏移属性
来设置元素的位置;
- 跟父元素没有任何关系;单独使用的,可以没有父元素
- 不随滚动条滚动。
- 完全脱标 —— 完全不占位置;
案例演练:固定定位案例。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-W18JyxB5-1627969734309)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day06/%E7%AC%94%E8%AE%B0/images/08_%E5%9B%BA%E5%AE%9A%E5%AE%9A%E4%BD%8D%E6%A1%88%E4%BE%8B.png)]
补充:固定定位的盒子不一定都是以可视窗口为参考的,如何让其以版心为参考呢?
方法:离侧边距离=可视窗口50%+版心宽度50%
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IovMUUDY-1627969734310)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625801429447.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vK6dRxf6-1627969734310)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625812160352.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j5kGpeL6-1627969734310)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day06\素材\QQ录屏20210709143000.gif)]
3.2.5 粘性定位(sticky) -了解
选择器 {
position:sticky;
top:10px; 表示距离页面顶部10px的时候开始固定不动
}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8osB7jyf-1627969734311)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625812928553.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LN1WqrEA-1627969734311)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625813017489.png)]
4. 定位(position)的案例
5. 定位(position)的扩展
5.1 绝对定位的盒子居中
注意:绝对定位/固定定位的盒子不能通过设置 margin: auto
设置水平居中(相对定位可以)。
在使用绝对定位时要想实现水平居中,可以按照下图的方法:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AUwWcwk4-1627969734312)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day06/%E7%AC%94%E8%AE%B0/images/10_%E7%BB%9D%E5%AF%B9%E5%AE%9A%E4%BD%8D%E6%B0%B4%E5%B9%B3%E5%B1%85%E4%B8%AD.png)]
-
left: 50%;
:让盒子的左侧移动到父级元素的水平中心位置;
-
margin-left: -100px;
:让盒子向左移动自身宽度的一半。
但是这种方法也有局限性,如果盒子的尺寸改变的话代码也需要改变。
✔可以用CSS3中的2D平移新特新来替代,
tranform:translate(-50%,-50%);
垂直居中定位同理
这种居中方法很灵活,当浏览器窗口缩放的时候可自适应
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HR6sA4CE-1627969734313)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day06\素材\QQ录屏20210709151438.gif)]
5.2 堆叠顺序(z-index)
在使用定位布局时,可能会出现盒子重叠的情况。
加了定位的盒子,默认后来者居上, 后面的盒子会压住前面的盒子。
应用 z-index
层叠等级属性可以调整盒子的堆叠顺序。如下图所示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KuA1Oeu1-1627969734313)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day06/%E7%AC%94%E8%AE%B0/images/12_zindex%E7%A4%BA%E6%84%8F%E5%9B%BE.png)]
z-index
的特性如下:
- 属性值:正整数、负整数或 0,默认值是 0,数值越大,盒子越靠上;
- 如果属性值相同,则按照书写顺序,后来居上;
- 数字后面不能加单位。
注意:z-index
只能应用于相对定位、绝对定位和固定定位的元素,其他标准流、浮动和静态定位无效。
5.3 定位改变display属性/特殊特性
前面我们讲过, display 是显示模式, 可以改变显示模式有以下方式:
- 可以用inline-block 转换为行内块
- 可以用浮动 float 默认转换为行内块(类似,并不完全一样,因为浮动是脱标的)
- 绝对定位和固定定位也和浮动类似, 默认转换的特性 转换为行内块。
所以说, 一个行内的盒子,如果加了浮动、固定定位和绝对定位,不用转换,就可以给这个盒子直接设置宽度和高度等。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-G7ssjVnh-1627969734314)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625815579176.png)]
同时注意:
浮动元素、绝对定位(固定定位)元素的都不会触发外边距合并的问题。 (我们以前是用padding border overflow解决的)
也就是说,我们给盒子改为了浮动或者定位,就不会有垂直外边距合并的问题了。
5.4绝对定位(固定定位)会完全压住盒子
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-D63LcpoR-1627969734314)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625881000263.png)]
6. 综合演练 - 淘宝轮播图
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JnbEk5kJ-1627969734315)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625881654401.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KZChKOW7-1627969734315)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625881671086.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HkP2wAfV-1627969734316)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625896989808.png)]
"en">
"UTF-8">
"X-UA-Compatible" content="IE=edge">
"viewport" content="width=device-width, initial-scale=1.0">
Document
"tb-promo">
"images/1.jpg" alt="">
"#" class="prev"><
"#" class="next">>
"promo-nav">
- "selected">
7. 定位小结
定位模式
是否脱标占有位置
移动位置基准
模式转换(行内块)
使用情况
静态static
不脱标,正常模式
正常模式
不能
几乎不用
相对定位relative
不脱标,占有位置
相对自身位置移动
不能
基本单独使用
绝对定位absolute
完全脱标,不占有位置
相对于定位父级移动位置
能
要和定位父级元素搭配使用
固定定位fixed
完全脱标,不占有位置
相对于浏览器移动位置
能
单独使用,不需要父级
注意:
- 边偏移需要和定位模式联合使用,单独使用无效;
top
和 bottom
不要同时使用;
left
和 right
不要同时使用。
8.学成网定位总结添加
一个小技巧:
9. 网页布局总结
一个完整的网页,有标准流 、 浮动 、 定位 一起完成布局的。每个都有自己的专门用法。
1). 标准流
可以让盒子上下排列 或者 左右排列的
2). 浮动
可以让多个块级元素一行显示 或者 左右对齐盒子 浮动的盒子就是按照顺序左右排列
如果块级盒子水平显示就用浮动。
3). 定位
定位最大的特点是有层叠的概念,就是可以让多个盒子 前后 叠压来显示。 但是每个盒子需要测量数值。
如果元素自由的在某个盒子内移动就用定位布局。
-------------------------------------------------------------------
第七天
CSS高级技巧❗❕❕‼✅
目标
- 理解
- 能说出元素显示隐藏最常见的写法
- 能说出精灵图产生的目的
- 能说出去除图片底侧空白缝隙的方法
- 应用
- 能写出最常见的鼠标样式
- 能使用精灵图技术
- 能用滑动门做导航栏案例
1. 元素的显示与隐藏
-
目的
让一个元素在页面中消失或者显示出来
-
场景
类似网站广告,当我们点击关闭就不见了,但是我们重新刷新页面,会重新出现!
1.1 display 显示(重点)
-
display 设置或检索对象是否及如何显示。
display: none 隐藏对象❗❗❗❗
display:block 除了转换为块级元素之外,同时还有显示元素的意思。
-
特点: 隐藏之后,不再保留位置。
实际开发场景:
配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛❗
1.2 visibility 可见性 (了解)
-
设置或检索是否显示对象。
visibility:visible ; 对象可视
visibility:hidden; 对象隐藏
-
特点: 隐藏之后,继续保留原有位置。(停职留薪)
1.3 overflow 溢出(重点)
-
检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
选择器 {
overflow:hidden visible scroll auto;
};
属性值
描述
visible
不剪切内容也不添加滚动条
hidden
不显示超过对象尺寸的内容,超出的部分隐藏掉
scroll
不管超出内容否,总是显示滚动条
auto
超出自动显示滚动条,不超出不显示滚动条
实际开发场景:
- 清除浮动❓
- 隐藏超出内容,隐藏掉, 不允许内容超过父盒子。
1.4 显示与隐藏总结
属性
区别
用途
display❗
隐藏对象,不保留位置
配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛
visibility
隐藏对象,保留位置
使用较少
overflow
只是隐藏超出大小的部分
1. 可以清除浮动 2. 保证盒子里面的内容不会超出该盒子范围3、如果有定位的盒子慎重使用overflow功能,可能会把超出的部分隐藏掉(如学成在线hot元素)
1.5 显示与隐藏案例
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FozsCYFk-1627969734317)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day07\案例\images\diaplay.gif)]
--------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------
2. CSS用户界面样式
- 所谓的界面样式, 就是更改一些用户操作样式,以便提高更好的用户体验。
- 更改用户的鼠标样式 (滚动条因为兼容性非常差,我们不研究)
- 表单轮廓等。
- 防止表单域拖拽
2.1 鼠标样式cursor
设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
属性值
描述
default
小白 默认
pointer❗
小手
move
移动
text
文本
not-allowed
禁止
鼠标放我身上查看效果哦:
<ul>
<li style="cursor:default">我是小白li>
<li style="cursor:pointer">我是小手li>
<li style="cursor:move">我是移动li>
<li style="cursor:text">我是文本li>
<li style="cursor:not-allowed">我是禁止li>
ul>
2.2 轮廓线 outline
是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
outline : outline-color ||outline-style || outline-width
但是我们都不关心可以设置多少,我们平时都是去掉的,不好看。
最直接的写法是 : outline: 0; 或者 outline: none;
<input type="text" style="outline: 0;"/>
2.3 防止拖拽文本域resize
实际开发中,我们文本域右下角是不可以拖拽的:
<textarea style="resize: none;">textarea>
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ghr511sW-1627969734317)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625924957912.png)]
2.4 用户界面样式总结
属性
用途
用途
鼠标样式
更改鼠标样式cursor
样式很多,重点记住 pointer
轮廓线
表单默认outline
outline 轮廓线,我们一般直接去掉,border是边框,我们会经常用
防止拖拽
主要针对文本域resize
防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none
3. vertical-align 垂直对齐
- 有宽度的块级元素居中对齐,是margin: 0 auto;
- 让文字居中对齐,是 text-align: center;
但是我们从来没有讲过有垂直居中的属性。
vertical-align 垂直对齐,它只针对于行内元素或者行内块元素, 所以必要时需要转化
vertical-align : baseline |top |middle |bottom
设置或检索对象内容的垂直对其方式。
-
注意:
vertical-align 对块级元素中的内容对齐不起作用,它只针对于行内元素或者行内块元素,
特别是行内块元素, 通常用来控制图片/表单与文字的对齐。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WjFuwctn-1627969734318)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1627712091518.png)]
3.1 图片、表单和文字对齐
所以我们知道,我们可以通过vertical-align 控制图片和文字的垂直关系了。
默认的图片会和文字基线对齐。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nM8Drao5-1627969734318)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625972552023.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BxOJLIEo-1627969734319)(F:/01-03%20%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%9F%BA%E7%A1%80/02-CSS%E8%B5%84%E6%96%99/02-CSS%E8%B5%84%E6%96%99/CSS-Day07/%E7%AC%94%E8%AE%B0/media/1498467742995.png)]
也可以让文本域和文字垂直居中对齐
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0CHzWxHJ-1627969734319)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625971679314.png)]
注意:❗❗❗
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5ZvNjwGa-1627969734320)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625973399166.png)]
3.2 去除图片底侧空白缝隙
-
原因:
图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。也就是说基线和底线之间留有缝隙
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4vlIZkTe-1627969734320)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625973735726.png)]
-
解决的方法就是:
-
给img vertical-align:middle | top| bottom等等。 让图片不要和基线对齐。(推荐)
-
给img 添加 display:block; 转换为块级元素就不会存在问题了。但是只能写在一行了。(不推荐)
4. 溢出的文字省略号显示
4.1 单行文字省略显示
/三部曲/
1 .white-space:强制一行显示
- white-space设置或检索对象内文本显示方式。通常我们使用于强制一行显示内容
white-space:normal ;默认处理方式,一行显示不开自动换行 ❌
white-space:nowrap ; 强制在同一行内显示所有文本,直到文本结束或者遭遇br标签对象才换行。✔
2. 超出的部分隐藏
overflow:hidden
3. text-overflow 溢出用省略号显示
- 设置或检索是否使用一个省略标记(…)标示对象内文本的溢出
text-overflow : clip ;不显示省略标记(...),而是简单的裁切 ❌
text-overflow:ellipsis ; 当对象内文本溢出时显示省略标记(...) ✔
注意:
❗❗一定要首先强制一行内显示,再次和overflow属性 搭配使用
4. 总结三步曲
/*1. 先强制一行内显示文本*/
white-space: nowrap;
/*2. 超出的部分隐藏*/
overflow: hidden;
/*3. 文字用省略号替代超出的部分*/
text-overflow: ellipsis;
4.2 多行文字溢出省略号显示
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ogRIPDxa-1627969734321)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626002775847.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sWJnNbiF-1627969734321)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626002923395.png)]
5. CSS精灵技术(sprite) 重点
5.1 为什么需要精灵技术
图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展现给用户。
然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。
pink老师告诉你我们为什么需要精灵技术:
为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度,减小服务器压力。
出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。
5.2 精灵技术讲解
CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图。
这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。
我们需要使用CSS的
- background-image、
- background-repeat
- background-position属性进行背景定位,
- 其中最关键的是使用background-position❗ 属性精确地定位。
5.3 精灵技术使用的核心总结
首先我们知道,css精灵技术主要针对于背景图片,插入的图片img 是不需要这个技术的。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lij3nrEH-1627969734322)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625903968318.png)]
5.4 制作精灵图(了解)
CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图。
大部分情况下,精灵图都是网页美工做。
我们精灵图上放的都是小的装饰性质的背景图片。 插入图片不能往上放。
我们可以横向摆放也可以纵向摆放,但是每个图片之间留有适当的空隙
在我们精灵图的最低端,留一片空隙,方便我们以后添加其他精灵图。
结束语: 小公司,背景图片很少的情况,没有必要使用精灵技术,维护成本太高。 如果是背景图片比较多,可以建议使用精灵技术。
5.5 精灵图网页显示方法
1、选中要展示的部分,测量盒子尺寸参数和坐标参数(FW/PS)
2、制作盒子(尺寸根据参数确定),放进制作好的精灵图(默认会在盒子的左上角显示)
3、根据坐标对精灵图进行移动,则可显示出来目标图像
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HlSGMqZY-1627969734322)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625904570030.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZkjcGOYL-1627969734323)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625907092144.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Lj9wuH9g-1627969734323)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625904905576.png)]
6.字体图标
6.1字体图标的好处
像精灵图毕竟是张大图片,体量比较大,有的小图标可以用字体图标来做,有字体的属性,如大小,颜色,阴影等等,
字体图标使用场景︰主要用于显示网页中通用、常用的一些小图标
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bROoCQok-1627969734324)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625907805600.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eJid95VD-1627969734324)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625907861466.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9RxECRTp-1627969734325)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625907956950.png)]
6.2 字体图标的下载(矢量图)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-toSxWavr-1627969734325)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625908897486.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LWD9U1OB-1627969734326)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625908918801.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R6xotyLE-1627969734326)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625908788334.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c6dfF9JA-1627969734327)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625908938814.png)]
6.3字体图标的使用(四部曲)
1、先把fonts文件夹放在页面根目录下
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-auZyVecS-1627969734327)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625909823736.png)]
2、 引入字体图标(将下载的压缩包里的style.css文件用vscode打开然后复制 @font-face声明)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5UFbeDc0-1627969734328)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625910459525.png)]
@font-face {
font-family: 'icomoon';
src: url('fonts/icomoon.eot?75p0ri');
src: url('fonts/icomoon.eot?75p0ri#iefix') format('embedded-opentype'),
url('fonts/icomoon.ttf?75p0ri') format('truetype'),
url('fonts/icomoon.woff?75p0ri') format('woff'),
url('fonts/icomoon.svg?75p0ri#icomoon') format('svg');
font-weight: normal;
font-style: normal;
}
!引入到css文件中
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5Ic5hwgR-1627969734329)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625909801698.png)]
3、复制图标(body中)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8FNoCrUh-1627969734329)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625910677917.png)]
4、引入样式(style中)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LbL7neQU-1627969734330)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625920284088.png)]
6.4字体图标的追加和加载原理
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EYwp8zqI-1627969734330)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625920925705.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PZhRdlhp-1627969734331)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625921060233.png)]
7. 滑动门
先来体会下现实中的滑动门,或者你可以叫做推拉门:
滑动门出现的背景
制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋办?
为了使各种特殊形状的背景能够自适应元素中文本内容的多少,出现了CSS滑动门技术。它从新的角度构建页面,使各种特殊形状的背景能够自由拉伸滑动,以适应元素内部的文本内容,可用性更强。 最常见于各种导航栏的滑动门。
http://weixin.qq.com/
核心技术
核心技术就是利用CSS精灵(主要是背景位置)和 盒子padding撑开宽度, 以便能适应不同字数的导航栏。
一般的经典布局都是这样的:
<li>
<a href="#">
<span>导航栏内容span>
a>
li>
css样式
* {
padding:0;
margin:0;
}
body{
background: url(images/wx.jpg) repeat-x;
}
.father {
padding-top:20px;
}
li {
padding-left: 16px;
height: 33px;
float: left;
line-height: 33px;
margin:0 10px;
background: url(./images/to.png) no-repeat left ;
}
a {
padding-right: 16px;
height: 33px;
display: inline-block;
color:#fff;
background: url(./images/to.png) no-repeat right ;
text-decoration: none;
}
li:hover,
li:hover a {
background-image:url(./images/ao.png);
}
总结:
- a 设置 背景左侧,padding撑开合适宽度。
- span 设置背景右侧, padding撑开合适宽度 剩下由文字继续撑开宽度。
- 之所以a包含span就是因为 整个导航都是可以点击的。
8.CSS三角形
网页中常见一些三角形,使用CSS直接画出来就可以,不必做成图片或者字体图标
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DeistAEB-1627969734331)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625921294589.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ht27N7ah-1627969734332)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625921475507.png)]
如何制作三角形?
答:将一个边框颜色设为有色,其余为透明
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HO8mNKOE-1627969734333)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625922498729.png)]
练习:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zUw3A0KU-1627969734334)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1625923670739.png)]
9. 布局技巧
9.1 margin负值的巧妙运用
1). 负边距+定位:水平/垂直居中
咱们前面讲过, 一个绝对定位的盒子, 利用 父级盒子的 50%, 然后 往左(上) 走 自己宽度的一半 ,可以实现盒子水平/垂直居中。
2). 压住盒子相邻边框
- 有边框的盒子排列时会出现两个盒子之间的边框加粗的情况
- 给右面的盒子添加
margin-left: -1px;
右面的边框压住左面的边框,从而解决这个问题
-
但是,如果想要实现把鼠标放在其中一个盒子上,盒子边框改变颜色,要是按照上面的方法,改完的盒子会出现被压住的一边没有办法改变颜色的情况
-
解决方法:
-
给要变色的盒子添加相对定位,然后盒子就会压住其他盒子(因为相对定位既不脱标,默认的z值又高于标准流所以边框能显示 )
ul li {
假设没有定位
}
ul li:hover {
position:relative 则加上相对定位
border:1px solid blue
}
-
如果盒子已经有定位则用z-index提高层级
ul li {
假设有了定位,如:
position:relative;
}
ul li:hover {
z-index:1; 则添加优先级
border:1px solid blue;
}
9.2 文字围绕浮动元素
-
根据浮动不会压住文字的特性,既有图片又有文字只需要在左侧图片添加浮动,在大盒子里面写上文字就可以
-
文字会和盒子一样宽 因此会环绕图片
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xKkSNz9o-1627969734334)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626009615784.png)]
-
代码实例:
"box">
"pic">
"l.jpg" alt="">
集锦 热身赛-巴西秘鲁 内马尔替补两人血两人血染赛场锦 热身赛-巴西秘鲁场
9.3巧用行内块元素布局
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-t1oJy3mh-1627969734335)(F:\01-03 前端开发基础\02-CSS资料\02-CSS资料\CSS-Day07\笔记\media\是.gif)]
* {
margin: 0;
padding: 0;
}
a {
text-decoration: none;
}
.box {
width: 1000px;
height: 30px;
margin: 100px auto;
text-align: center;
}
.box a {
display: inline-block;
background-color: #f7f7f7;
border: 1px solid #ccc;
color: rgb(18, 19, 19);
width: 36px;
height: 36px;
text-align: center;
line-height: 36px;
font-size: 14px;
}
.box .prev,
.box .next {
width: 100px;
}
.box input {
height: 36px;
width: 45px;
border: 1px solid #ccc;
outline: none;
}
.box button {
width: 60px;
height: 36px;
background-color: #f7f7f7;
border: 1px solid #ccc;
}
.box a:hover {
background-color: #ccc;
}
.box button:hover {
background-color: #ccc;
}
"box">
"#" class="prev"><<上一页
"#">1
"#">1
"#">3
"#">4
"#">5
"#">6
"#">7
"#">...
"#" class="next">下一页>>
到第
"text">
页
9.4 CSS三角巧妙运用
css除了能做简单的等腰直角三角形,也能做一些尺寸不定的三角形,步骤如下:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-avR0Uthr-1627969734335)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626072264270.png)]
案例:京东价格条
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VXos2ZiF-1627969734336)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626087773645.png)]
"box">
"now-price">¥299.00
"triangle">
"origin-price">¥400.00
9.5CSS的初始化
- 不同浏览器对某些标签的默认值是不同的,为了消除不同浏览器对html文本呈现的差异,照顾浏览器的兼容性。
- 简单理解:重设浏览器的样式(也称为CSS)
- 京东初始化代码:
* {
margin: 0;
padding: 0;
}
em,
i {
/* 清除斜体 */
font-style: normal;
}
li {
list-style: none;
}
img {
/* 为了兼容低版本浏览器,否则在图片上有链接的话会出现边框(和图片周围文字一个原理) */
border: 0;
/* 取消图片底侧有空白缝隙的问题*/
vertical-align: middle;
}
button {
/* ,定义当鼠标经过button的时候变成小手,否则button上不会出现小手 */
cursor: pointer;
}
a {
color: #666;
text-decoration: none;
}
a:hover {
color: #c81623;
}
button,
input {
font-family: Microsoft YaHei, Heiti SC, tahoma, arial, Hiragino Sans GB, "\5B8B\4F53", sans-serif;
/* \5B8B\4F53 的是宋体的unicode的编码,写汉字的话容易出现乱码 */
}
body {
/*CSS3写法 :抗锯齿性,让文字显示更加清晰 */
-webkit-font-smoothing: antialiased;
background-color: #fff;
font: 12px/1.5 Microsoft YaHei, Heiti SC, tahoma, arial, Hiragino Sans GB, "\5B8B\4F53", sans-serif;
color: #666;
}
.hide,
.none {
display: none;
/* 隐藏 */
}
/* 清除浮动 */
.clearfix:after {
visibility: hidden;
clear: both;
display: block;
content: ".";
height: 0;
}
.clearfix {
*zoom: 1;
}
------------------------------------------------
第八天 新特性
HTML5新特性
tips:广义的HTML5: HTML5本身+CSS3+JavaScript
- 有兼容性的问题,基本上在IE9以上才能使用
1.HTML5新增语义化标签
-
终结了所有盒子都叫div
-
新增标签:
-
标签
描述
头部标签
导航标签
内容标签
定义文档某个区域
侧边栏标签
尾部标签
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n7h1ATe6-1627969734337)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626140099302.png)]
注意:
- 这种语义化标准主要是针对搜索引擎的
- 这些新标签页面中可以使用多次
- 在 IE9 中,需要把这些元素转换为块级元素
- 其实,我们移动端更喜欢使用这些标签
- HTML5 还增加了很多其他标签,我们后面再慢慢学
2.HTML5新增的多媒体标签
新增的多媒体标签主要包含两个:
- 音频:
- 视频:
使用它们可以很方便的在页面中嵌入音频和视频,而不再去使用 flash 和其他浏览器插件。
2.1视频标签
- 只支持mp4,webm,ogg,尽量使用MP4格式,支持的浏览器最多
- 语法规范:
<video src="文件地址" controls="controls">video>
"controls" width="300">
/*考虑到兼容性问题,可以写成以下几种格式(程序执行成功后直接跳出)*/
- 属性值:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-syMAtsaa-1627969734337)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141629907.png)]
2.2音频标签
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DIxXHrMT-1627969734338)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141799036.png)]
-
支持音频格式:mp3(支持的最多) ,wav,ogg
-
语法规范:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-owNqSiYg-1627969734338)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626141961939.png)]
-
google禁用音频只能通过js来解决
2.3总结
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-poaz2u4g-1627969734339)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626142669350.png)]
3.HTML5新增的input表单
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-se3xn3zb-1627969734339)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626143720198.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-NgHeyI8L-1627969734340)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145254529.png)]
注:如果用手机打开链接,则会适配手机显示和输入格式
4.HTML5新增的表单属性
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qEB2P0Ma-1627969734340)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145636165.png)]
- multiple:
- required属性可以实现 在空文本提交时系统会报错
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8S7w0q0E-1627969734341)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626145916567.png)]
-
更改placeholder里文字的颜色:
input::placeholder { 伪元素,后面解释
color: skyblue;
}
------------------------------------------------
CSS3新特性
- 兼容性:IE9以上支持
- 移动端优于pc端
1.CSS3新增选择器
- 属性选择器
- 结构伪类选择器
- 伪类选择器
1.1属性选择器 [ ](权重为10)
- 选择元素有某个属性的标签
- 注意:属性选择器权重为10 (方括号内的才算属性选择器)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nTCZWCds-1627969734341)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626147008784.png)]
- 代码案例:
"text" value="请输入用户名">
"text">
"text" value="select">
选择属性值开头或结尾的某些元素
div[class$=icon] { /*注意:这一行中,div标签选择器权重为1,属性选择器权重为10,所以一共是11*/
color: grey;
}
选择某些属性值结尾的某些元素
div[class$=icon] {
color: grey;
}
选择值里面有这个文字的元素
div[class*=icon] {
color: green;
}
1.2伪类结构选择器(权重为10)
- 权重为10
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TPTtqTHE-1627969734341)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626161960871.png)]
child类型
-
-
-
-
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8oFhMZq8-1627969734342)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626162087846.png)]
-
实例:隔行变色
-
用到nth-child里的关键字 even-偶数 odd-奇数
ul li:nth-child(odd) {
background-color: grey;
}
-
nth-child里面的公式 如果n是公式,则会从0开始计算,每次加一,但是第0个元素和超出的元素个数会被忽略
ul li:nth-child(n) { 相当于选择了所有的孩子
background-color: grey;
}
-
注意:只能用n这个字母,但是可以使用加减乘除常数
of-type类
- child类:
- nth-child会把所有盒子排序
- 然后先看nth-child(1)找到那个元素,然后再看前面它指定的标签,如果这两个不匹配,那么这个样式就不显现
- of-type类:
- nth-of-type(1)会把指定元素排序
- 然后再把指定元素的第一个元素赋予样式,所以不存在前后样式不匹配的问题
即:
section div:nth-child(1) {
background-color:blue
}
section div:nth-of-type(1) {
background-color:blue
}
光头强
熊大
熊二
如果用nth-child,则排序后发现第一个元素是光头强,但是其标签为p与div不符,所以什么也不显示;
如果用nth-of-type ,则直接将div排序,将第一个元素熊大指定目标样式
1.3伪元素选择器 ❗❗(权重为1)
伪元素选择器可以帮助我们利用CSS创建模拟新标签元素,而不需要HTML嵌套多层标签,从而简化HTML结构。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DCBntXTV-1627969734343)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626165084080.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mod8fORW-1627969734343)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626165048984.png)]
div::before { 这个权重是1+1=2
color: skyblue;
content: ''; /* 必须书写的属性 */
}
- 元素和::不能有空隙
- 因为伪元素选择器创建出来的是行内元素,所以要想实现更改尺寸,需要转换为行内块
伪元素选择器使用场景-1
配合字体图标
"fake">
伪元素选择器使用场景-2
仿土豆效果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8E1olm7a-1627969734344)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626181527778.png)]
"tudou">
"1.jpg" alt="" class="pic">
伪元素选择器使用场景-3
伪元素清除浮动,无需结构里再插入盒子,html结构更简单
after伪元素法
- 相当于额外标签法的升级版
- 语法规范:
.clearfix:after {
content: ""; 伪元素必须写的属性
display: block; 伪元素插入的元素必须是块级元素
height: 0px; 不要看见这个元素
clear: both; 清除浮动核心代码
visibility: hidden; 不要看见这个元素
}
.clearfix {
/* I6,I7专有 */
*zoom: 1;
}
双伪元素清除浮动 (最常使用)
.clearfix:before,.clearfix:after {
content:"";
display:table;
/* 如果写display:block的话两个块元素就会分行显示,影响父盒子大小 */
/* table是表格,转化成块级元素并同行显示 */
}
.clearfix:after {
clear:both;
}
.clearfix {
*zoom:1;
}
-
原来的盒子增加border,padding会撑大盒子
-
CSS3解决了这个问题!
-
语法规范:
div {
box-sizing: content-box | border-box;
}
-
content-box 是默认值 盒子大小为 width+padding+border
-
border-box 盒子最终大小为width ✅✅
-
但注意 padding和margin不要大于width宽度
-
可以在CSS初始化时加上这个属性,如下
* {
padding:0;
margin:0;
box-sizing:border-box;
}
2.几个新功能
2.1CSS3图片模糊处理(filter)
新增滤镜filter属性
div {
filter: 函数();
/* 例:filter: blur(5px); blur模糊处理 ,数值越大越模糊 */
}
/*要想鼠标附着后模糊消失:*/
div:hover {
filter:blur(0);
}
2.2 CSS3执行计算函数(calc)
div {
width: calc(100%-80px);
}
/*calc函数中可进行+ - * /的计算*/
2.3CSS3过渡属性 (transition)
过渡(transition)是CSS3中具有颠覆性的特征之一,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果。
过渡动画: 是从一个状态 渐渐的过渡到另外一个状态
可以让我们页面更好看,更动感十足,虽然 低版本浏览器不支持(ie9以下版本) 但是不会影响页面布局。
我们现在经常和 :hover 一起 搭配使用。
-
语法规范:
div {
transition: 要过渡的属性 花费时间 运动曲线 何时开始;
}
属性值
描述
要过渡的属性
想要变化的CSS属性,高度宽度内外边距颜色都可以,所有属性都过渡则写 all
花费时间
单位秒(必须写单位),比如0.5s
运动曲线
默认ease (逐渐慢下来)(可以省略)
何时开始
设置延迟触发时间(必须有单位) ,单位秒,默认0s(可以省略)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fAy2uphQ-1627969734344)(C:\Users\28897\AppData\Roaming\Typora\typora-user-images\1626232145664.png)]
过渡属性实例:进度条
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0BttsIDk-1627969734345)(F:\01-03 前端开发基础\CSS3和html5新特性\images\jindutiao.gif)]
"bar">
"bar_in">
小米logo实例
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PV6xB3Qc-1627969734345)(F:\01-03 前端开发基础\CSS3和html5新特性\images\xiaomilogo.gif)]
3.CSS3 2D转换