W3C:
制定网页开发的标准,以使同一个网页在不同浏览器中有相同的效果。
W3C标准:
HTML(Hypertext Markup Language)超文本标记语言
标签
或者
注释: 注释不能嵌套!
标签的属性: 设置标签中的内容如何显示
单引号双引号都可
文档声明(doctype):用来告诉浏览器当前网页的版本
html5:或者
放在最顶端
字符集(charset):编码和解码采用的规则。
乱码问题:编码和解码采用不同的字符集
常见的字符集:
meta标签避免乱码
<head>
<meta charset="utf-8">
head>
doctype html>
<html>
<head>
<meta charset="utf-80">
<title>网页的标题title>
head>
<body>
<h1>网页的大标题h1>
body>
html>
VScode
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>
body>
html>
文件将每个一段时间自动保存,从而达到实时更新的效果,不需要手动保存。
结构在HTML中有些时候,我们不能直接书写一些特殊符号,比如:多个连续的空格,比如字母两侧的大于和小于号
解决方案 :使用html中的实体(转义字符)
实体的语法:
&实体的名字;
空格
>
大于号
<
小于号
©
版权符号
更多实体到W3school网站中找
meta写在head标签里,主要用于设置网页中的一些元数据,元数据不是给用户看的
<head>
<meta charser="utf-8">
head>
//keywords表示网站的关键字,可以同时指定多个关键字,关键字间使用,隔开
//description用于指定网站的描述,网站的描述会显示在搜索引擎的结果中,类似于网站介绍
//title标签的内容会作为搜索结果的超链接上的文字显示
//http-equiv=“refresh” 将页面重定向到另一个网站,过3秒页面跳转到百度网站
h1~h6 共六级标签,重要性递减
h1在网页中的重要性仅次于title标签,一般情况下一个页面中只有一个h1
一般情况下标题标签只会用到h1~h3
在页面中独占一行的叫块元素(block element )
在网页中一般通过块元素来对页面进行布局
行内元素主要用来包裹文字
一般情况下会在块元素内放行内元素,而不会在行内元素中放块元素。
块元素中基本什么都能放
p元素是行内元素,其中不能放任何的块元素
浏览器在解析网页时,会自动对网页中不符合规范的内容进行修正
比如:
网页右键“查看网页源代码”:
查看程序员写的源码
网页右键“检查”或者按F12:
【elements】内存中的代码-浏览器解析并规格化后的代码
布局标签(结构化语义标签)
<ul>
<li>结构li>
<li>表现li>
<li>行为li>
ul>
<ol>
<li>结构li>
<li>表现li>
<li>行为li>
ol>
<dl>
<dt>结构dt>
<dd>结构表示网页的结构,用来规定网页中哪里是标题,哪里是段落<dd>
<dd>结构表示网页的结构,用来规定网页中哪里是标题,哪里是段落<dd>
<dd>结构表示网页的结构,用来规定网页中哪里是标题,哪里是段落<dd>
dl>
<ul>
<li>
aa
<ul>
<li>aa-1li>
<li>aa-2
<ul>
<li>aa-1li>
<li>aa-2li>
ul>
li>
ul>
li>
ul>
br*4==
<a href="./target.html" target="_blank">超链接1a>
<br><br>
<a href="../列表.html">超链接2a>
<br><br>
<a href="./inner/target2.html">超链接3a>
<br><br>
<a href="../outer/target3.html">超链接4a>
<br><br>
<img src="./img/1.gif" alt="松鼠" width="500">
<img src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fww1.sinaimg.cn%2Fmw690%2F002nFBTqgy1gwdu5ry2flj60u00xldoe02.jpg&refer=http%3A%2F%2Fwww.sina.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=jpeg?sec=1639809603&t=348c582f988ad6a27d6c0561a6198081">
<img src="">
用于向当前页面引入一个其他页面,搜索引擎不会爬取引入的页面
<iframe src="https://www.qq.com" width="800" height="600" frameborder="0">iframe>
<audio src="./source/audio.mp3" controls autoplay loop>audio>
<audio controls >
对不起,您的浏览器不支持播放音频!请升级浏览器!
<source src="./source/audio.mp3">
<source src="./source/audio.ogg">
audio>
<audio src="./source/audio.mp3" controls autoplay loop>audio>
<audio controls >
<source src="./source/audio.mp3">
<source src="./source/audio.ogg">
<embed src="./source/audio.mp3" type="audio/mp3" width="300" height="100">
audio>
<video src="./source/audio.mp3" controls autoplay loop>video>
<video controls >
对不起,您的浏览器不支持播放视频!请升级浏览器!
<source src="./source/video.webm">
<source src="./source/video.mp4">
video>
<video src="./source/audio.mp3" controls autoplay loop>video>
<video controls >
<source src="./source/video.webm">
<source src="./source/video.mp4">
<embed src="./source/video.mp4" type="video.mp4" >
video>
hello world
<head>
<style>
p{
color:green;
font-size:50px;
}
style>
head>
/*css注释*/
标签名{}
p{}
h1{}
<style>
p{
}
h1{
}
style>
#id属性值
#box{}
#red{}
<head>
<style>
#red{
color:red;
}
style>
head>
<body>
<p id="red">儿童相见不相识p>
body>
.class属性值
.blue{}
.abc{}
<head>
<style>
.blue{
color:blue;
}
.abc{
font-size:30px;
}
style>
head>
<body>
<p class="blue abc">秋水共长天一色p>
<p class="blue">落霞共孤鹜齐飞p>
body>
*
*{}
<style>
*{
}
style>
复合选择器
交集选择器
选择器1选择器2选择器3选择器n{}
div.red{
font-size:30px;
}
.a.b.c{
color:blue;
}
并集选择器(选择器分组)
选择器1,选择器2,选择器3,选择器n{}
h1,span,.a{
color:green;
}
关系选择器
父元素>子元素
div.box>span{
color:orange;
}
祖先 后代
div span{
color:skyblue;
}
前一个+后一个
p+span{
color:red;
}
兄~弟
p~span{
color:red;
}
属性选择器
标签名[属性名]
选择含有指定属性的元素标签名[属性名=属性值]
选择含有指定属性和属性值的元素标签名[属性名^=属性值]
选择属性值以指定值开头的元素标签名[属性名$=属性值]
选择属性值以指定值结尾的元素标签名[属性名*=属性值]
选择属性值中含有某值的元素的元素p[title]{
}
p[title=abc]{
}
p[title^=abc]{
}
p[title$=abc]{
}
p[title*=abc]{
}
伪类选择器:
:
开头:first-child
第一个子元素:last-child
最后一个子元素nth-child(x)
选中第x个元素
:first-of-type
第一个子元素:last-of-type
最后一个子元素nth-of-type(x)
选中第x个元素:not()
将符合条件的元素从选择器中去除ul>li:not(:nth-child(3))
a:link
表示没访问过的链接(正常链接)a:visited
表示访问过的链接,由于隐私的原因,visited这个伪类只能修改链接的颜色a:hover
表示鼠标移入的状态a:active
表示鼠标点击时的状态伪元素选择器:
::
开头::first-letter
表示第一个字母p::first-letter{
font-size:50px;
}
::first-line
表示第一行p::first-line{
background-color:yellow;
}
::selection
表示选中的内容p::sellection{
background-color:greenyellow;
}
::before
元素的开始div::before{
content:'abc';
color:red;
}
::after
元素的最后div::after{
content:'haha';
color:blue;
}
before和after必须结合content属性来使用
:
连接,以;
结尾p{
color:red;
font-size:40px;
}
<style>
html{
font-size=16px;
}
style>
RGB(红色,绿色,蓝色)
#红色绿色蓝色
width
和height
两个属性来设置border-width
:默认值3px
border-top-width
border-right-width
border-bottom-width
border-left-width
border-color
:可以分别指定四个边的边框,规则和border-width一样
border-style
border:solid 10px orange;
border-top:solid 10px orange;
overflow:auto
overflow-x
overflow-y
<head>
<link rel="stylesheet" href="./css/reset.css">link>
<style>
/*自己的样式在下面*/
style>
head>
margin :50px auto;
左右边界设置为auto<style>
.item{
height:50px;
line-height:50px;
}
style>
<style>
h2{
display:inline-block;
}
style>
<style>
.box1{
width:100px;
height:100px;
padding:10px;
border:10px red solid;
box-sizing:content-box; //默认,盒子大小140*140
}
style>
<style>
.box1{
width:100px;
height:100px;
padding:10px;
border:10px red solid;
box-sizing:border-box;//盒子大小100*100
}
style>
outline:10px red solid;
border:10px red solid;
box-shadow:10px 20px 50px orange;
border-radius:10px 20px 30px 40px;
左上 右上 右下 左下border-top-left-radius:100px 30px;
//水平方向 垂直方向
border-top-right-radius:20px 10px;
border-bottom-left-radius:20px 10px;
border-bottom-left-radius:20px 10px;
border-radius:50%
//圆形
通过浮动可以使一个元素向其父元素的左侧或右侧移动
float:left;
float:right;
float:none;
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>
<style>
header,main,footer{
width: 1000px;
margin:0 auto;
}
header{
height: 150px;
background-color: rgb(247, 244, 244);
}
main{
height: 500px;
background-color: rgb(227, 250, 228);
margin:10px auto;
}
nav,article,aside{
float: left;
height: 100%;
}
nav{
width: 200px;
background-color: rgb(225, 199, 247);
}
article{
width: 580px;
background-color: rgb(182, 245, 250);
float: left;
margin: 0 10px;
}
aside{
width: 200px;
background-color: rgb(253, 188, 248);
}
footer{
height: 150px;
background-color: rgb(250, 240, 213);
}
style>
head>
<body>
<header>header>
<main>
<nav>nav>
<article>article>
<aside> aside>
main>
<footer>footer>
body>
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>cleartitle>
<style>
.box1{
border: 10px red solid;
}
.box2{
height: 100px;
width: 100px;
background-color: #bfa;
float: left;
}
.box3{
height: 200px;
width: 100px;
background-color: rgb(81, 84, 247);
float: left;
}
.box1::after{ //用伪类::after解决css问题
display: block; //解决行内元素不会独占一行
content:'';
clear:both; //清除浮动元素的最大影响
}
style>
head>
<body>
<div class="box1">
<div class="box2">div>
<div class="box3">div>
div>
body>
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>Documenttitle>
<style>
.box1{
width: 200px;
height: 200px;
background-color: blue;
}
.box2{
width: 100px;
height: 100px;
background-color: blueviolet;
margin-top: 100px;
}
style>
head>
<body>
<div class="box1">
<div class="box2">div>
div>
body>
html>
<style>
.box1::before{
content: '';
display: table;
}
style>
<style>
.clearfix::before,
.clearfix::after{
content: '';
display: table;
clear: both;
}
style>
position:static
默认值,元素是静止的没有开启定位position:relative
相对定位top:100px;
bottom:100px;
left:100px;
right:100px;
position:absolute
绝对定位left:0;
right:0;
bottom:0;
top:0;
margin:auto;
position:fixed
固定定位position:sticky
粘滞定位z-index:1
元素的层级color
设置字体颜色font-size
设置字体大小font-family
字体族(字体的格式)font-family:Microsoft YaHei,Heiti,sans-serif;
@font-face
将服务器中的字体直接提供给用户使用<style>
@font-face{
font-family:'myfont';
src:url(./font/**.ttf);
}
style>
name在zeal里的fontawesome文档中找
只有fas和fab两种,出现小方块,就选择另外一种图标的编码;
<style>
.box::before{
content:'图标的编码;';
font-family:‘Font Awesome 6 Brands’;
}
style>
height:100px;
line-height:100px;
font:自重 字体风格 字体大小/行高 字体族
font-weight:normal/bold
字重 字体的加粗font-style:normal/italic
字体的风格 斜体text-align:left/right/center/justify;
两端对齐vertical-align
垂直对齐的方式
img{vertical-align:top/bottom/middle}
text-decoration
<style>
.box{
width:200px;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}
style>
background-color:#bfa;
background-image:url(./img/1.png);
background-repeat:no-repeat;
不重复background-repeat:repeat;
默认值,背景沿x轴和y轴双方向重复background-repeat:repeat-x;
沿x轴重复background-repeat:repeat-y;
沿y轴重复background-position:-50px 300px;
水平方向的偏移量 垂直方向的偏移量background-position:top left;
八个方位可选,需要两个值确定background-clip:border-box;
默认值,背景会出现在边框的下边background-clip:padding-box;
背景出现在内容区和内边距background-clip:content-box;
背景只出现在内容区background-origin:padding-box;
默认值,background-position从内边距开始计算background-origin:border-box;
背景图片的偏移量从边框处开始计算background-origin:content-box;
背景图片的偏移量从内容区开始计算background-size:30px 40px;
宽度 高度background-size:30px ;
高度等比例放缩background-size:cover;
图片的比例不变,将元素铺满(图片可能缺失)background-size:contain;
图片比例不变,将图片在元素中完整显示(元素可能有空白)background:
所有相关样式都可以设置,且没有顺序要求,也没有哪个属性是必须写的background:background-position/background-size
有顺序格式要求background:background-origin background-clip
有顺序要求background-image
来设置background-image:linear-gradient(45deg,.5turn,to right,red 50px,yellow 150px);
线性渐变background-image:repeating-linear-gradient(to right,red,yellow 50px)
可以平铺的线性渐变background-image:radial-gradient(大小 at 位置,颜色 位置,颜色 位置,颜色 位置)
background-image:radial-gradient(farthest-corner at 100px 100px,颜色 位置,颜色 位置,颜色 位置)
<table border="1" width="50%" align="center">
<tr>
<td>A1td>
<td>B1td>
<td>C1td>
<td>D1td>
tr>
<tr>
<td>A2td>
<td>B2td>
<td>C2td>
<td rowspan="2">D2td>
tr>
<tr>
<td>A3td>
<td>B3td>
<td>C3td>
tr>
<tr>
<td>A4td>
<td>B4td>
<td colspan="2">C4td>
tr>
table>
<table>
<thead>
<tr>
<th>头部的单元格th>
tr>
thead>
<tbody>主体tbody>
<tfoot>底部tfoot>
table>
border-spacing:10px;
指定边框之间的距离border-collapse:collapse;
设置边框合并<style>
tr:nth-child(odd){
background-color:#bfa;
}
style>
text-align:center
vertical-align:middle
display:table-cell;
<form action="表单要提交的服务器的地址" >
<input type="text" name="username"/>
<input type="password" name="password"/>
<input type="submit" value="注册"/>
<input type="radio" name="hello" value="a"/>
<input type="radio" name="hello" value="b" checked/>
<input type="checkbox" name="test" value="1"/>
<input type="checkbox" name="test" value="2"/>
<input type="checkbox" name="test" value="3" checked/>
<input type="button" value="按钮"/>
<input type="reset" value="重置"/>
<button type="submit">提交button>
<button type="reset">重置button>
<button type="button">按钮button>
<select name="haha">
<option value="i">选项一option>
<option value="ii">选项二option>
<option value="iii">选项三option>
select>
form>
<input type="checkbox" disabled="disabled"/>
JS&CSS Minifier
Minify:Document
->.mini.,
隔开transition-property:height,width;
transition-property:all;
transition-duration:2s,100ms;
ease
默认值,慢速开始,先加速,再减速linear
匀速运动ease-in
加速运动ease-out
减速运动ease-in-out
先加速 后减速cubic-bezier()
来指定时序函数 https://cubic-bezier.com
steps()
分步执行过渡效果,可以设置第二个值
end
:在时间结束时执行过渡(默认值)start
:在时间开始时执行过渡transition-timing-function:ease;
transition-timing-function:cubic-bezier(.24,.95,.82,-0.88);
transition-timing-function:steps(2,start);
transition-delay:2s;
transition:2s margin-left 1s;
@keyframes test{
from{
margin-left:0;
}
to{
margin-left:700px;
}
}
from
表示动画的开始位置,也可以使用0%
to
表示动画的结束位置,也可以使用100%
animation-name:test;
animation-duration:4s;
animation-delay:2s;
animation-timing-function:ease-in-out;
animation-iteration-count:1;
normal
:默认值,从from
向to
运行,每次都是这样reverse
:从to
向from
运行,每次都这样alternate
:从from
向to
运行,重复执行动画时反向执行alternate-reverse
:从to
向from
运行,重复执行动画时反向执行animation-direction:alternate;
running
:默认值,动画执行paused
:动画暂停animation-play-state:paused;
none
:默认值,动画执行完毕元素回到原来位置forwards
:动画执行完毕元素会停止在动画结束的位置backwards
:动画延时等待时,元素就会处于开始位置both
:结合了forwards和backwardsanimation-fill-mode:both;
animation:test 2s 2 1s alternate;
translateX()
沿X轴方向平移translateY()
沿Y轴方向平移transform:translateY(-100px);
transform:translateY(100%);
margin:0 auto
这种居中方式只适用元素的大小确定left:50%;
top:50%;
transform:translateX(-50%) translateY(-50%);
translateZ()
沿Z轴方向平移html{
perspective:800px;
}
body:hover .box1{
transform:translateZ(400px);
}
rotateX()
rotateY()
rotateZ()
transform:rotateZ(.25turn);
transform:rotateY(180deg) translateZ(400px);
backface-visibility:hidden;
transform-style:perserve-3d;
3D透视效果opacity:0.7;
整个元素的透明度是0.7scaleX()
水平方向缩放scaleY()
垂直方向缩放scale()
双方向的缩放scaleZ()
Z轴方向的缩放,只有3D效果 才能看出来transform:scale(2);
center
transform-origin:20px 20px;
display:flex
设置为块级弹性容器display:inline-flex
设置为行内的弹性容器row
:默认值,弹性元素在容器中水平排列(左向右);主轴:自左向右row-reverse
:弹性元素在容器中反向水平排列(右向左);主轴:自右向左column
:弹性元素在容器中纵向排列(自上向下)column-reverse
:弹性元素在容器中纵向排列(自下向上)nowrap
:默认值,元素不会自动换行wrap
:元素沿着辅轴方向自动换行wrap-reverse
:元素沿着辅轴反方向换行flex-flow:row wrap;
flex-start
:元素沿着主轴起边排列flex-end
:元素沿着主轴终边排列center
:元素居中排列space-around
:空白分布到元素两侧space-between
:空白均匀分布到元素间space-evenly
:空白分布到元素的单侧stretch
:默认值,将元素的长度设置为相同的值flex-start
:元素不会拉伸,沿着辅轴起边对齐flex-end
:沿着辅轴的终边对齐center
:居中对齐baseline
:基线对齐space-around
:空白分布到元素两侧space-between
:空白均匀分布到元素间space-evenly
:空白分布到元素的单侧li:nth-child(1){
align-self:stretch;
}
flex-grow:1;
flex-grow:2;
auto
,表示参考元素自身的高度或宽度flex:增长 缩减 基础;
flex:initial;
initial
:“flex:0 1 auto”auto
:“flex:1 1 auto”none
:“flex:0 0 auto” 弹性元素没有弹性li:nth-child(1){
order:2;
}
li:nth-child(2){
order:3;
}
li:nth-child(3){
order:1;
}
html{
/* css原生也支持变量的设置 */
--color:#ff0;
--length:200px;
}
.box{
width: var(--length);
height: var(--length);
color: var(--color);
}
.box1{
/* calc()计算函数 */
width: calc(200px*2);
height: var(--length);
background-color: var(--color);
}
Easy LESS
->F1->compile less to css->生成一个同名css文件
// less中的单行注释,注释中的内容不会被解析到css中
/*
css中的注释,内容会被解析到css文件中
*/
@变量名
@a:200px;
@b:#bfa;
@c:box6;
@变量名
的形式使用即可.box5{
width: @a;
color:@b;
}
@{变量名}
的形式使用.@{c}{
width: @a;
background-image: url("@{c}/1.png");
}
div{
width: 300px;
height: $width;
}
&
表示外层的父元素.box1{
.box2{
color: red;
}
>.box3{
color: red;
&:hover{
color: blue;
}
}
&:hover{
color: orange;
}
div &{
width: 100px;
}
}
相当于
.box1 .box2 {
color: red;
}
.box1 > .box3 {
color: red;
}
.box1 > .box3:hover {
color: blue;
}
.box1:hover {
color: orange;
}
div .box1 {
width: 100px;
}
:extend()
对当前选择器扩展指定选择器的样式(选择器分组).p1{
width: 100px;
height: 200px;
}
.p2:extend(.p1){
color: red;
}
相当于
.p1,
.p2 {
width: 100px;
height: 200px;
}
.p2 {
color: red;
}
.test(@w:100px,@h:200px,@bg-color:red){ //这部分不会显示在css文件中
width: @w;
height: @h;
border: 1px solid @bg-color;
}
div{
//调用混合函数,按顺序传递参数,可以不用写变量名
.test(200px,300px,#bfa);
.test(@bg-color:red, @h:100px, @w:300px);
}
/
可能会无效(
100vw/@total-width)
*40;.
:height: 175.
/40rem;@import"syn.less";
html{
font-size:5.3333vm;
}
.box1{
width:1.2rem;
height:0.875rem;
}
@media 查询规则{}
all
:所有设备print
:打印设备screen
:带屏幕的设备speech
:屏幕阅读器,
连接多个媒体类型,这样它们之间就是一个并集的关系and
连接多个媒体类型,这样它们之间就是一个交集的关系only
,表示只有。only的使用主要是为了兼容一些老版本浏览器@media print,screen{
body{
background-color:#bfa;
}
}
width
视口的宽度height
视口的高度min-width
视口的最小宽度(视口大于指定宽度时生效)max-width
视口的最大宽度(视口小于指定宽度时生效)@media only screen and (min-width:500px)and(max-width:700px){
body{
background-color:#bfa;
}
}