前端知识点视频补充

news2024/11/23 22:22:48

使用工具:

Vscode使用:

需要下载插件:open in browser。这个插件可以快速打开浏览器。

选择文件夹有两种方式:选择打开文件、拖拽方式(这种最方便)

快捷键:快速生成Htm结构文件:!+回车 (注意是英文符号)

代码格式化:shift+alt+f

向上移动:Alt+up

快速复制一行(复制到上行):shift+Alt+up

一、HTML补充

HTML5 是超文本标记语言。它有两种表现形式:双标签(html、p、div) 和单标签(img、meta)。

<meta>是单标签 用来指定网页格式。常用:<meta charset="utf-8">

路径:

路径分为绝对路径和相对路径。绝对路径就是从d盘一直到目标所在。

相对路径:分为

                          父级路径: ../    一般表示回退到上一个文件夹。然后找到图片所在位置。

                          子级路径: /1.jpg   

                          同级路径:  ./images/1.jpg  

  一般来说,子级路径和同级路径是一起使用的。比如上面一个例子。

超文本链接:<a>

内联元素和块级元素:

 

HTML5新版本 新增的标签:

新增标签的目的是为了利于SEO(搜索引擎)的排名。利于搜索爬虫快速找到。

需要注意的是:存在浏览器版本兼容性问题。

选择器的优先级:

二、CSS补充

CSS是层叠样式表,又叫 级联样式表,简称样式表。

语法:由两部分构成: 选择器;一条或多条声明。

CSS引入样式:

分为:

         内联样式:<p style="~"> </p>

         内部样式:在头部定义。<style>  </style>

         外部样式:<link rel="stylesheet" href="     .css">

选择器:

分为:

         全局选择器:*{     }   它的优先级是最低的

         元素选择器:根据HTML元素选择。而且一旦选择了,就是body部分所有这个元素的样式。  

         类选择器: 用圆点 .   定义。针对所需要的标签使用。注意命名:不能以数字开头。同一个标签可以使用多个类选择器,用空格隔开。例如:<p class="first  second"></p>

         ID选择器:在css里面用#定义。 <h2 id="content" />   #content{   } 。特点:它的名称只能使用一次。(和类选择器不同,类选择器可以使用多次。)

         合并选择器:  p,h2{    }    或者:  .text,.title{    }

需要注意 选择器的优先级:行内样式优先级最高、同级类元素,后者会覆盖前者。

关系选择器:

分为

        后代选择器:E   F{     }  选择E里面所有的F标签

        子代选择器:div > p {   }  紧跟div后的p标签

        相邻兄弟选择器:h3+p{    }   只有相邻的。隔一个都不行

        通用兄弟选择器:E~F{    }   选择E之后的所有同级标签。

CSS盒子模型:

注意下边图像的四个概念。

外边距:透明的、消除边框外的区域。   (撑开自身,内容大小不变)//不是撑大噢

边框:

内边距:消除内容周围区域,是透明的。不过会因为背景的改变而改变,外边距不会。(它会撑大自身,内容大小不变。)

content:显示文本和图像。 

弹性盒模型(flex box):

目的:为了适应不同屏幕的大小。提供一种更加有效的方式对一个容器中的子元素进行排列、对齐和分配 空白空间。

组成:弹性容器(flex-container)和弹性子元素(flex-item)组成。

设置display:flex;(定义 一个弹性容器)  默认是横向摆放。

flex-direction 属性:

row、row-reverse、column(垂直摆放)、column-reverse。

justify-content:

就是相当于 子元素是什么方向,那么它的样式就是什么方向。

 align-items属性:

相当于 子元素是什么方向,它的方向就是子元素的纵向。它一般和justify-content搭配使用。搭配使用可以定义五个方向的位置。

小结:弹性盒模型只能定义5个位置的方向。如果需要指定位置存放。在后续,浮点元素和定位元素会有介绍。

扩展:flex元素,定义宽度权重。

例如:在一个父框架里面定义n个子框架。在子框架设置:flex:2 ;flex:1;flex:1。那么就是占用父框架的几分之几。

文档流:

存在几个问题:高矮不齐、底边对齐;元素之间无空隙;空格折叠。

文档流就是,普通定义的一些选择器,它们会在一个文档里面的样式。

为了解决文档流的问题,提出了脱离文档流的方法。

分别是:浮动、绝对定位、固定定位。

脱离文档流:

浮动:

定义:   它会脱离文档流,相当于在上层有一个布局。 (如果有两个图片都定义:float:left;它们都显示在上层,不会出现有空隙的情况。)

浮动也可以使 同级元素横向摆放。类似于:display:flex;

当浮动的元素超出容器的框架,它会被挤在容器下面。

不同点:浮动可以设置宽高,flex可以适应屏幕。

注意:浮动使元素脱离文档流,且只有左右浮动,无上下浮动。

清除浮动:

浮动的缺点:会造成 父元素高度的塌陷;后续元素受影响。

例如:如果没有设置 父框架的高度,它的框架是靠子元素撑开。而一旦设置子元素为浮动,那么父元素的高度就会变为0。而且后续添加的子元素或者同级元素,它会出现在原本父元素的位置,被设置为浮动的子元素所覆盖。

清除浮动的方法:

           父元素设置高度;      //它可以直接撑开框架,就不需要子元素撑开了。

           对受影响的元素增加clear属性。例如:后续添加的子元素,使用clear:both;无论是左浮动还是右浮动都可以消除。

           overflow清除浮动。  在父元素上添加:overflow:hidden; clear:both;  这种情况下,父元素不能设置高度。

          伪对象方式。   在父元素添加:   .container::after{ content:"";  display:block; clear:both; }。同样,父元素不能设置高度。

小结:在没有对父元素设置高度的情况下,一般使用第三种清除浮动的方式。而第二种清除浮动方式,用于会受影响的子元素或者同级元素下才使用。

定位position:

分为:relative、absolute、fixed。后面两种方式可以脱离文档流。 它们有四个属性值:left、right、top、bottom。

绝对定位absolute:每设置一个绝对定位相当于单独设置一层。

固定定位fixed:它的特点是无论页面怎么流动,它都会固定在页面上。

相对定位和绝对定位 是相对于具有定位的父级属性进行位置调整,如果没有父级元素,就往上找,直到最底层是文档流。

z-index:决定堆叠顺序。谁大,谁放在上面。

CSS新特性:

圆角:border-radius

 50%或者100%都表示圆形。它有四个值:分别表示的顺序是:左上,右下;右上,坐下。

border-radius:1px  2px   3px  4px;

回顾:margin:0 auto;表示图形 在屏幕居中。0表示上下位置不用管,auto表示左右自适应。

阴影:box-shadow

它也有四个值,分别的含义是:h-shadow水平阴影、v-shadow垂直阴影、blur(模糊)和color。

注意blur和color可以合起来 用rgba表示。rgba(0,0,0,0.1)。        0.1就是模糊度。

box-shadow:2px  2px  rgba(0,0,0,0.1);

动画:

是指 使元素从一种样式逐渐变化为另一种样式的效果。(可以改变任意次)

需要指定变化的时间:两种方式:

使用关键词: from (等同于0%)、to(等同于100%);使用百分号:0%表示动画开始、100%表示动画完成。

@keyframes创建动画:

@keyframes myAnim{
  0%   {top: 0px;}
  25%  {top: 200px;}
  50%  {top: 100px;}
  75%  {top: 200px;}
  100% {top: 0px;}
}

animation执行动画: p{  animation:myAnim  5s  linear 0s infinite}    //分别表示动画器名称、持续时间、速度(匀速)、延迟时间、循环次数(无数次)

    还可以加上鼠标触碰就停止的效果:p:hover {    animation-play-state:paused;}

执行动画的一些详情值见下图所示:

 

媒体查询:

  会根据设备的大小 自动识别加载不同的样式。

一般都是在开头设置meta标签:使用设备的宽度作为视图宽度并禁止初始的缩放。(比如:一些在pc屏幕设置宽度后,在缩放,它会等比例缩放,而不是,按照我们需要的样式不变。)

<meta name="viewport" content=" width=device-width ,initial-scale=1,maximum-scale,user-scale=1 ">

媒体查询的语法:

@media screen and()

 

雪碧图Css Sprite:

也叫做css精灵图。

原理:通过background-image 引入背景图片;通过background-position 将背景图片移动到自己需要的位置。

注意:display:block;表示将一个行内联元素变为块级元素。

字体图标:

  当使用图标时,我们可能遇到图片失真的情况,也可能因为图片的数量很多,使页面的加载很慢。继而提出了字体图标的方式。

它的用法:可以参考图标库。从图标库下载代码,然后复制到我们的项目中直接使用。

iconfont-阿里巴巴矢量图标库

 

如果要改变字体图标的样式,建议新建一个类。例如下图:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/781501.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

msvcr100.dll丢失的解决方法

在解决msvcr100.dll丢失问题前&#xff0c;给大家介绍一下为什么msvcr100.dll会丢失 msvcr100.dll文件丢失的原因可能有多种。以下是一些常见的原因&#xff1a; 文件被误删&#xff1a;有时候&#xff0c;用户可能会误删除msvcr100.dll文件&#xff0c;导致其丢失。 文件损…

蓝桥杯专题-真题版含答案-【生命之树】【消除尾一】【密码脱落】【生日蜡烛】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

用户管理功能

后端 # 获取用户列表 bp.get("/user/list") def user_list():users UserModel.query.order_by(UserModel.join_time.desc()).all()user_list [user.to_dict() for user in users]return restful.ok(datauser_list)# 用户是否可用 bp.post("/user/active"…

json-server提供json接口服务--示例版本

一、基于以下数据做接口常用功能的查询 1.1启动服务并且创建数据库文件&#xff0c;对外提供文件如下&#xff1a; {"posts": [{"author": "杰瑞","id": 1},{"id": 2,"title": "json-server","au…

通过Jmeter压测存储过程

一、存储过程准备&#xff1a; 1、建立一个空表&#xff1a; 1 CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER ); 2、建立一个存储过程&#xff1a; 1 2 3 4 5 6 7 8 9 CREATE OR REPLACE PROCEDURE insert_test_data (n IN NUMBER) AS BEGIN --E…

顺丰基于 Flink CDC + Hudi 推进实时业务落地

摘要&#xff1a;本文整理自大数据研发高级工程师唐尚文&#xff0c;在 Flink Forward Asia 2022 数据集成专场的分享。本篇内容主要分为三个部分&#xff1a; 应用场景 实践与优化 未来规划 点击查看原文视频 & 演讲PPT 一、应用场景 1.1 顺丰集团业务概览 顺丰除了大家…

LeetCode153.Find-Minimum-In-Rotated-Sorted-Array<寻找旋转排序数组中的最小值>

题目&#xff1a; 寻找旋转排序数组中的最小值 思路&#xff1a; (1) sort 排序 (2) 循环找最小数。 代码是&#xff1a; //code//1 class Solution { public:int findMin(vector<int>& nums) {int len nums.size() - 1;sort(nums.begin(),nums.end());int fir…

go学习 模块与包 - Init函数 - 如何导入第三方包 - 切片与数组的数据传递方式 - go中文件的读写

目录 包&#xff08;package&#xff09;是组织和复用代码的基本单元。 包的种类&#xff1a; 包的导入 包的组成 如下两个文件中定义了A变量和 sc_num变量&#xff0c;他们的首字母开头分别为大写和小写&#xff0c;因此可以说明A变量是公有变量&#xff0c;而sc_num是私…

【unity之IMGUI实践】通用API实现抽象行为封装【五】

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;uni…

【数字图像处理与应用】模板匹配

【数字图像处理与应用】模板匹配 题目模板匹配原理Matlab代码实现算法介绍显示图像的匹配结果 (最匹配的一个)MATLAB实现运行结果图像的相关值结果&#xff1a;在原图像上绘制检测到的目标位置&#xff1a;显示检测到的目标坐标&#xff1a; 显示图像的匹配结果 (最匹配的三个&…

计讯物联5G千兆网关TG463赋能无人船应用方案,开启自动巡检的智能模式

方案背景 水电站、水库、堤坝等水利工程水下构筑物常年处于水下&#xff0c;并在复杂的水流环境下运行&#xff0c;难免会出现磨蚀、露筋等损伤&#xff0c;而传统的安全监测方式一般是通过潜水员检查上层水柱或通过降低水位进行人工巡查&#xff0c;不仅成本高&#xff0c;效…

深入理解Linux网络——TCP协议三次握手和四次挥手详细流程

文章目录 一、三次握手流程二、为什么握手是三次三、关闭连接的情况四、四次挥手流程五、为什么挥手是四次 系列文章&#xff1a; 深入理解Linux网络——内核是如何接收到网络包的深入理解Linux网络——内核与用户进程协作之同步阻塞方案&#xff08;BIO&#xff09;深入理解L…

EGE-UNet, 轻量化U-Net

随着transform 的出现&#xff0c;现在语义分割网路结构越来越复杂&#xff0c;轻量化网路也较少了&#xff0c;有些轻量化也只是名义上的轻量化。今天我看到一篇很好的论文&#xff0c;上海交大发表在 MICCAI 2023 的最新研究工作&#xff0c;一个称为Efficient Group Enhance…

堆排序与直接选择排序

目录 一、直接选择排序 1.基本思想 2.直接选择排序的特性总结 3.代码实现&#xff1a; 二、堆排序 1. 概念&#xff1a; 2.图像实现&#xff1a; 3.代码实现&#xff1a; 一、直接选择排序 1.基本思想 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09…

Edge 中比较独特的调试技巧

背景 大家日常开发基本都会使用 Chrome&#xff0c;毕竟确实好用。但是基于 Chromium 的新版 Microsoft Edge 已于 2020 年 1 月 15 日发布。 Edge 目前的使用基本跟 Chrome 差不多了&#xff0c;但显然&#xff0c;Edge 团队不仅仅想当 Chrome 的备用。他们也提供了一些特有…

Matlab中实现对一幅图上的局部区域进行放大

大家好&#xff0c;我是带我去滑雪&#xff01; 局部放大图可以展示图像中的细节信息&#xff0c;使图像更加直观和精美&#xff0c;此次使用magnify工具实现对绘制的figure选择区域绘制&#xff0c;图像效果如下&#xff1a; 1、基本图像绘制 这里选择绘制一个散点图&#xff…

jar 命令实践

jar -h非法选项: h 用法: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ... 选项:-c 创建新档案-t 列出档案目录-x 从档案中提取指定的 (或所有) 文件-u 更新现有档案-v 在标准输出中生成详细输出-f 指定档案文件名-m 包含指定清单文…

JAVA SE -- 第十天

&#xff08;全部来自“韩顺平教育”&#xff09; 一、枚举&#xff08;enumeration&#xff0c;简写enum&#xff09; 枚举是一组常量的集合 1、实现方式 a.自定义类实现枚举 b.使用enum关键字实现枚举 二、自定义类实现枚举 1、注意事项 ①不需要提供setXxx方法&#xff…

EMA:指数移动平均

Exponential Moving Average 目的&#xff1a;使得参数变化更加顺滑 设原参数为 param_updates [0.1, 0.2, -0.1, 0.3, -0.2] 使用ema进行变换 param_ema 0 alpha 0.9 for param in params:param_ema alpha * param_ema (1 - alpha) * paramprint(param_ema) 结果为…