[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TWSHkoYn-1654060785223)(https://gitee.com/imagesss/warehouse1/raw/master/20220402093737.png)]
(在线文档:API文档_Web)
标题标签:
段落和换行标签:
段落之间距离大
换行标签:行之间距离小
文本格式化标签:
div和span标签:没有语义,就是一个盒子,用来布局网页,可以放文字、图片等
图像标签:
路径:
链接标签: 文本、图像、表格、音频、视频等
锚点标签:点击链接可以快速定位到页面中某个位置
注释标签:
特殊字符:
表格标签:
<table>
<thead>
<tr>
<th>表头单元格标签,加粗居中显示th>
tr>
thead>
<tbody>
<tr>
<td>列标签td>
tr>
tbody>
table>
列表标签:
无序列表:样式和布局一般通过CSS设置
<ul>
<li>朱一龙li>
<li>龚俊li>
<li>蔡徐坤li>
ul>
有序列表:样式和布局一般通过CSS设置
<ol>
<li>朱一龙li>
<li>龚俊li>
<li>蔡徐坤li>
ol>
自定义列表:样式和布局一般通过CSS设置
<dl>
<dt>名词1,如关注我们dd>
<dd>名词1解释1,如微博关注我们dd>
<dd>名词1解释2,如微信关注我们dd>
<dt>名词2dd>
<dd>名词2解释1dd>
<dd>名词2解释2dd>
dl>
表单标签:收集用户信息,由表单域、表单控件和提示信息构成
<form action="URL地址" method="提交方式" name="表单域名称">
<input type="radio" name="sex" value="男" id="man" checked="checked"/>
<label for="man">男label>
<input type="radio" name="sex" value="女" id="woman"/>
<label for="woman">女label>
<select>
<option>山东option>
<option selected="selected">北京option>
<option>火星option>
select>
<textarea rows="5" cols="20">默认文字textarea>
form>
内部样式表(内嵌样式表):将样式单独写在style标签内部,style标签一般放在head标签中,可以控制当前HTML页面,开发中使用较多,2)3)的样例全都使用内部样式表
龚俊
行内样式表:将样式写在标签里,只能控制当前标签,适合修改简单样式,一般情况下使用很少
<div style="color: red; font-size: 12px;">龚俊div>
外部样式表:样式单独写到CSS文件中,只有样式,没有style标签,在HTML页面中将CSS文件引入,可以控制多个页面,开发中使用最多
div {
color: red;
font-size: 12px;
}
DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" href="style.css">
head>
<body>
<div>龚俊div>
body>
html>
标签选择器
DOCTYPE html>
<html lang="en">
<head>
<style>
p {
color: red;
font-size: 12px;
}
style>
head>
<body>
<p>龚俊p>
body>
html>
类选择器
DOCTYPE html>
<html lang="en">
<head>
<style>
/*可以被多个标签调用,一个标签可以调用多个*/
.red {
color: red;
}
.font12 {
font-size: 12px;
}
style>
head>
<body>
<div class="red">龚俊div>
<div class="red font12">朱一龙div>
body>
html>
id选择器
DOCTYPE html>
<html lang="en">
<head>
<style>
/*只能调用一次,即只能被一个标签调用*/
#red {
color: red;
}
style>
head>
<body>
<div id="red">龚俊div>
body>
html>
通配符选择器
DOCTYPE html>
<html lang="en">
<head>
<style>
/*不需要调用,自动就给所有元素使用样式*/
* {
margin: 0;
padding: 0;
}
style>
head>
<body>
<div>龚俊div>
<div>朱一龙div>
body>
html>
字体属性
DOCTYPE html>
<html lang="en">
<head>
<style>
/*给整个body指定字体大小*/
body {
font-size: 16px;
}
/*标题标签需要单独指定文字大小*/
h2 {
font-size: 16px;
}
/*a标签在浏览器中具有默认样式,实际工作中需要给链接单独指定样式,body的样式不会影响它*/
a {
font-size: 16px;
}
/*字体,更多用法建议查阅文档*/
p {
font-family: 'Microsoft YaHei', 'Times New Roman', Arial;
}
/*使加粗变正常,更多用法建议查阅文档*/
strong {
font-weight: 400;
}
/*使倾斜变正常,更多用法建议查阅文档*/
em {
font-style: normal;
}
/*字体符合属性,不能颠倒顺序*/
/*font: font-style font-weight font-size/line-height font-family;*/
/*不需要设置的属性可以省略(取默认值),但必须保留font-size和font-family属性 */
div {
font: intalic 700 16px/20px 'Microsoft YaHei';
}
style>
head>
<body>
<h2>美人们h2>
<p>蔡徐坤p>
<strong>龚俊strong>
<em>朱一龙em>
<div>三生三世十里桃花div>
body>
html>
文本属性
DOCTYPE html>
<html lang="en">
<head>
<style>
/*文本颜色*/
div {
/*color: deeppink;
color: #cc00ff; */
color: rgb(255,0,255);
}
/*文本水平对齐(如果给一个盒子添加text-align: center;那么它里面的行内元素和行内块元素都会水平居中对齐)*/
h2 {
text-align: center;
}
/*图片水平对齐*/
.pic {
text-align: center;
}
/*下划线、上划线、删除线等*/
a {
text-decoration: none;
}
/*文本首行缩进,可以取正值、负值像素,可以用em元素单位*/
p {
text-indent: 2em;
}
/*行间距,即行高,包含文本高度;可以通过文字行高设置垂直居中效果;
测量行高推荐小工具FastStone Capture*/
p {
line-height: 25px;
}
/* 去掉li前面的项目符号 */
ul li {
list-style: none;
}
style>
head>
<body>
<h2>美人们h2>
<div>龚俊div>
<a href="#">粉红色的回忆a>
<p>朱一龙p>
<p class="pic">
<img src="../img/图像.gif"/>
p>
<ul>
<li>lllli>
ul>
body>
html>
后代选择器(包含选择器)
DOCTYPE html>
<html lang="en">
<head>
<style>
/*后代选择器*/
ul li {
color: pink;
}
ul li a {
color: pink;
}
.nav li a {
color: pink;
}
style>
head>
<body>
<ul>
<li>lllli>
<li><a href="#">aaaa>li>
ul>
<ul class="nav">
<li>lllli>
<li><a href="#">aaaa>li>
ul>
body>
html>
子元素选择器(子选择器)
DOCTYPE html>
<html lang="en">
<head>
<style>
/*选择某元素的最近一级所有的子元素*/
div>a {
color: pink;
}
style>
head>
<body>
<div class="nav">
<a href="#">aaaa>
<p>
<a href="#">aaaa>
p>
div>
body>
html>
并集选择器
DOCTYPE html>
<html lang="en">
<head>
<style>
/*并集选择器*/
div,
p span {
color: pink;
}
style>
head>
<body>
<div class="nav">ddddiv>
<p>
<a href="#">aaaa>
<span>sssspan>
p>
body>
html>
伪类选择器(如链接伪类、结构伪类等)
链接伪类选择器(为了确保生效,请按照link、visited、hover、active的顺序声明,开发中一般只用到其中几个)
DOCTYPE html>
<html lang="en">
<head>
<style>
/*选择所有未被访问的链接*/
a:link {
color: blue;
}
/*选择所有已被访问的链接*/
a:visited {
color: black;
}
/* 选择鼠标指针位于其上的链接 */
a:hover {
color: pink;
}
/* 选择活动链接(鼠标按下未弹起的链接) */
a:active {
color: yellow;
}
/* 当鼠标经过div时,让它孩子a标签变颜色 */
div:hover a{
color: yellow;
}
/* 链接伪类选择器实际工作开发中的写法 */
a {
color: black;
text-decoration: none;
}
a:hover {
color: blue;
text-decoration: underline;
}
style>
head>
<body>
<a href="#">aaaa>
<a href="#">aaaa>
<div><a href="#">aaaa>div>
body>
html>
focus伪类选择器(一般情况下焦点在类表单元素才能获取,因此这个选择器主要用于选取获得焦点的表单元素)
DOCTYPE html>
<html lang="en">
<head>
<style>
/* 选择获得焦点的表单元素 */
input:focus {
background-color: yellow;
color: red;
}
style>
head>
<body>
<form action="post">
<input type="text">
<input type="text">
form>
body>
html>
块元素:如div、h1-h6、p、ul、ol、li标签等
自己独占一行
可以设置高度、宽度、外边距及内边距等(宽度默认是容器的100%,或者父元素宽度的100%)
每个块元素都是一个容器及盒子,里面可以放所有类型元素
文字类元素(如h1-h6、p)里不能使用块级元素
行内元素:又称内联元素,如a、strong、b、em、i、del、s、ins、u、span标签等
行内块元素:既有块级元素的特点,又有行内元素的特点,如img、input、td标签
元素显示模式转换:使一个模式的元素拥有另外一种模式的特性
DOCTYPE html>
<html lang="en">
<head>
<style>
a {
/* 转换为块元素 */
display: block;
width: 150px;
height: 50px;
background-color: pink;
}
div {
/* 转换为行内元素 */
display: inline;
background-color: pink;
}
span {
/* 转换为行内块元素 */
display: inline-block;
width: 150px;
height: 50px;
background-color: pink;
}
style>
head>
<body>
<a href="#">aaaa>
<div>ddddiv>
<span>sssspan>
body>
html>
DOCTYPE html>
<html lang="en">
<head>
<style>
span {
/* 设置背景颜色,默认是transparent透明,也可以手动设置为transparent */
background-color: pink;
/* 设置背景颜色及半透明效果,前三个参数对应rgb,
最后一个参数alpha为透明度,取值0-1之间,小数点前0可以省略:
background: rgba(0, 0, 0, .6); */
/* 设置背景图片,默认是none,也可以手动设置为none */
background-image: url(龚俊.jpg);
/* 设置背景图片不平铺,默认repeat平铺,也可以手动设置为repeat
横向平铺为repeat-x,纵向平铺为repeat-y */
background-repeat: no-repeat;
/* 设置背景图片位置,
1、如果使用精确单位,第一个为x,第二个为y
(如果只规定x,则y默认居中,没法只规定y)
2、如果使用top/bottom/center/left/right等方位名词,则两个值前后顺序无所谓
(如果只指定一个方位名词,另一个默认居中)
3、如果精确单位和方位名词混合使用,第一个为x,第二个为y */
background-position: center 40px;
}
body {
color: #fff;
font-size: 20px;
background-image: url(bg.jpg);
background-repeat: no-repeat;
background-position: center top;
/* 把背景图片固定住,scroll背景图像随对象内容滚动,fixed背景图像固定 */
background-attachment: fixed;
/* 背景复合写法:没有特定书写顺序,一般习惯约定顺序为:
background: pink url(image.jpg) no-repeat fixed top center; */
}
a {
display: inline-block;
width: 120px;
height: 58px;
color: white;
text-align: center;
line-height: 50px;
text-decoration: none;
background: url(bg1.jpg) no-repeat;
}
a:hover {
/* 设置鼠标经过变换背景图片 */
background-image: url(bg2.jpg);
}
style>
head>
<body>
<span>sssspan>
<p>pppp>
<a href="#">aaaa>
body>
html>
网页布局过程
网页布局准则
网页布局策略:先用标准流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置
网页布局思路
网页布局注意点
(最基本的布局方式,又称普通流/文档流)
盒子模型
content内容:文字、图片或其他的盒子
border边框(会加大盒子大小)
DOCTYPE html>
<html lang="en">
<head>
<style>
.div1 {
width: 300px;
height: 200px;
/* border语法
border-style属性值有solid实线、dashed虚线、dotted点线等,
更多样式见API文档 */
border-width: 5px;
border-style: solid;
border-color: pink;
/* border复合语法:
border: border-width border-style border-color;(没有顺序) */
/* 上下左右border分开设定 */
border-top: 1px solid #000;
border-left: 1px solid #000;
/* 层叠性:后写的边框样式会把先写的覆盖掉 */
}
/* 设置表格大小 */
table {
width: 500px;
height: 250px;
}
/* 设置表头单元格的高 */
th {
height: 35px;
}
/* 设置表格border */
table,
th,
td {
border: 1px solid pink;
/* 合并相邻边框 */
border-collapse: collapse;
}
style>
head>
<body>
<div class="div1">ddddiv>
<table>
<tr>
<th>hhhth>
tr>
<tr>
<td>dddtd>
tr>
table>
body>
html>
padding内边距
(如果盒子本身显式地设置了width/height属性,则padding会撑大盒子大小)
(如果盒子本身没有显式地设置width/height属性,则padding不会撑开盒子大小)
(盒子里的内容默认与盒子一样大,即儿子默认和父亲一样大)
(如果儿子没有显式地设置width/height属性,则其padding不会撑开其大小,还是和父亲一样大)
DOCTYPE html>
<html lang="en">
<head>
<style>
div {
width: 300px;
height: 200px;
/* padding语法 */
padding-left: 5px;
padding-right: 5px;
padding-top: 5px;
padding-bottom: 5px;
/* padding复合语法:1个值代表上下左右内边距 */
padding: 5px;
/* padding复合语法:2个值代表上下内边距、左右内边距 */
padding: 5px 10px;
/* padding复合语法:3个值代表上内边距、左右内边距、下内边距 */
padding: 5px 10px 20px;
/* padding复合语法:4个值代表上右下左顺时针内边距值 */
padding: 5px 10px 20px 30px;
}
style>
head>
<body>
<div>ddddiv>
body>
html>
margin外边距
(相邻块元素的垂直外边距会出现合并的现象,所以尽量只给一个盒子添加margin值)
(嵌套块元素的垂直外边距会出现塌陷的现象,即父元素有上外边距同时子元素也有上外边距,此时父元素会塌陷较大的外边距,而子元素与父元素之间还是紧挨着)
(塌陷现象的解决方案有:为父元素定义上边框,多宽都行;为父元素定义上内边距,多宽都行;为父元素添加overflow:hidden; )
(浮动、固定、绝对定位的盒子不会有塌陷问题)
DOCTYPE html>
<html lang="en">
<head>
<style>
div {
width: 300px;
height: 200px;
/* margin语法 */
margin-left: 5px;
margin-right: 5px;
margin-top: 5px;
margin-bottom: 5px;
/* margin复合语法:1个值代表上下左右外边距 */
margin: 5px;
/* padding复合语法:2个值代表上下外边距、左右外边距 */
margin: 5px 10px;
/* padding复合语法:3个值代表上外边距、左右外边距、下外边距 */
margin: 5px 10px 20px;
/* padding复合语法:4个值代表上右下左顺时针外边距值 */
margin: 5px 10px 20px 30px;
}
.d {
/* 设置块级盒子水平居中:盒子必须指定宽度,盒子左右外边距设置为auto,
如margin: auto;
如margin-left: auto; margin-right: auto; */
margin: 100px auto;
/* 行内元素或行内块元素水平居中对齐只需给其父元素设置text-align: center; */
}
style>
head>
<body>
<div>ddddiv>
<div class=".d">ddddiv>
body>
html>
清除内外边距
(行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距,设置了也没用,但是转换为块级元素和行内块元素就可以了)
DOCTYPE html>
<html lang="en">
<head>
<style>
/* 清除内外边距通常作为css的第一行代码 */
* {
margin: 0;
padding: 0;
}
style>
head>
<body>
123
<ul>
<li>abcli>
ul>
body>
html>
圆角边框(CSS3)
DOCTYPE html>
<html lang="en">
<head>
<style>
.yuanxing {
width: 200px;
height: 200px;
background-color: pink;
/* 给正方形设置圆角边框:border-radius: 100px; */
border-radius: 50%;
}
.jvxing {
width: 300px;
height: 100px;
background-color: pink;
/* 给矩形设置圆角边框 */
border-radius: 50px;
}
.radius {
width: 200px;
height: 200px;
background-color: pink;
/* 四个角分别设置不同的圆角弧度值:左上角 右上角 右下角 左下角 */
border-radius: 5px 10px 15px 20px;
/* 两个值:左上角和右下角一个值,右上角和左下角一个值
border-radius: 5px 10px; */
/* 分开写:
border-top-left-radius: 5px;
border-bottom-right-radius: 20px; */
}
style>
head>
<body>
<div class="yuanxing">div>
<div class="jvxing">div>
<div class="radius">div>
body>
html>
盒子阴影(CSS3)
DOCTYPE html>
<html lang="en">
<head>
<style>
div {
width: 200px;
height: 200px;
background-color: pink;
margin: 100px auto;
/* 设置盒子阴影:box-shadow: h-shadow v-shadow blur spread color inset;
六个参数含义:水平阴影位置(必需,可以负值) 垂直阴影位置(必需,可以负值)
模糊距离(可选) 阴影尺寸(可选) 阴影颜色(可选)
将外部阴影改成内部阴影(可选,默认outset,但是不可以写outset) */
box-shadow: 10px 10px 10px 10px rgba(0, 0, 0, .3);
/* 盒子阴影不占空间,不会影响其他盒子排列 */
}
style>
head>
<body>
<div>div>
body>
html>
文字阴影(CSS3)
DOCTYPE html>
<html lang="en">
<head>
<style>
div {
font-size: 50px;
color: orangered;
font-weight: 700;
/* 给文字添加阴影:text-shadow: h-shadow v-shadow blur color;
四个参数含义:水平阴影位置(必需,可以负值) 垂直阴影位置(必需,可以负值)
模糊距离(可选) 阴影颜色(可选) */
text-shadow: 5px 5px 6px rgba(0, 0, 0, .3);
}
style>
head>
<body>
<div>龚俊div>
body>
html>
float属性
DOCTYPE html>
<html lang="en">
<head>
<style>
.left .right {
/* float属性用于创建浮动框,将其移动到一边,
直到左边缘或右边缘触及包含块或另一个浮动框的边缘;
属性值有left、right、none(默认值) */
float: left;
width: 200px;
height: 200px;
background-color: pink;
}
.right {
float: right;
}
style>
head>
<body>
<div class="left">div>
<div class="right">div>
body>
html>
浮动的特性
清除浮动
(由于父级盒子很多情况下不方便给高度,但是子盒子浮动又不占位置,最后父级盒子高度为0时,就会影响下面的标准流盒子,对后面的元素排版产生影响)
额外标签法:在浮动元素末尾添加一个空的块级元素标签,给这个标签添加CSS代码:clear: left; 或clear: right; 或 clear: both(常用); 但是这种方法会导致添加许多无意义的标签,结构性较差
父级元素添加overflow属性:将其属性值设置为诶hidden、auto或scroll;但是这种方法无法显示子元素溢出部分
父级元素添加after伪元素:额外标签法的升级版,没有增加标签,结构更简单
.clearfix:after {
content: "";
display: block; /* 插入的元素必须是块级 */
height: 0;
clear: both;
visibility: hidden;
}
.clearfix { /* IE6、7专有 */
*zoom: 1;
}
父级元素添加双伪元素:代码更简洁
.clearfix:before, .clearfix:after {
content: "";
display: table; /* 前面后面都插入元素 */
}
.clearfix:after {
clear: both;
}
.clearfix { /* IE6、7专有 */
*zoom: 1;
}
常见图片格式
PS切图方式:
(定位可以让盒子自由的在某个盒子内移动位置,或固定在屏幕中某个位置,并且可以压住其他盒子)
(定位=定位模式+边偏移,定位模式用于指定一个元素在文档中的定位方式,边偏移决定了该元素的最终位置)
定位模式:通过CSS的position属性来设置
静态定位:static,默认定位方式,无定位的意思,按照标准流的方式摆放位置,没有边偏移
相对定位:relative,移动位置时参照点是自己原来的位置,不脱标,继续保留原来位置,不会影响后面的元素布局,最典型的应用是给绝对定位当爹
绝对定位:absolute
如果没有祖先元素或祖先元素没有定位,则以浏览器即Document文档为准定位
如果祖先元素有定位,无论是相对、绝对、固定定位,都以最近一级的有定位的祖先元素为参考点移动位置
脱标,不再占有原先位置
元素绝对定位水平居中小技巧:加了绝对定位的盒子不能通过margin: 0 auto设置水平居中,但可以通过设置盒子左侧绝对定位left: 50%走到父级元素水平中心位置,再设置盒子margin-left: -自身宽度一半的距离
与浮动类似,行内元素添加绝对定位,可以直接设置高度和宽度;块级元素添加绝对定位,如果不给宽度或高度,默认大小是内容的大小;绝对定位的元素不会触发外边距合并的问题
与浮动不同,绝对定位的元素会压住下面标准流盒子的所有内容,包括图片和文字
固定定位:fixed
以浏览器可视窗口为参照点移动元素,跟父元素没有任何关系,不随滚动条滚动
脱标,不占有原先位置
元素固定定位在版心右侧的小技巧:让固定定位的盒子left: 50%走到浏览器可视区一半的位置,再设置盒子margin-left: 版心宽度一半的距离
与浮动类似,行内元素添加固定定位,可以直接设置高度和宽度;块级元素添加固定定位,如果不给宽度或高度,默认大小是内容的大小;固定定位的元素不会触发外边距合并的问题
与浮动不同,固定定位的元素会压住下面标准流盒子的所有内容,包括图片和文字
粘性定位:sticky,以浏览器的可视窗口为参照点移动元素;必须添加top、left、right、bottom其中一个才有效,意思是当距离可视化窗口某个边多少像素时开始有粘性定位的效果,否则就把它当相对定位来看;不脱标,占有原先位置;跟页面滚动搭配使用,兼容性较差,IE不支持
边偏移:有四个属性,属性值单位px,或者相对于父元素宽高的百分比
(如果一个盒子既有left属性,也有right属性,则默认会执行left属性,同理会默认优先执行top属性,而不是bottom属性)
定位叠放次序:z-index属性控制,只有定位的盒子才有z-index属性,无论是哪种定位方式;属性值可以是正整数、负整数或0,数字后面不能加单位,默认是auto;数值越大盒子越靠上,如果属性值相同,则按照书写顺序后来者居上
子绝父相:子级绝对定位不会占有位置,可以放在父盒子里的任何一个地方,不会影响其他兄弟盒子;父盒子需要加定位限制子盒子在父盒子里显示,又需要占有位置,因此父亲只能是相对定位;当然子绝父相不是永远不变的,如果父亲不需要占有位置,子绝父绝也会遇到
元素显示与隐藏
(又称aprites精灵图或雪碧图)
核心原理:将网页中一些小背景图像整合到一张大图中,这样服务器只需要一次请求就可以了
精灵图的使用
主要针对小背景图片使用,就是把多个小背景图片整合到一张大图片中
需要精确测量每个小背景图片的大小和位置,大小决定盒子的大小,位置决定背景图片移动距离
移动背景图片位置使用background-position,即这个目标图片的x、y坐标,一般都是负值
.box2 {
width: 27px;
height: 25px;
margin: 200px;
background:
url(images/sprites.png) no-repeat -155px -106px;
}
精灵图优缺点
(iconfont)
字体图标产生目的:主要针对精灵图中一些结构和样式复杂一点的小图片,为前端工程师提供一种方便高效的图标使用方式,展示的是图标,本质属于字体
字体图标的优点
字体图标的使用
字体图标的下载
下载包fonts文件夹中字体文件样式
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5Tdv7KVZ-1654060785228)(https://gitee.com/imagesss/warehouse1/raw/master/20220410115744.png)]
字体图标引入到html页面
把下载包里面的fonts文件夹放到需要使用字体图标的html页面根目录下
在CSS样式中全局声明字体(从下载包里的style.css中直接复制粘贴就行,一定要注意字体文件路径的问题)
@font-face {
font-family: 'icomoon';
src: url('fonts/icomoon.eot?p4ssmb');
src: url('fonts/icomoon.eot?p4ssmb#iefix') format('embedded- opentype'),
url('fonts/icomoon.ttf?p4ssmb') format('truetype'),
url('fonts/icomoon.woff?p4ssmb') format('woff'),
url('fonts/icomoon.svg?p4ssmb#icomoon') format('svg');
font-weight: normal;
font-style: normal;
font-display: block;
}
html标签内添加小图标:打开下载包里的demo.html文件,复制相应图标,放在标签(如span标签)内
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c6EY6FaD-1654060785231)(https://gitee.com/imagesss/warehouse1/raw/master/20220410115728.png)]
<span>span>
给标签定义字体,务必保证与CSS中声明的@font-face里面字体保持一致
span {
font-family: "icomoon";
}
通过类名调用字体图标
字体图标的追加:上传压缩包里的selection.json至字库网站,然后选中自己相要的新的图标,重新下载压缩包,并替换原来的文件就可以了
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZJ9p9WBN-1654060785233)(https://gitee.com/imagesss/warehouse1/raw/master/20220410122414.png)]
div {
width: 0;
height: 0;
/* 为了照顾兼容性 */
line-height: 0;
font-size: 0;
border: 50px solid transparent;
border-left-color: pink;
}
更改用户鼠标样式
li {cursor: pointer;}
清除表单轮廓
input {outline: none;}
防止表单域拖拽
textarea {resize: none;}
单行文本溢出显示省略号:给装文本的盒子添加如下CSS属性
/* 先强制一行内显示文本(默认normal自动换行) */
white-space: nowrap;
/* 超出的部分隐藏 */
overflow: hidden;
/* 文字用省略号替代超出的部分 */
text-overflow: ellipsis;
多行文本溢出显示省略号:给装文本的盒子添加如下CSS属性;但是有较大兼容性问题,适合于webKit浏览器或移动端(移动端大部分是webkit内核);其实更推荐让后台人员做这个效果
/* 超出的部分隐藏 */
overflow: hidden;
/* 文字用省略号替代超出的部分 */
text-overflow: ellipsis;
/* 弹性伸缩盒子模型显示 */
display: -webkit-box;
/* 限制在一个块元素显示的文本的行数 */
-webkit-line-clamp: 2;
/* 设置或检索伸缩盒对象子元素的排列方式垂直居中 */
-webkit-box-orient: vertical;
margin负值的巧妙运用实现浮动的盒子间边框重合效果
在鼠标经过浮动的或标准流的盒子时给盒子添加相对定位并更改边框颜色,实现四条边变色的效果
在鼠标经过本来就有相对定位的盒子时给提高盒子的z-index值并更改边框颜色,实现四条边变色的效果
巧妙运用浮动元素不会压住文字的特性
巧妙运用给盒子设置水平居中对齐,那么它内部的行内块元素和行内元素都会水平居中对齐的特性
巧妙运用行内块元素盒子间本身默认有一定间距的特性
绘制白色不等腰直角三角形:给div添加如下CSS代码
width: 0;
height: 0;
border-color: transparent white transparent transparent;
border-style: solid;
border-width: 22px 8px 0 0;
CSS初始化:不同浏览器对有些标签的默认值是不同的,为了消除不同浏览器对HTML文本呈现的差异,照顾浏览器的兼容性,每个网页都必须首先进行CSS初始化,即重设浏览器样式(以京东首页为例,可去京东官网查看源代码)
* {
/* 清除所有标签内外边距 */
margin: 0;
padding: 0
}
em,
i {
/* em和i标签内斜体文字不倾斜 */
font-style: normal
}
li {
/* 去掉li标签的小圆点 */
list-style: none
}
img {
/* 给img设置border: 0;照顾低版本浏览器图片外边包含了链接会有边框的问题 */
border: 0;
/* 取消图片底侧的空白缝隙 */
vertical-align: middle
}
button {
/* 设置鼠标经过botton按钮时,鼠标变为小手 */
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
}
body {
/* CSS3抗锯齿形让文字显示地更加清晰 */
-webkit-font-smoothing: antialiased;
/* 设置body背景颜色 */
background-color: #fff;
/* 设置body所有字体默认样式 */
/* 把中文字体名称用相应的Unicode编码代替,有效避免浏览器解释CSS代码时出现乱码问题,
如黑体\9ED1\4F53、宋体\5B8B\4F53、微软雅黑\5FAE\8F6F\96C5\9ED1 */
font: 12px/1.5 Microsoft YaHei, Heiti SC, tahoma, arial, Hiragino Sans GB, "\5B8B\4F53", sans-serif;
/* 设置body所有字体默认颜色 */
color: #666
}
.hide,
.none {
display: none
}
/* 清除浮动 */
.clearfix:after {
visibility: hidden;
clear: both;
display: block;
content: ".";
height: 0
}
.clearfix {
*zoom: 1
}
(HTML5新特性都有兼容性问题,基本上的IE9+以上版本浏览器才支持,适合在移动端使用)
(它们都属于块级元素,IE9中需要把这些元素转换为块级元素)
视频标签
语法
<video src="文件地址" controls="controls">video>
支持MP4、WebM、Ogg三种视频格式,尽量使用MP4,几乎所有浏览器都支持,为了兼容性,可以这样设置:
<video width="320" height="240" controls>
<source src="movie.mp4" type="video/mp4">
<source src="movie.ogg" type="video/ogg">
您的浏览器不支持video标签。
video>
常用属性
音频标签
语法
支持MP3、Wav、Ogg三种音频格式,尽量使用MP3,几乎所有浏览器都支持,为了兼容性,可以这样设置:
<audio controls>
<source src="horse.ogg" type="audio/ogg">
<source src="horse.mp3" type="audio/mp3">
您的浏览器不支持audio元素。
audio>
常用属性
(在验证时必须添加form表单域,并添加提交按钮,当我们点击提交按钮时就能验证表单了)
(新增CSS3特性有兼容性问题,ie9+才支持,移动端更适合)
(属性选择器、结构伪类选择器与类选择器、伪类选择器优先级权重相同,均为(0,0,1,0))
属性选择器
结构伪类选择器
E:first-child:匹配父元素中的第一个子元素,此子元素必须是E标签,否则无效
E:last-child:匹配父元素中的最后一个子元素,此子元素必须是E标签,否则无效
E:nth-child(n):匹配父元素中的第n个子元素,此子元素必须是E标签,否则无效
E:first-of-type:匹配父元素中第一个E元素
E:last-of-type:匹配父元素中的最后一个E元素
E:nth-of-type(n):匹配父元素中的第n个E元素
<head>
<style>
section div:nth-of-type(1){
background-color: blue;
}
style>
head>
<body>
<section>
<p>光头强p>
<div>熊大div>
<div>熊二div>
section>
body>
伪元素选择器
(创建的伪元素在文档树中找不到,属于行内元素,必须有content属性)
(伪元素选择器和标签选择器的权重一样,都为(0,0,0,1))
E::before:在E元素内部的前面插入内容,权重为(0,0,0,1)+(0,0,0,1)=(0,0,0,2)
E::after:在E元素内部的后面插入内容
使用场景
伪元素字体图标
div::after {
position: absolute;
top: 10px;
right: 10px;
content: '\e91e';
color: red;
font-size: 18px;
}
伪元素清除浮动
.clearfix:after {
content: "";
display: block; /* 插入的元素必须是块级 */
height: 0;
clear: both;
visibility: hidden;
}
.clearfix { /* IE6、7专有 */
*zoom: 1;
}
.clearfix:before, .clearfix:after {
content: "";
display: table; /* 前面后面都插入元素 */
}
.clearfix:after {
clear: both;
}
.clearfix { /* IE6、7专有 */
*zoom: 1;
}
伪元素仿土豆效果
.tudou::before {
content: '';
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::before {
display: block;
}
(虽然ie9以下版本浏览器不支持,但不会影响页面布局)
(经常和:hover一起搭配使用)
div {
width: 200px;
height: 100px;
background-color: pink;
transition: width .5s ease 0s, height .5s ease 1s;
}
div:hover {
width: 400px;
height: 200px;
}
translate(移动):不会影响到其他元素的位置,参数可以是像素,可以是百分比(相对于自身元素,常用于盒子中的盒子居中对齐),对行内标签没有效果
rotate(旋转):单位deg,必须写,角度为正顺时针,角度为负逆时针,默认旋转中心点是元素中心点(可以用于做三角,代替字体图标)
transform-origin(设置转换中心点):x y默认转换中心点是(50%,50%),x和y的取值可以是百分比,像素或方位名词(top bottom left right center)
scale(缩放):x和y如果是整数,意思是放大多少倍,小数意思是缩小,如果只写一个参数,则第二个参数和第一个参数一样;可以设置转换中心点缩放,默认以盒子中心点缩放,不影响其他盒子;scale会让阴影变大
2D转换综合写法
(相比较过渡,动画可以实现更多变化,更多控制,连续自动播放等效果)
keyframes(定义动画):用from和to等同于0%和100%,百分比是总时间的划分
@keyframes 动画名称 {
0% {
transform: translate(0,0);
}
25% {
transform: translate(1000px,0);
}
50% {
transform: translate(1000px,500px);
}
75% {
transform: translate(0,500px);
}
100% {
transform: translate(0,0);
margin-left: 100px;
}
}
animation(调用动画):谁用谁调用
translate3d(3D移动):
perspective(透视)
rotate3d(3D旋转):
transform-style(3D呈现):代码写给父级,影响子盒子,控制子元素是否开启三维立体环境,默认flat子元素不开启3d立体空间,还有preserve-3d开启3d立体空间
(为了兼容老版本)
/* 提倡的写法 */
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
-o-border-radius: 10px;
border-radius: 10px;
VS Code快速生成html结构语法
VS Code快速生成CSS样式语法
快速格式化代码:
手动格式化代码:右键 -> 格式化文档 或 Shift+Alt+F
设置保存页面时自动格式化代码:文件 -> 首选项 -> 设置
搜索emmet.include -> setting.json下的用户中添加语句"editor.formatOnType":true 和 “editor.formatOnSave”:true
或搜索editor:format将Editor:Format On Save 和 Editor:Format On Type勾选
模块化开发:最典型的应用就是common.css公共样式,包含版心宽度、清除浮动、页面文字颜色等公共样式
网站favicon图标:favicon.ico一般用于作为缩略的网站标志,显示在浏览器的地址栏或标签上
把品优购图标切成png图片
把png图片转换为ico图标,需借助于第三方转换网站,例如比特虫:http://www.bitbug.net/
在html页面里面的
标签里引入代码<link rel="shortcut icon" href="favicon.ico" type="image/x-icon"/>
网站首页TDK三大标签SEO优化:Search Engine Optimization搜索引擎优化,利用搜索引擎的规则提高网站在有关搜索引擎内自然排名
title标签:具有不可替代性,是搜索引擎了解网页的入口和对网页主题归属的最佳判断点,建议:网站名(产品名)-网站介绍(尽量不要超过30个汉字)
<title>品优购商城-综合网购首选-正品低价、品质保障、配送及时、轻松购物!title>
description标签:简要说明网站主要是做什么的
<meta name="description" content="品优购商城-专业的综合网上购物商城,销售加点、数码通讯、电脑、家具百货、服装服饰、母婴、图书、食品等数万个品牌优质商品.便捷、诚信的服务,为您提供愉悦的网上购物体验!" />
keyword标签:页面关键词,是搜索引擎的关注点之一
div {
/* css3盒子模型 */
box-sizing: border-box;
-webkit-box-sizing: border-box;
/* 清除点击高亮,设置为transparent完成透明 */
-webkit-tap-highlight-color: transparent;
/* 在移动端浏览器默认的外观在ios上加上这个属性才能给按钮和输入框自定义样式 */
-webkit-appearance: none;
}
img,
a {
/* 禁用长按页面时的弹出菜单 */
-webkit-touch-callout: none;
}
(当用户没有缩放行为的情况下,布局视口=视觉视口=独立设备像素)
布局视口layout viewport:iOS,Android基本都将这个视口分辨率设置为980px,所以PC的网页大多能在手机上呈现,一般默认可以通过可以手动缩放网页,一般移动设备都默认设置了一个布局视口,用于解决早期的PC端页面在手机上显示的问题
视觉视口visual viewport:是用户正在看到的网站区域,可以通过缩放去操作视觉视口,但不会影响布局视口,布局视口仍保持原来的宽度
理想视口ideal viewport:对于移动设备来说,最理想的情况是用户刚进入页面时不再需要缩放,这就是引进理想视口的原因。对设备来讲是最理想的视口尺寸,需要动手添写meta视口标签通知浏览器操作:
meta视口标签主要目的:布局视口的宽度应该与理想视口的宽度一致,即设备有多宽,我们布局的视口就多宽
语法
属性
物理像素点:指屏幕显示的最小颗粒,是物理真实存在的,是厂商在出厂时就设置好的,比如苹果6\7\8是750*1334
物理像素比:开发时1px不一定等于1个物理像素,PC端页面1px等于1个物理像素,移动端不尽相同;1px能显示的物理像素点的个数,称为物理像素比或屏幕像素比
Retina(视网膜屏幕)是一种显示技术,可以将更多的物理像素点压缩至一块屏幕里,从而达到更高的分辨率,并提高屏幕显示的细腻程度
多倍图:在标准的viewport设置中,使用倍图来提高图片质量,解决在高清设备中的模糊问题,通常使用2倍图(因为iPhone6\7\8的影响,现在还存在3倍图4倍图的情况)
/* 在iphone8下面 */
img {
/* 原始图片100*100px */
width: 50px;
height: 50px;
}
.box {
/* 原始图片100*100px */
background-size: 50px 50px;
/* 只写一个参数肯定是宽度高度省略了,会等比例缩放 */
/* 属性值可以是百分比,是相对于父盒子来说的 */
/* 属性值可以是cover,完全覆盖盒子,可能有部分背景图片显示不全 */
/* 属性值可以是contain,高度宽度等比例拉伸,当宽度或高度铺满盒子就不再进行拉伸了,可能有部分空白区域 */
}
多倍图切图:使用cutterman切图工具,如选择iOS,@3X是3倍图,@2X是2倍图,@1X是一倍图
通过盒子的宽度设置成百分比来根据屏幕宽度进行伸缩(如50%、200%),不受固定像素的限制,内容向两侧填充
max-width:最大宽度
max-height:最大高度
min-width:最小宽度
min-height:最小高度
常用初始化样式(以京东移动端首页为例)
body {
margin: 0 auto;
min-width: 320px;
max-width: 640px;
background: #fff;
font-size: 14px;
font-family: -apple-system, Helvetica, sans-serif;
line-height: 1.5;
color: #666;
}
二倍精灵图做法
在firework里面吧精灵图等比例缩放为原来的一半,约为也行
之后根据大小测量坐标
代码里面background-size设置为精灵图原来宽度的一半,约为也行,只要和第一步对应就行,如
.sou {
position: absolute;
top: 8px;
left: 50px;
width: 18px;
height: 15px;
background: url(../images/jd-sprites.png) no-repeat -81px 0;
background-size: 200px auto;
}
图片格式
(也称伸缩布局、伸缩盒布局、弹性布局、弹性盒布局)
操作方便,布局简单,移动端应用广泛,PC端浏览器支持情况较差,IE11或更低版本不支持或仅部分支持
flexible Box的缩写,为盒子模型提供最大的灵活性,任何一个容器都可以指定为flex布局,当父盒子设为flex布局以后,子元素的float、clear和vertical-align属性将失效
通过给父盒子添加flex属性来控制子盒子的位置和排列方式,采用flex布局的元素,称为flex容器(container),所有子元素称为flex项目
常见父元素属性
flex-direction:设置主轴的方向
(默认主轴方向就是x轴方向,水平向右;默认侧轴方向就是y轴方向,水平向下)
justify-content:设置主轴上子元素排列方式
flex-wrap:设置子元素是否换行
align-content:设置侧轴上的子元素排列方式(多行,即只能用于子项出现换行的情况,在单行下是没有效果的)
align-items:设置侧轴上的子元素排列方式(单行,即在子项为单项时使用)
flex-flow:复合属性,相当于同时设置了flex-direction(设置主轴方向)和flex-wrap(设置子元素是否换行)
flex-flow: column wrap;
常见子元素属性
flex属性:定义子项目分配剩余空间,用flex表示子项目占的份数,默认0
align-self:控制子项自己在侧轴的排列方式,可覆盖align-items属性,默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch;属性值同align-items
order:定义子项的排列顺序(前后顺序),数值越小,排列越靠前,默认为0
div span:nth-child(2) {
order: -1;
}
rem基础
媒体查询(Media Query)(CSS3新语法)
可针对不同媒体类型或屏幕尺寸定义不同样式,多用于苹果手机、Android手机、平板等设备
语法规范
@media mediatype and|not|only (media feature) {
css-code;
}
mediatype
关键字
媒体特性(只展示三个)
一个CSS文件中多个媒体查询一般按照从大到小或从小到大的思路来写,我们最喜欢的还是从小到大来写,如果有冲突,则后写的可以层叠掉先写的,可以使代码更简洁
使用媒体查询引入资源
针对不同的媒体使用不同stylesheets样式表
直接在link中判断设备的尺寸,然后引用不同的css文件
一个建议:我们媒体查询最好的方法是从小到大,如先写media feature为min-width:320px的媒体查询引入,再写min-width:640px的媒体查询引入
Less基础(Leaner Style Sheets)(CSS预处理器的一种,扩展了CSS的动态特性)
Less中文网址:http://lesscss.cn/
常见的CSS预处理器:Sass、Less、Stylus
Less的使用:新建一个后缀名为less的文件,在这个文件里面书写less语句
Less变量:@变量名:值(变量名不能包含特殊字符,不能以数字开头,对大小写敏感)
Less编译:本质上Less包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器编译生成对应的CSS文件,这样我们的html页面才能使用
(借助EasyLESS插件来实现,只要保存一下Less文件,会自动生成CSS文件)
(更改EasyLESS插件自动保存位置:EasyLESS插件 -> 设置 -> 扩展设置 -> 在settings.json中编辑 -> “less.compile”: {“out”: “…/css/”})
Less嵌套:内层选择器前面没有&符号则被解析为父选择器的后代,如果有&符号则被解析成父元素或父元素的伪类
a{
color: blue;
&:hover { //如果有伪类选择器、交集选择器、伪元素选择器,我们内层选择器前面需要加&
color: red;
}
}
Less运算:任何数字、颜色或者变量都可以参加运算,加(+)减(-)乘(*)除(/),可以使用小括号,可以引用定义的变量
(运算符左右两侧必须敲一个空格隔开)
(两个数参与运算,如果只有一个数有单位,则最后的结果就以这个单位为准)
(两个数参与运算,如果2个数有不同的单位,则最后的结果以第一个单位为准)
媒体查询+rem+less
媒体查询+less:按照设计稿与设备宽度的比例,动态计算并设置html根标签的fontsize大小
@no: 15;
@media screen and (min-width: 320px) {
html {
font-size: 320px / @no;
}
}
@media screen and (min-width: 360px) {
html {
font-size: 360px / @no;
}
}
rem:CSS中设计稿元素的宽、高、相对位置等取值,按照同等比例换算为rem为单位的值
@baseFont: 50;
.search-content {
position: fixed;
top: 0;
left: 50%;
transform:translateX(50%);
width: 15rem;
height: 88rem / @baseFont;
background-color: #FFC001;
}
flexible.js+rem(更简单)github地址:http://github.com/amfe/lib-flexible
原理:把当前设备划分为10等份,但不同设备下比例是一致的,我们只需确定好参考设计稿的html文字大小就可以了,如设计稿750px,则设置html文字大小为75px(步骤见第三点)
不需要写不同屏幕的媒体查询,这些都在flexible.js中做了处理
(需要下载flexible.js文件,并在html中引入这个文件:)
不需要在less中手动写公式计算rem值,让flexible.js来计算
(借助cssrem插件来实现px自动转换rem的操作)
(需要ctrl+逗号或vscode左下角打开设置 -> 打开settings.json -> 修改对应行为“cssrem.rootFontSize": 75 -> 重启生效)
简介
使用
像素大厨+vm/vh:https://www.fancynode.com.cn/pxcook
less+vw/vh
响应式开发:使用媒体查询针对不同宽度的设备进行布局和样式设置,从而适配不同设备
Bootstrap前端开发框架:基于HTML、CSS和JAVASCRIPT
Bootstrap使用四步曲
创建文件结构:加一个官网下载的bootstrap文件夹
创建html骨架结构
引入相关样式文件
书写内容
响应式布局容器:在不同屏幕下通过媒体查询来改变这个布局容器的大小,可以自定义,通过给盒子添加预定义类container和container-fluid实现
Bootstrap流式栅格系统(grid systems,网格系统)(以下均为container布局容器)
Bootstrap里container宽度固定,但不同屏幕下container宽度不同,把不同宽度的container划分为12等份,通过一系列行(row)与列(column)的组合来创建页面布局)
超小屏幕(手机,小于768px):设置宽度为100%(栅格系统类前缀:.col-xs-)
小屏幕(平板,大于等于768px):设置宽度为750px(栅格系统类前缀:.col-sm-)
中等屏幕(桌面显示器,大于等于992px):宽度设置为970px(栅格系统类前缀:.col-md-)
大屏幕(大桌面显示器,大于等于1200px):宽度设置为1170px(栅格系统类前缀:.col-lg-)
可以同时为一列指定多个设备的类名,以便划分不同份数,份数小于12份占不满,大于12份换行,行(row)必须放到container布局容器里面
小列1
小列2
列1
列2
列1
列2
Bootstrap手动修改container宽度
/* Bootstrap里container宽度最大1170px,如果效果图是1280px宽度,需手动修改container宽度 */
@media screen and (min-width: 1280px) {
.container {
width: 1280px;
}
}
Bootstrap引入字体图标:只需要去官网查找相应字体图标类名,加在标签上就行了
/* 修改a标签字体标签的位置等属性 */
.nav a::before {
vertical-align: middle;
padding-right: 5px;
}
Bootstrap添加预定义样式:只需要去官网查找相应样式类名,加在标签上就行了
(https://caniuse.com/)
git可以把我们的本地网站提交上传到远程仓库(码云gitee)里面
利用git提交本地网站到码云新建的仓库里(新建时不勾选使用readme文件初始化这个仓库)
提交码云仓库另一种方式(新建仓库时勾选使用readme文件初始化这个仓库)
码云部署发布静态网站
草料二维码生成网址对应的二维码:https://cli.im
div class=“col-lg-4”>列1
列1
列2
Bootstrap手动修改container宽度
/* Bootstrap里container宽度最大1170px,如果效果图是1280px宽度,需手动修改container宽度 */
@media screen and (min-width: 1280px) {
.container {
width: 1280px;
}
}
Bootstrap引入字体图标:只需要去官网查找相应字体图标类名,加在标签上就行了
/* 修改a标签字体标签的位置等属性 */
.nav a::before {
vertical-align: middle;
padding-right: 5px;
}
Bootstrap添加预定义样式:只需要去官网查找相应样式类名,加在标签上就行了
(https://caniuse.com/)
git可以把我们的本地网站提交上传到远程仓库(码云gitee)里面
利用git提交本地网站到码云新建的仓库里(新建时不勾选使用readme文件初始化这个仓库)
提交码云仓库另一种方式(新建仓库时勾选使用readme文件初始化这个仓库)
码云部署发布静态网站
草料二维码生成网址对应的二维码:https://cli.im