前言
这是我第二次关于Web前端零基础入门HTML5+CSS3基础的学习笔记,主要是从两个不同讲师的角度全方面的学习一下web前端基础和顺带复习一下。所以我会在这里记录一下在第一个学习笔记中不熟悉或没有的部分,大家可以结合第一个笔记来一起看一下,第一个笔记比较详细。
这次学习B站尚硅谷的视频,想看是视频的小伙伴可以一用上面的链接。
HTML
首先我们回顾一下整体架构,再认识一下HTML,CSS,JS的作用。
data:image/s3,"s3://crabby-images/f3a94/f3a94f71ed64103739b83a411e7c0812c6bcb7b2" alt="在这里插入图片描述"
文档的声明
HTML发展到现在有多个版本,在使用前你需要对浏览器声明一下,你所要使用的HTML的文档(doctype)版本
<!DOCTYPE html>
zeal的下载使用与W3C在线文档的使用
zeal是一个离线文章的查看器,可以在没有网络的情况下查看文档。文档是我们编程时的说明书,对于每一个语言或者程序、软件都会有其的文档供我们在编程学习中使用。
zeal下载知道说明,亲测有用。不过有个很明显的缺点是zeal是英文版的,需要一定的英语基础,而且由于是国外的软件在下载文档时需要耐心等待几分钟。
W3C在线使用教程是中文版,内容也是比较全面的。不过要在联网时使用,而且版本较老。
VScode插件live Sever的安装
VScode是我们编程的使用的编程软件,这里是下载链接。根据自己的操作系统版本选择下载即可,具体的是全程同意的傻瓜式下载。
live Sever是一个VScode的插件,一个具有实时加载功能的小型服务器,可以使用它来破解html/css/javascript,但是不能用于部署最终站点。也就是说我们可以在项目中实时用live-server作为一个实时服务器实时查看开发的网页或项目效果。
下载后可以直接右键点击“open with live sever”使用。
meta标签
meta是html语言head区的一个辅助性标签。meta标签的作用有:搜索引擎优化(SEO),定义页面使用语言,自动刷新并指向新的页面,实现网页转换时的动态效果,控制页面缓冲,网页定级评价,控制网页显示的窗口等。
注意:
- 标签通常位于 区域内。
- 元数据通常以 名称/值 对出现。
- 如果没有提供 name 属性,那么名称/值对中的名称会采用 http-equiv 属性的值。
属性如下: data:image/s3,"s3://crabby-images/e5c4c/e5c4c75ee4b8eb6d85ffef0fa2259bcd9813cdd5" alt="在这里插入图片描述"
hgroup标签
hgroup是在两个标题之间有关系时使用,如在一个h1标题为大标题,一个h2为小标题时使用。
<hgroup>
<h1>Calculus I</h1>
<p>Fundamentals</p>
</hgroup>
<p>This course will start with a brief introduction about the limit of a function. Then we will describe how the idea of derivative emerges in the Physics and Geometry fields. After that, we will explain that the key to master calculus is …</p>
data:image/s3,"s3://crabby-images/320f8/320f862b63efb8ca2c53e4116701a7b47e283a6e" alt="在这里插入图片描述"
blockquote块引用
blockquote是块引用,在引用时可以使用该标签,因为其的显示方式时块,所以时独占一行。
<blockquote>
<p>Words can be like X-rays, if you use them properly—they’ll go through anything. You read and you’re pierced.</p>
</blockquote>
—Aldous Huxley, Brave New World
data:image/s3,"s3://crabby-images/40087/4008732007d0f635f7c03fceb6eecd599da9fdd6" alt="在这里插入图片描述"
语义化标签(了解)
内容分区元素,即语义化标签允许将文档内容组织到逻辑片段中。使用分区元素为页面内容创建大致的大纲,包括头部header、页尾 footer、导航navigation, 以及用于标识内容部分的标题元素。
这部分是HTML5新增的部分,并不常用,仅作了解,实际上这些功能都可以用div和span来实现。
下面是zeal中关于此部分的文档内容的说明。 data:image/s3,"s3://crabby-images/96b8b/96b8b42ec5f81ad8a0a5ac29091f89d1413a2993" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/794f1/794f14650f3f1724eb69bdb1f0f75b4ff3326b6e" alt="在这里插入图片描述"
超链接
在这里补充一下第一个笔记 在超链接处的遗漏,即href=“#”,在表示空链接,也可以跳转页面的各个位置。 data:image/s3,"s3://crabby-images/8f761/8f761f4a578ddec40e1d175a21c14a7f78704f24" alt="在这里插入图片描述"
图片标签和图片格式(了解)
在img标签中,存在一个alt的属性,该属性是在图片无法显示时,才可以被用户看见。写不写都不影响整体页面的运行。但如果写了,除了如下方所示的内容外,还可以被浏览器基于关键词(alt的内容)智能搜索。
data:image/s3,"s3://crabby-images/79d1c/79d1cfea404904b4fb37fdbce8e245aa5bdea97e" alt="在这里插入图片描述"
各种图片格式在使用时的优缺点如下
data:image/s3,"s3://crabby-images/8a362/8a362e6aad0dcadb8461c3622c9552bf5ec4c05b" alt="在这里插入图片描述"
内联框架标签iframe
作用:用于向当前页面引入一个其它页面 代码形式如下
<!-- frameborder是内联框架的边框的宽度 -->
<iframe src="引入页面的路径" height="高度" width="宽度" frameborder="0"></iframe>
CSS
选择器补充
1.兄弟元素
兄弟元素:拥有相同父级元素的元素
<!-- 选择下一个兄弟 -->
兄+弟{css}
<!-- 选择下面所有弟弟 -->
兄~弟{css}
2.属性选择器
即通过属性来选择对应修饰的标签,书写格式如下 data:image/s3,"s3://crabby-images/23526/2352634573decf1eb2cfdd65a5588dd79b2690da" alt="在这里插入图片描述"
3.伪类补充
选择第几个元素来进行修饰
选择器名:first-of-type{css}
选择起名:last-of-type{css}
选择器名:nth-of-type(n){css}
选择器名:not()
作用:将符合条件的元素从选择器中去除 如 li:not(nth-of-type(3)) 是将li中第三个剔除
超链接的伪类
data:image/s3,"s3://crabby-images/d1324/d13242d064f6cb7bb8d130523334dab13e2c4be2" alt="在这里插入图片描述"
伪元素
data:image/s3,"s3://crabby-images/2fb05/2fb05b9645daaad63af72a6c020e7386baddea27" alt="在这里插入图片描述"
overflow属性
作用:处理子元素溢出 使用:overflow: 属性值;
属性值如下 data:image/s3,"s3://crabby-images/bc64a/bc64a712b2e7f8bbd97ae4e62eecb5d787f94262" alt="在这里插入图片描述"
outline属性
data:image/s3,"s3://crabby-images/00431/00431fb0407264c8f3dc70bd2bef40fc770dac88" alt="在这里插入图片描述" 代码形式
outline:宽度 颜色 边框的形式(soild实线,dashed虚线,dotted点线);
元素脱离文档流的特点
data:image/s3,"s3://crabby-images/aab4b/aab4b8ce836e4910f98d88886a7fdf7d71d701d0" alt="在这里插入图片描述"
用BFC解决高度塌陷问题
提前说明,如果用BFC是可以解决高度塌陷的问题,但会有一定的副作用。下面有第三种的副作用最小,但仍有副作用。建议是用clear或:before 与:after来解决,效果较好。
高度塌陷
data:image/s3,"s3://crabby-images/7cc4a/7cc4aab1c3a51f143217911fcbef195b78a2cd05" alt="在这里插入图片描述" BFC的特点如下 data:image/s3,"s3://crabby-images/b8a90/b8a9098001bb62e8b2055e36a614c6347e2d7c6e" alt="在这里插入图片描述"
粘滞定位
data:image/s3,"s3://crabby-images/8225e/8225e4f911f4010eb47efd5b23b8fa2f292a3d4f" alt="在这里插入图片描述"
如京东商城的右边导航使用了这样的定位,效果如下
data:image/s3,"s3://crabby-images/73132/73132e6fe3f933dfad944ec309a303887c5c5b2f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/6483d/6483d405b0ab0ed0734d4452201541cfbbf61f94" alt="在这里插入图片描述"
图标字体
图标字体是如同下方的一样的图像,它的本质是矢量图,可以像字体一样自由放大而不失真,具体使用方法请参考这篇文章
data:image/s3,"s3://crabby-images/70578/70578c64e7eb4dda5778fd6e199c3a8307527e8e" alt="在这里插入图片描述"
水平对齐补充
水平对齐补充一个属性值:justify两端对齐
data:image/s3,"s3://crabby-images/c47cb/c47cb3338158eeffb370bb352f189ae9c6f394cb" alt="在这里插入图片描述"
网页空白处理和多余内容处理
作用:采用下面的三行代码可以将多余的文字内容以省略号的形式显示。
data:image/s3,"s3://crabby-images/7a7fe/7a7feaab347f4024907719689fc472056b09e760" alt="在这里插入图片描述"
背景补充
1.背景框
data:image/s3,"s3://crabby-images/bc0ee/bc0ee3c72e64ed369cced7aeca9964324959745e" alt="在这里插入图片描述"
2.背景图的偏移background-origin
data:image/s3,"s3://crabby-images/c8de4/c8de4bb5c44b4306d279e389dc4ebd5688e39358" alt="在这里插入图片描述"
3. background-attachment
data:image/s3,"s3://crabby-images/a4288/a4288b5abf8fb3974f32981bff9d1161eb328020" alt="在这里插入图片描述"
颜色渐变
data:image/s3,"s3://crabby-images/5b8a7/5b8a76ba2f76a209e80e20a1e56e7712b9b2cc27" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/38430/38430d845adc45d849bbc41fbc7984f954c86866" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/272ca/272ca561987066c595b710720cda1afd0c508f3f" alt="在这里插入图片描述"
表格属性补充
data:image/s3,"s3://crabby-images/fd2d0/fd2d0662717c496bde8ca79dff629afe7e331579" alt="在这里插入图片描述"
表单补充
表单数据提交步骤,一般要提交给服务器,但在下方临时搭一个HTML来接受,方便演示 data:image/s3,"s3://crabby-images/ce5c0/ce5c049d0620482ddae58139fffb74be130729eb" alt="在这里插入图片描述"
注意:选择框,要注明value值
data:image/s3,"s3://crabby-images/bc24b/bc24b9dc5eefd3bbfbd002275a5110d113182eb2" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/60463/6046338914a3ebc3fc437d2c76f29320660e82f1" alt="在这里插入图片描述"
用z-index提高优先级
为了解决谁覆盖谁的问题,我们可以采用 z-index:数字(优先级级数); 来解决这个问题,优先级高的覆盖优先级低的。一般我会把最高优先级设置为9999。
优先级详细介绍
data:image/s3,"s3://crabby-images/a92f1/a92f1487ac8453dbee9cf2a8344ed5884b15bbbc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f12a2/f12a233112d8936a0d6dcd49d6890f37e5aa827c" alt="在这里插入图片描述"
过渡transition
data:image/s3,"s3://crabby-images/7802e/7802e13622d518ffa5cd293bedef3d9fdb012971" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c5b39/c5b39d6ced5c927d9ea98fd1f4d5a4d7eeb90711" alt="在这里插入图片描述"
关键帧-自动(无需触动)
data:image/s3,"s3://crabby-images/e18bc/e18bc7db5915485d837234bbe75e329ce0eb6b96" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f34d3/f34d381061a608f5e060d2733f5d90f692e8b9ac" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/51f16/51f164de947885922d0101de98c28a19dddd4207" alt="在这里插入图片描述"
from默认为0,to默认为100%,即从过程的开始到结束
可以根据这样的特点设置中间的几个过程
data:image/s3,"s3://crabby-images/41c0d/41c0d27cddb88ac5dd78239204517bc4a4548e3c" alt="在这里插入图片描述"
变形(transform)
1.平移
data:image/s3,"s3://crabby-images/787bb/787bbb129953993aa64ea7959778636d516dc86d" alt="在这里插入图片描述" 注意:这种方式是可以确定元素的位置,但只能确定有固定宽高的元素的位置。
data:image/s3,"s3://crabby-images/d45d1/d45d103980631268bec8653d5eeb9bc427282283" alt="在这里插入图片描述"
2.旋转
data:image/s3,"s3://crabby-images/430e1/430e18fae8d186c0e77a74693b2cf3e005440402" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/be9bf/be9bfc7d96473c3fb2ecc5c74115decef8ba5452" alt="在这里插入图片描述"
3.缩放
data:image/s3,"s3://crabby-images/d0e93/d0e934167ba1b90b2dccdd5827364cd4be0cbf28" alt="在这里插入图片描述"
3.变形原点
data:image/s3,"s3://crabby-images/0a411/0a4115c267d9ee8e3e0293068340274a2aa18d44" alt="在这里插入图片描述"
less
less是一门css的预处理语言,是css的增强版,通过less可以编写更少的代码实现更强大的样式。 特点:
- 在less中添加了许多的新特性,像对变量的支持,对mixin的支持
- less的语法大体上与css语法一致,但是less中田佳琳许多对css的扩展
- 浏览器无法直接运行less代码,要执行必须像less转化为css,然后浏览器执行。
缺点是老版本的浏览器不兼容
详细介绍在这里
弹性盒子
data:image/s3,"s3://crabby-images/9f6bd/9f6bd748c25e7e360cf14dd9a58b1c16987d9d6b" alt="在这里插入图片描述"
1.弹性容器的样式
data:image/s3,"s3://crabby-images/191d6/191d60d474a4e74b21a0a813cc16809f37491924" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/bcfb5/bcfb5375c6d5bd647bb0516d1681f8eaddac75b3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ed3f1/ed3f1717906bb8d6471988fd286929c2940e8eb4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/57915/57915dfbb5d8860f43b10b583fd6adcec4f4e6be" alt="在这里插入图片描述"
下面的属性值和上面一致
data:image/s3,"s3://crabby-images/48f35/48f35210455bf1431f2671b20ab39f8c6eb663c6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/04687/046875e9c109840f4cc2ba97c31611779950324c" alt="在这里插入图片描述" 下面的属性值和上面一致
data:image/s3,"s3://crabby-images/db89d/db89d193a2b68816b5aa54efdfc7266b86916581" alt="在这里插入图片描述"
2.弹性元素的样式
data:image/s3,"s3://crabby-images/271a0/271a0e4979841415b9f9288222640a42c970c150" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/861a0/861a0e359e43823e09b787452f0c99c24596230c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/e0c81/e0c81bbf3602add1d397b9cec8ade8e80b30d23f" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/0e81d/0e81da1c916450a9f05ca32fb01934ff58306fa5" alt="在这里插入图片描述"
像素
1.基本介绍
data:image/s3,"s3://crabby-images/9ea16/9ea1697debe7f006e49da1d336608eff46a56a75" alt="在这里插入图片描述"
2.手机像素
data:image/s3,"s3://crabby-images/c00ea/c00ead88a3092d6951bb58ced8c29b6f430dd672" alt="在这里插入图片描述"
3.完美视口
data:image/s3,"s3://crabby-images/569de/569de843d265e1c5190fb254233b8e29ccccbec4" alt="在这里插入图片描述"
4.像素单位vw
data:image/s3,"s3://crabby-images/28dc5/28dc5d4e7c6b6d23d51394ac8b47dde2b21f6326" alt="在这里插入图片描述"
媒体查询
data:image/s3,"s3://crabby-images/9ede3/9ede35141afd8a0d03398c1c1dd5c7bba7e3b991" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/96ecf/96ecf2f6ba7f72f16bd4580b135417f8aeacd6dd" alt="在这里插入图片描述"
实战练习
小米商城
代码自取 链接:https://pan.baidu.com/s/1kiVODIV7Gz3Fhmy54DUniA 提取码:akcu data:image/s3,"s3://crabby-images/e1e47/e1e4753a3a1c1fcb6ff2009e7b1a86dd2acc1653" alt="在这里插入图片描述" blog.csdnimg.cn/89c5b862aa5849099e80af2c945a2eb8.png)
在网页上实现动画的效果
图片仅用于演示,来自他人博客
1.米兔练习
<!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>Document</title>
<style>
*{
margin: 0;
padding: 0;
}
.box1{
width: 132px;
height: 271px;
background-image: url(./米兔.png);
background-position: 0 0;
transition: 0.3s steps(3);
margin: 0 auto;
}
.box1:hover{
background-position: -396px 0;
}
</style>
</head>
<body>
<div class="box1"></div>
</body>
</html>
2.奔跑的少年
<!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>Document</title>
<style>
*{
padding: 0;
margin: 0;
}
.box1{
width: 120px;
height: 136px;
margin: 100px auto ;
background-image: url(./奔跑的少年.png);
animation: run 1s steps(10) infinite ;
}
@keyframes run{
from{
background-position: 0 0;
}
to{
background-position: -1200px 0;
}
}
</style>
</head>
<body>
<div class="box1"></div>
</body>
</html>
data:image/s3,"s3://crabby-images/688c7/688c7a4365fefbbe7c54bbca6b153e31170db253" alt="在这里插入图片描述"
3.用动画(animation)和rotaeZ(旋转)实现钟表
<!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>Document</title>
<style>
*{
margin: 0;
padding: 0;
}
.clock{
width: 265px;
height: 265px;
margin: 100px auto;
border-radius: 50%;
border: 1px solid #000;
background-image: url(./img/表盘.jpg);
position: relative;
}
.hour-wrapper{
position: absolute;
height: 50%;
width: 50%;
top: 0;
left: 0;
bottom: 0;
right: 0;
margin: auto;
animation: run 3600s linear infinite;
}
.sec-wrapper{
position: absolute;
height: 80%;
width: 80%;
margin: auto;
top: 0;
left: 0;
bottom: 0;
right: 0;
animation: run 1s steps(60) infinite;
}
.min-wrapper{
position: absolute;
height: 65%;
width: 65%;
margin: auto;
top: 0;
left: 0;
bottom: 0;
right: 0;
animation: run 60s steps(60) infinite;
}
.hour{
height: 50%;
width: 8px;
background-color: #000;
margin: 0 auto;
}
.min{
height: 50%;
width: 6px;
background-color: #000;
margin: 0 auto;
}
.sec{
height: 50%;
width: 4px;
background-color: rgb(231, 12, 12);
margin: 0px auto;
}
@keyframes run {
from{
transform: rotateZ(0);
}
to{
transform: rotateZ(360deg);
}
}
</style>
</head>
<body>
<div class="clock">
<div class="hour-wrapper">
<div class="hour"></div>
</div>
<div class="min-wrapper">
<div class="min"></div>
</div>
<div class="sec-wrapper">
<div class="sec"></div>
</div>
</div>
</body>
</html>
data:image/s3,"s3://crabby-images/7425c/7425c5fb77b56da99f282443967213046b2e59f9" alt="在这里插入图片描述"
4.旋转的正方体
<!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>Document</title>
<style>
html{
perspective: 800px;
}
.cube{
width:200px ;
height: 200px;
margin: 0 auto;
margin-top: 250px;
animation: run 20s infinite linear;
transform-style: preserve-3d;
}
.cube> div{
width: 200px;
height: 200px;
opacity: .7;
position:absolute;
}
img{
vertical-align: top;
width: 200px;
height: 200px;
}
.box1{
transform: rotateY(90deg) translateZ(100px);
}
.box2{
transform: rotateY(-90deg) translateZ(100px);
}
.box3{
transform: rotateX(90deg) translateZ(100px);
}
.box4{
transform:rotateX(-90deg) translateZ(100px)
}
.box5{
transform: rotateY(180deg) translateZ(100px);
}
.box6{
transform: rotateY(0deg) translateZ(100px);
}
@keyframes run{
from{
transform: rotateX(0) rotateZ(0);
}
to{
transform: rotateX(1turn) rotateZ(1turn);
}
}
</style>
</head>
<body>
<div class="cube">
<div class="box1"><img src="./img/01.gif" alt=""></div>
<div class="box2"><img src="./img/02.gif" alt=""></div>
<div class="box3"><img src="./img/03.gif" alt=""></div>
<div class="box4"><img src="./img/04.jpg" alt=""></div>
<div class="box5"><img src="./img/05.gif" alt=""></div>
<div class="box6"><img src="./img/06.gif" alt=""></div>
</div>
</body>
</html>
素材图片 data:image/s3,"s3://crabby-images/2a094/2a094a3e5b2e845bb058f98f52adb4f4d5fbbf07" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/48626/486267c239c24cb301f19517cb6ac9089f6249f6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c91cc/c91cc62d3e8835a899e8605c63e215feca76e65d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c8bb5/c8bb5ea0fa0b7cacf4960ab0c67755b8a10bef20" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d6c69/d6c69eb7673b3b68b0861705089b39022b1db65c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/392e8/392e8561707be60ccff62bfdca6b938f890163d1" alt="在这里插入图片描述"
|