CSS - 常用属性和布局方式

目录

前言

一、常用属性

1.1、字体相关

1.2、文本相关

1.3、背景相关

1.3.1、背景颜色

1.3.2、背景图片

1.4、圆角边框

二、常用布局相关

2.1、display

2.2、盒子模型

2.2.1、基本概念

2.2.2、border 边框

2.2.3、padding 内边距

2.2.4、margin 外边距

2.3、弹性布局

2.4、实际开发常用小技巧


前言


这里推荐一个 CSS 属性网站,里面的样式很全,忘记了也可以在这里查~

CSS 参考手册

一、常用属性


1.1、字体相关

        .one {
            /* 字体家族: 默认是微软雅黑 */
            font-family: "宋体";
            /* 字体大小 */
            font-size: 100px;
            /* 字体粗细 */
            font-weight: 900;
            /* 设置字体倾斜*/
            font-style: italic;
        }

例如 hello ,效果如下 

1.2、文本相关

        /* 文本相关 */
        .two {
            font-size: 100px;
            color: red;
            /* 文本对齐: left左对齐、right右对齐、center居中对齐 */
            text-align: center;
            /* 文本装饰:underline下划线、none去除下划线(a 标签) */
            text-decoration: underline;
            /* 文本缩进 */
            text-indent: 20px;
            /* 行高(行间距) */
            line-height: 100px;
        }

例如 world ,效果如下:

1.3、背景相关

1.3.1、背景颜色

        .three {
            width: 200px;
            height: 500px;
            background-color: green;
        }

1.3.2、背景图片

a)通过 background-image 来设置一个背景图片

        .one {
            width: 2000px;
            height: 2000px;
            background-color: grey;
            background-image: url(img/logo.png);
        }

Ps:background: rgba(0, 0, 0, 0.2);  中前三个是三原色调色,最后一个是半透明程度 

例如一个小鸭子图标,使用 background-image 设置背景图片,默认都是 “平铺” ,就类似于铺地砖一样,效果如下: 

b)可以使用 background-repeat 来禁止平铺,如下:

        .one {
            width: 2000px;
            height: 2000px;
            background-color: grey;
            /* 背景图片 */
            background-image: url(img/logo.png);
            /* 禁止平铺 */
            background-repeat: no-repeat;
        }

c)可以 backgroud-position 来设置背景图的位置

        .one {
            width: 2000px;
            height: 2000px;
            background-color: grey;
            /* 背景图片 */
            background-image: url(img/logo.png);
            /* 禁止平铺 */
            background-repeat: no-repeat;
            /* 设置位置 */
            background-position: center center;
        }

d)设置背景图的大小

        .one {
            width: 2000px;
            height: 2000px;
            background-color: grey;
            /* 背景图片 */
            background-image: url(img/logo.png);
            /* 禁止平铺 */
            background-repeat: no-repeat;
            /* 设置位置 */
            background-position: center center;
            /* contain 表示保证图片原有比例的情况下填满容器,cover 表示一定填满容器(忽略比例)
,当然也可以自己手动指定宽高 */
            /* background-size: contain; */
            background-size: 2000px 2000px;
        }

1.4、圆角边框

a)通过 border-radius 可以设置圆角矩形(值为内切圆半径)

        .one {
            width: 300px;
            height: 300px;
            background-color: greenyellow;
            border-radius: 30px;
        }

b)如果是一个正方形,并且 border-radius 的值刚好是边长的一般,此时就得到了正圆形(头像一般都是这么设置的).

        .one {
            width: 300px;
            height: 300px;
            background-color: greenyellow;
            border-radius: 150px;
        }

二、常用布局相关


2.1、display

  • 块级元素: display: block;   
  • 行级元素:display: inline;
  • 隐藏元素:display: none;

每个 html 元素都会有默认的 display 属性,例如 h1 ~ h6、p、div、ul、ol、li、table...... 默认都是 block 块级元素.  而  a 、span、img 默认都是 inline 行级元素.

区别有很多,主要是以下两个方面:

  1. 块级元素默认独占一行,行内元素默认不独占一行
  2. 块级元素可以设置尺寸(width、height),行内元素则不能.

Ps:因此在实际的开发中,我们经常会把行内元素(比如 span),通过 display: block 改成块级元素.

2.2、盒子模型

2.2.1、基本概念

一个 HTML 元素,就是一个矩形的盒子,组成如下:

Ps:这些属性只有块级元素设置才生效

  • margin:外边距.  可以想象成每个房子(盒子)之间的距离.
  • border:边框.  可以想象成房子的墙壁.
  • padding:内边距. 可以想象成墙壁和内部家具(content)的距离.

2.2.2、border 边框

a)border:边框.  可以想象成房子的墙壁.

    <style>
        .one {
            width: 400px;
            height: 500px;
            background-color: grey;
            /* red边框颜色、20px边框粗细、solid边框为实线 */
            border: red 20px solid;
        }
    </style>

b)边框也可以分开设置

        .one {
            width: 400px;
            height: 500px;
            background-color: grey;
            /* red边框颜色、20px边框粗细、solid边框为实线 */
            /* border: red 20px solid; */
            /* 边框也可以分开设置 */
            border-left: red 20px solid;
            border-right: green 20px dotted;
            border-top: blue 20px dashed;
            border-bottom: orange 20px solid;
        }

边框使用注意事项:

设置了边框粗细以后,虽然给 div 设置的尺寸例如是 500*400,但实际上可能却变成了 540* 340,这是因为边框把元素给撑大了!

在实际的开发中,一般不希望见到这种情况,因此可以使用 box-sizing:border-box 属性来避免此情况.

一般会对所有元素都进行如下设置:

        * {
            box-sizing: border-box;
        }

2.2.3、padding 内边距

a)内边距,就是元素和边框的距离,可以想象成墙壁和内部家具的距离.

        .one {
            width: 400px;
            height: 500px;
            background-color: grey;
            border: red 20px solid;
            padding: 30px;
        }

b)也可以设置给四个方向分别设置

        .one {
            width: 400px;
            height: 500px;
            background-color: grey;
            border: red 20px solid;
            /* padding: 30px; */
            /* 可以分别给四个方向设置 */
            /* padding-left: 20px; */
            /* 给上下设置 30px,左右设置 20px */
            /* padding: 30px 20px; */
            /* 给四个方向分别设置,顺序是 上右下左 顺时针顺序设置 */
            padding: 10px 20px 30px 40px;
        }

2.2.4、margin 外边距

外边距:可以想象成每个房子(盒子)之间的距离,用法和 padding 基本一样

这里讲一个特殊用法:把 margin 左右方向设置为 auto ,可以实现元素水平居中的效果(前提是块级元素,并且有设置 width),但是垂直方向设置为 auto,则不能垂直居中.

        .one {
            width: 400px;
            height: 500px;
            background-color: grey;
            margin: 100px auto;
        }

2.3、弹性布局

前面讲到,块级元素默认是独占一行的(垂直方向排列的),有时又想让块级元素能够水平方向排列,就可以使用弹性布局了.

Ps:行内元素虽然也是水平排列,但是不能设置尺寸.

这里我们只需要知道最基础的三个属性即可.

1.开启弹性布局:display: flex ,某个元素一旦开始了弹性布局,此时内部的子元素(子元素里的子元素不受影响),就会按照水平方向排列.

2.水平方向排列规则:通过 justify-content 属性进行设置. 

例如有以下元素

    <div class="one">
        <div class="two">0</div>
        <div class="two">2</div>
        <div class="two">3</div>
        <div class="two">4</div>
        <div class="two">5</div>
    </div>

    <style>
        .two {
            width: 100px;
            height: 100px;
            background-color: greenyellow;
            border: red 3px solid;
        }
    </style>

justify-content: center居中排列:

justify-content: left靠左:

justify-content: right靠右:

justify-content: space-around 分散排列(不占据两边):

justify-content: space-between(占据两边):

justify-content: space-evenly(全部均分,包括左右):

Ps:一般最常用的就是 space-around

3. align-items:设置垂直方向排列,这个一般就用 center 就可以.

        .one {
            display: flex;
            justify-content: space-around;
            align-items: center;
        }

2.4、实际开发常用小技巧

Ps:如果全局全局属性是 Vue-cli 的工程,那么就在 App.vue 中的 style 添加即可

a)一般在开始写项目的 css 样式时,会先进行以下操作,防止一些干扰.

* {
    /* 防止边框将元素撑大 */
    box-sizing: border-box;
    /* 去除浏览器默认样式 */
    padding: 0;
    margin: 0;
}

b)为了让背景图片能铺满整个屏幕,需要给 body 和 html 标签设置自适应高度(随着浏览器的缩放而缩放)

html {
    height: 100%;
}

body {
    height: 100%;
}

height: 100% 就表示高度和父元素一样高.

解释:由于 body 的父元素时 html,而 html 元素的父元素是浏览器窗口,这里设置 100%,就是让 html 元素和浏览器一样高,再让 body 和 html 一样搞,此时 body 就和浏览器窗口一样高了.

c)版心高度设置:我们在做完导航栏以后,接下来版心的高度该如何设置呢?在 CSS 3 中新出了一个语法    height: calc(100% - 50px);    通过他就可以实现. 

  1. 第一个参数:写100% 就表示父元素的高度.
  2. 第二个参数:50px 就是指导航栏的高度(根据实际情况而定).

 注意:减号两侧必须要加空格.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

sql server2014如何添加多个实例 | 以及如何删除多个实例中的单个实例

标题sql server2014如何添加多个实例 前提&#xff08;已安装sql server2014 且已有默认实例MSSQLSERVER&#xff09; 添加新的实例 其实就是根据安装步骤再安装一次&#xff08;区别在过程中说明&#xff09; 双击安装 选择“全新独立安装或添加现有功能” 然后下一步下一…

【Spring Cloud】如何确定微服务项目的Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本

文章目录 1. 版本选择2. 用脚手架快速生成微服务的pom.xml3. 创建一个父工程4. 代码地址 本文描述如何确定微服务项目的Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本。 1. 版本选择 我们知道Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本选择一致性非常重…

小主机折腾记18

这个月冲动消费了小两千块钱…… 1.880g5twr 由于四根2400t的内存条没有用出去&#xff0c;我又把它们装回了惠普的800g5twr&#xff1b; 看到pdd有400块钱的9350K&#xff0c;于是想着给他上一个9350k 在参考了pdd、咸鱼以及淘宝的价格后&#xff0c;我发现400块钱的9350k都…

【JAVA学习笔记】41 - 接口

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter10/src/com/yinhai/interface_ 一、快速入门 usb插槽就是现实中的接口。你可以把手机&#xff0c;相机&#xff0c;u盘都插在usb插槽上&#xff0c;而不用担心那个插槽是专门插哪个的&#x…

Git基本概念与使用

一、Git基本概念 git&#xff0c;是一种分布式版本控制软件&#xff0c;与CVS、Subversion这类的集中式版本控制工具不同&#xff0c;它采用了分布式版本库的作法&#xff0c;不需要服务器端软件&#xff0c;就可以运作版本控制&#xff0c;使得源代码的发布和交流极其方便。g…

信奥赛一本通:数据排序(合影效果、病人排队、明明的随机数、单词排序、出现次数超过一半的数、统计字符数)

数据排序 1182&#xff1a;合影效果1183&#xff1a;病人排队1184&#xff1a;明明的随机数1185&#xff1a;单词排序1186&#xff1a;出现次数超过一半的数1187&#xff1a;统计字符数 1182&#xff1a;合影效果 由题目可知&#xff0c;n个人有 性别与身高两种属性&#xff0c…

Elasticsearch实践:ELK+Kafka+Beats对日志收集平台的实现

可以在短时间内搜索和分析大量数据。 Elasticsearch 不仅仅是一个全文搜索引擎&#xff0c;它还提供了分布式的多用户能力&#xff0c;实时的分析&#xff0c;以及对复杂搜索语句的处理能力&#xff0c;使其在众多场景下&#xff0c;如企业搜索&#xff0c;日志和事件数据分析等…

PDF Reader Pro v2.9.8(pdf编辑阅读器)

PDF Reader Pro是一款PDF阅读和编辑软件&#xff0c;具有以下特点&#xff1a; 界面设计简洁&#xff0c;易于上手。软件界面直观清晰&#xff0c;用户可以轻松浏览文档&#xff0c;编辑注释和填写表单。功能强大&#xff0c;提供了多种PDF处理工具&#xff0c;包括阅读、注释…

北邮22级信通院数电:Verilog-FPGA(6)第六周实验:全加器(关注我的uu们加群咯~)

北邮22信通一枚~ 跟随课程进度更新北邮信通院数字系统设计的笔记、代码和文章 持续关注作者 迎接数电实验学习~ 获取更多文章&#xff0c;请访问专栏&#xff1a; 北邮22级信通院数电实验_青山如墨雨如画的博客-CSDN博客 作者建群啦&#xff01;&#xff01;&#xff01;欢…

基于​Segment-and-Track Anything与ProPainter实现视频一键目标移除与一键祛除水印

一、 ProPainter 1.算法简介 ProPainter是由新加坡南洋理工大学&#xff08;Nanyang Technological University&#xff09;的S-Lab团队开发的一款视频修复工具。它融合了图像和特征修复的优势&#xff0c;以及高效的Transformer技术&#xff0c;旨在提供高质量的视频修复效果…

libcurl Socks5 堆缓冲区溢出漏洞(CVE-2023-38545)详细分析

简介 curl 是用于在各种网络协议之间传输数据的命令行工具&#xff0c;libcurl 用于提供处理网络通信和数据传输的 Api 接口。curl 默认下载缓冲区为 102400 字节&#xff0c;但如果设置低于每秒 102400 字节&#xff0c;缓冲区大小会自动设置为更小的值。libcurl 下载缓冲区默…

AIO开放接口平台免费畅享ChatGPT聊天、联网互动、学术等服务!更有DALL·E 3最强AI绘图功能!

免费畅享&#xff01; AIO平台ChatGPT联网、聊天、学术等服务&#xff01; AIO开放接口平台 | 服务介绍 ALL IN ONE &#xff08;AIO&#xff09;API服务是LLM(大语言模型)开放接口平台&#xff1a;持续接入各种主流的大模型接口&#xff0c;并提供简单、易用、统一的API交互…

第四章 路由基础

目录 4.1 路由器概述 4.1.1 路由器定义 4.1.2 路由器工作原理 4.1.3 路由表的生成方式 &#xff08;1&#xff09;直连路由 &#xff08;2&#xff09;静态路由 &#xff08;3&#xff09;动态路由 4.1.4 路由器的接口 &#xff08;1&#xff09;配置接口 &#xff0…

css中px、em、rem、%、vw、vh、vm、rpx 这些单位的区别

序言 px&#xff1a;像素 相对长度单位&#xff0c;相对于显示器屏幕分辨率(推荐使用) em&#xff1a;相对长度单位 基准点为父节点字体的大小&#xff0c;如果自身定义了font-size按自身来计算&#xff08;浏览器默认字体是16px&#xff09;&#xff0c;整个页面内1em不是一个…

如何将 Helm Chart 推送至 Harbor ?

Author&#xff1a;rab 前言&#xff1a;我们说 Helm 的私有仓库可以是任何 HTTP Server&#xff08;如 Nginx、Apache 等&#xff09;&#xff0c;而 Harbor 自带 Helm 私有仓库的功能&#xff08;但默认是禁用的&#xff0c;需要我们手动启用&#xff09;&#xff0c;如果为了…

电子元器件管理系统 JAVA语言开发

目录 一、系统介绍 二、系统下载 三、系统截图 一、系统介绍 基于VueSpringBootMySQL的电子元器件管理系统包含元器件单位模块、元器件仓库模块、元器供应商模块、元器件品类模块、元器件明细模块、元器件采购模块、元器件采购审核模块、元器件领用模块、学生元器件申请模块…

Cisco IOS XE Web UI 命令执行漏洞

Cisco IOS XE Web UI 命令执行漏洞 受影响版本 Cisco IOS XE全版本 漏洞描述 Cisco IOS XE Web UI 是一种基于GUI的嵌入式系统管理工具&#xff0c;能够提供系统配置、简化系统部署和可管理性以及增强用户体验。它带有默认映像&#xff0c;因此无需在系统上启用任何内容或安…

ideaSSM在线商务管理系统VS开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 SSM 在线商务管理系统是一套完善的信息管理系统&#xff0c;结合SSM框架和bootstrap完成本系统&#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整的源代码 和数据库&#xff0c;系统主…

VS Code C# 开发工具包正式发布

前言 微软于本月正式发布Visual Studio Code C#开发工具包&#xff0c;此前该开发套件已经以预览版的形式在6月份问世。经过4个月的测试和调整&#xff0c;微软修复了350多个问题&#xff0c;其中大部分是用户反馈导致的问题。此外&#xff0c;微软还对产品进行了300多项有针对…

OpenCV 笔记(3):基本图形的绘制

Part11. 绘制简单的图形 绘图功能是 OpenCV 最基础的功能&#xff0c;OpenCV 提供了基础的绘制函数&#xff0c;用于帮助我们绘制一些基本的图形。通过这些函数的组合&#xff0c;我们也可以做一些高级的应用。 11.1 绘制点和圆 OpenCV 的绘制函数相对简单&#xff0c;而且很多…