这篇文章为我跟随pink老师重新系统学习前端时做的一些笔记。
【HTML5与CSS3篇】
D1:HTML基础:简介+常用标签
D2:CSS入门:简介+基础选择器+字体&文本属性+引入方式
D2:CSS基础:复合选择器+元素显示模式+背景
D3:CSS进阶:层叠&继承&优先级+盒子模型+圆角边框+盒子&文本阴影+浮动
D4:CSS进阶:定位+元素的显示与隐藏
D5:CSS提高
【JavaScript篇】
D1:JavaScript入门:计算机基础+变量+数据类型
D2:JavaScript基础:运算符+运算流程分支控制+命名规范与语法格式
D3:JavaScript进阶
PS有多种切图方式:图层切图、切片切图、PS插件切图等。
最简单的切图方式:右击图层 --> 快速导出为PNG。
但很多情况下,需要先合并图层再导出:
略。
Cutterman简介及其使用略。
建议遵循以下顺序:
为了提高网页制作的效率,布局时通常有以下的整体思路:
导航栏注意点:
以下情况使用标准流或浮动很难实现:
以上效果需要使用定位来实现。
定位:将盒子定在某一个位置,所以定位也是在摆放盒子,按照定位的方式移动盒子。
定位 = 定位模式 +边偏移
定位模式用于指定一个元素在文档中的定位方式,边偏移则决定了该元素的最终位置。
定位模式决定元素的定位方式 ,它通过CSS的position属性来设置,其值可以分为四个:
值 | 语义 |
---|---|
static | 静态定位 |
relative | 相对定位 |
absolute | 绝对定位 |
fixed | 固定定位 |
边偏移就是定位的盒子移动到最终位置。
边偏移属性 | 示例 | 描述 |
---|---|---|
top | top: 80px; | 顶端偏移量,定义元素相对于其父元素的上边线的距离 |
bottom | bottom: 80px; | 底部偏移量,定义元素相对于其父元素的下边线的距离 |
right | right: 80px; | 右侧偏移量,定义元素相对于其父元素右边线的距离 |
left | left: 80px; | 左侧偏移量,定义元素相对于其父元素左边线的距离 |
静态定位是元素的默认定位方式,无定位的意思。
选择器 {
position: static;
}
相对定位是元素在移动位置的时候,是相对于它原来的位置来说的。
选择器 {
position: relative;
}
绝对定位是元素在移动位置的时候,是相对于它的祖先元素来说的。
选择器 {
position: absolute;
}
子绝父相的由来:
子级使用绝对定位,父级则需要相对定位:
总结:因为父级需要占有位置,因此是相对定位,子盒子不要占有位置,则是绝对定位。但子绝父相不是永远不变的,如果父元素不需要占有位置,子绝父绝也会遇到。
案例:带切换按钮的轮播图。
固定定位是元素固定于浏览器的可视区的位置。主要使用场景: 可以在浏览器页面滚动时元素的位置不会改变。
固定定位小技巧: 固定在版心右侧位置。
left: 50%;
走到浏览器可视区(也可以看做版心) 的一半位置。margin-left: 版心宽度的一半距离;
多走版心宽度的一半位置,到版心右侧。.fixed {
position: fixed;
/* 1. 走浏览器宽度的一半 */
left: 50%;
/* 2. 利用margin走版心盒子宽度的一半 */
margin-left: 400px;
}
粘性定位可以被认为是相对定位和固定定位的混合。
选择器 { position: sticky; top: 10px; }
在使用定位布局时候,可能会出现盒子重叠的情况。此时,可以用z-index来控制盒子的前后次序(z轴)。
选择器 {
z-index: 1;
}
加了绝对定位的盒子不能通过margin: 0 auto;
实现水平居中,但是可以通过以下计算方法实现水平和垂直居中:
left: 50%;
让盒子的左侧移动到父级元素的水平中心位置。margin-left: -100px;
让盒子向左移动自身宽度的一半.box {
position: absolute;
/* 实现水平居中 */
/* 1. left走50%,即父容器宽度的一半 */
left: 50%;
/* 2. margin为负值,往左边走自己盒子宽度的一半 */
margin-left: -100px;
/* 实现垂直居中 */
/* 1. top走50%,即父容器高度的一半 */
top: 50%;
/* 2. margin为负值,往上边走自己盒子高度的一半 */
margin-top: -100px;
width: 200px;
height: 200px;
background-color: pink;
/* margin: auto; */
}
绝对定位和固定定位也和浮动类似。
浮动元素、绝对定位(固定定位)元素都不会触发外边距合并的问题。
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>淘宝轮播图做法title>
<style>
* {
margin: 0;
padding: 0;
}
li {
list-style: none;
}
.tb-promo {
position: relative;
width: 520px;
height: 280px;
background-color: pink;
margin: 100px auto;
}
.tb-promo img {
width: 520px;
height: 280px;
}
/* 并集选择器可以集体声明相同的样式 */
.prev,
.next {
position: absolute;
/* 绝对定位的盒子垂直居中 */
top: 50%;
margin-top: -15px;
/* 加了绝对定位的盒子可以直接设置高度和宽度 */
width: 20px;
height: 30px;
background: rgba(0, 0, 0, .3);
text-align: center;
line-height: 30px;
color: #fff;
text-decoration: none;
}
.prev {
left: 0;
/* border-radius: 15px; */
border-top-right-radius: 15px;
border-bottom-right-radius: 15px;
}
.next {
right: 0;
/* border-radius: 15px; */
border-top-left-radius: 15px;
border-bottom-left-radius: 15px;
}
.promo-nav {
position: absolute;
bottom: 15px;
left: 50%;
margin-left: -35px;
width: 70px;
height: 13px;
background: rgba(255,255,255, .3);
border-radius: 7px;
}
.promo-nav li {
float: left;
width: 8px;
height: 8px;
background-color: #fff;
border-radius: 50%;
margin: 3px;
}
/* 不要忘记选择器权重的问题 */
/* .selected {
background-color: #ff5000;
} */
.promo-nav .selected {
background-color: #ff5000;
}
style>
head>
<body>
<div class="tb-promo">
<img src="images/tb.jpg" alt="">
<a href="#" class="prev"> < a>
<a href="#" class="next"> > a>
<ul class="promo-nav">
<li class="selected">li>
<li>li>
<li>li>
<li>li>
<li>li>
ul>
div>
body>
html>
类似网站广告,当我们点击关闭就不见了,但是重新刷新页面,广告会重新出现。本质:让一个元素在页面中隐藏或者显示出来。
display属性用于设置一个元素应如何显示。
display: none; /* 隐藏对象 */
display: block; /* 除了转换为块级元素之外,同时还有显示元素的意思 */
visibility属性用于指定一个元素应可见还是隐藏。
visibility: hidden;
;如果隐藏元素不想要原来位置,就用 display: none;
(用处更多,重点)visibility: visible; /* 元素可视 */
visibility: hidden; /* 元素隐藏 */
overflow属性指定了如果内容溢出一个元素的框(超过其指定高度及宽度)时,会发生什么。
overflow: visible; /* 不剪切内容也不添加滚动条 */
overflow: hidden; /* 不显示超过对象尺寸的内容,超出的部分隐藏掉 */
overflow: scroll; /* 不管超出内容否,总是显示滚动条 */
overflow: auto; /* 超出自动显示滚动条,不超出不显示滚动条 */
一般情况下,都不想让溢出的内容显示出来,因为溢出的部分会影响布局。但是如果是有定位的盒子,请慎用overflow: hidden;
,因为它会隐藏多余的部分。
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>仿土豆网显示隐藏遮罩案例title>
<style>
.tudou {
position: relative;
width: 444px;
height: 320px;
background-color: pink;
margin: 30px auto;
}
.tudou img {
width: 100%;
height: 100%;
}
.mask {
/* 隐藏遮罩层 */
display: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, .4) url(images/arr.png) no-repeat center;
}
/* 当我们鼠标经过了土豆这个盒子,就让里面的遮罩层显示出来 */
.tudou:hover .mask {
/* 这里不是转换为块元素,而是显示元素 */
display: block;
}
style>
head>
<body>
<div class="tudou">
<div class="mask">div>
<img src="images/tudou.jpg" alt="">
div>
<div class="tudou">
<div class="mask">div>
<img src="images/tudou.jpg" alt="">
div>
<div class="tudou">
<div class="mask">div>
<img src="images/tudou.jpg" alt="">
div>
<div class="tudou">
<div class="mask">div>
<img src="images/tudou.jpg" alt="">
div>
body>
html>
网页布局
定位模式
定位模式 | 是否脱标 | 移动位置 | 是否常用 |
---|---|---|---|
static静态定位 | 否 | 不能使用边偏移 | 很少 |
relative相对定位 | 否(占有位置) | 相对于自身位置移动 | 常用 |
absolute绝对定位 | 是(不占有位置) | 带有定位的父级 | 常用 |
fixed固定定位 | 是(不占有位置) | 浏览器可视区 | 常用 |
sticky粘性定位 | 否(占有位置) | 浏览器可视区 | 当前阶段少 |
元素的显示与隐藏