首页 > 其他分享 >CSS引入方式

CSS引入方式

时间:2023-01-09 23:12:24浏览次数:40  
标签:style 方式 样式 标签 css 引入 import CSS

内联式、 行内引入:

引入方法

  1. 直接在html的标签中书写css。这是一种最为原始也是最容易理解的
  2. 样式内容书写在html标签的style属性中,多个css样式可以写在一起,使用分号隔开。<标签名 style="具体样式属性: 属性值;">内容</标签名>
  3. 样式书写是 样式名:样式值; (注意全部是英文半角符号)

内联式特点:

  1. 冗余代码多,代码量大
  2. 不利于维护和修改
  3. 优先级相对来说较高,个别特殊的效果可以使用,但是不要滥用
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>内联式引入css</title>
</head>
<body>
    <ul>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
        <li style="background-color: green;width: 100px;height: 100px;float: left;margin: 10px;color: #fff;text-align: center;line-height: 100px;"></li>
    </ul>
</body>
</html>Copy to clipboardErrorCopied

 

嵌入式引入 头部引入

引入方法

  1. 可以把样式书写在style标签中

  2. 然后把style标签放在head标签中

  3. 使用css选择器选择你要控制的元素,然后书写样式

    /*样式书写格式:*/
    选择器{
        样式名1:样式值1;
        样式名2:样式值2;
    }Copy to clipboardErrorCopied

     

引入特点:

  1. 统一放置在 style 标签当中,然后通过选择器,将规定样式和对应的标签建立联系,便于维护和修改
  2. CSS 样式修改时并不需要翻阅 HTML 代码,也不需要去针对每个 HTML 标签处理样式,只需要调整style 标签中的样式,就可以针对性修改,页面达到了样式与结构相分离
  3. 代码量少
  4. 相对整站来说,存在冗余代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>嵌入式引入css</title>

    <style>
        li{
            color:red;
            background-color: yellow;
        }
    </style>
</head>
<body>
<ul>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
</ul>

</body>
</html>Copy to clipboardErrorCopied

 

css外部式引入

引入方式

  1. 在外部新建一个css文件(后缀是.css),把样式写在外部的css文件中。

  2. 当一个页面需要外部css的时候,可以使用link标签把css引入进来,把link标签书写在head标签中 <link rel="stylesheet" type="text/css" href="./index.css">

  3. link标签书写的位置应该和style是一样的

    • href:相关联css的路径
    • rel:stylesheet link引入的css和当前的文档html进行关联
    • type:text/css 引入的格式是text文本,是css文本

     

外部式引入特点:

  1. 将html和css完全分离成两个文件
  2. 一个css文件可以控制多个html文件
  3. 相对单页有冗余代码
  4. 相对来说有服务器压力
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" type="text/css" href="./index.css">
</head>
<body>
    <div>

    </div>
</body>
</html>Copy to clipboardErrorCopied

 

重绘重排

重排和重绘是DOM编程中耗能的主要原因之一:

  • 重排(回流):当render tree中的一部分或者是全部,因为元素的尺寸、布局、隐藏等等改变引起页面的重新渲染,这个过程称作为重排,完成重排以后,浏览器会重新绘制受影响的部分到屏幕,该过程称为重绘。

    重排的情况:

    • 添加或者删除可见的DOM元素
    • 元素位置改变
    • 元素尺寸改变
    • 元素内容改变(例如:一个文本被另一个不同尺寸的图片替代)
    • 页面渲染初始化(无法避免)
    • 浏览器窗口尺寸改变
  • 重绘:当render tree(渲染树)中更新的属性只会影响元素的外观、风格,不会影响元素的布局的时候,浏览器需要重新绘制当前元素的样式,被称作为重绘。

  • 重绘不会引起重排,但重排一定会引起重绘,一个元素的重排通常会带来一系列的反应,甚至触发整个文档的重排和重绘,性能代价是高昂的。

style标签和link标签的书写位置

如果书写到非head标签的位置可能会引起一些问题

  1. 不便于维护:后期维护的时候需要花费时间去寻找代码书写位置
  2. 会引起页面的回流(重排)和重绘
    • 页面从上至下去解析,假设style标签写在body后边,读取这个style之前,整个网页的文档已经渲染的差不多了,发现还有style标签,页面就会重新计算页面的样式 然后重新渲染,所以会引起 重绘和重排,网页可能出现闪烁,并且加载变慢
    • 所以style标签应该书写在head标签中

@import引入

@import是CSS提供引入css文件的一种方式

使用@import方法,在style标签中引入

@import "index.css";
@import url(index.css);
@import url("index.css");Copy to clipboardErrorCopied

 

link引入和@import引入的对比

  1. 功能范围不同 link属于html标签 @import只是css提供的引入css的功能
  2. 加载顺序不同 页面在加载的时候,link引入的css会同时被加载 @import引入的css只有等页面全部下载完成以后才进行加载,所以可能会出现闪烁
  3. 兼容性 link所有浏览器都支持 @import低版本ie不支持
  4. 使用JS控制样式 JS只能控制link标签 @import是不能够被JS控制的

标签:style,方式,样式,标签,css,引入,import,CSS
From: https://www.cnblogs.com/z-bky/p/17038805.html

相关文章

  • mybatis接口方法中可以接收各种各样的参数,mybatis底层对于这些参数进行不同的封装处理
    mybatis底层将传进来的参数封装成map集合,每个集合中会有对应的参数值argx,因此假如不使用注解,会出现下面的错误,提醒找不到该参数###Errorqueryingdatabase.Cause:org......
  • css的复杂选择器
    后代选择器后代选择器使用空格间隔开(AB:在A元素中寻找后代(不一定是儿子)是B的元素)<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>后......
  • tornado原理介绍及异步非阻塞实现方式
    tornado原理介绍及异步非阻塞实现方式以下内容根据自己实操和理解进行的整理,欢迎交流~在tornado的开发中,我们一般会见到以下四个组成部分。ioloop:同一个ioloop实例运......
  • coding通过jenkins的ssh方式拉取代码
    服务器上操作ssh-keygen-mPEM-trsa-b4096-C"xxx.xx@xxx.com" 找到你的id_rsa.pub复制到coding里面去 然后把私钥复制到jenkins里面id_rsa然后确定就可以拉取了,注......
  • 磁盘分区方式
    分区可以把服务器上的数据做物理上的隔离MBR分区MasterBootRecord主引导记录一个分区的最大容量为2T,硬盘不能超过2T最多有四个分区:情况1:四个主分区情况2:三个主......
  • 那些炫酷的CSS文字效果之诗词《兔》
    不知不觉已经迈入2023年,今年是兔年,想到兔子就会联想到玉兔,中秋,胡萝卜,兔子不吃窝边草,这就越扯越远了,今天的主题是用纯CSS来实现各种不错的文字效果,文字则摘录古诗词中有关《......
  • spring-cloud-gateway引入
    spring-cloud-gateway引入总结(含修改响应body)一、版本pom.xml<!--仅保留了spring系的版本--><properties><springframework.version>5.3.22</springframework.v......
  • CSS - 弹性布局 弹性布局的特性,父元素上的弹性布局,当父元素为弹性布局 子元素上的弹性
    1.弹性布局的特性(1)任何一个容器都可以指定为弹性布局(2)当我们为父盒子设置为弹性布局之后,子元素的float,clear,vertical-align属性将失效(3)通过给父元素设置flex属性,......
  • 详解kubernetes的发布方式
    项目的发布方式蓝绿发布:不停止旧版本,直接部署新版本灰度发布:旧版本和新版本共存滚动更新:平滑地将服务更新蓝绿发布蓝绿部署就是不停止旧版本,直接部署新版本部署过......
  • 盖瑞特涡轮增压器 | 完成财务重组,引入新资本并优化资产负债表
    从中桥投资、橡树资本和现有股东筹集13亿美元的新股本将长期债务减少至12.5亿美元等值定期贷款和3亿美元循环信贷融资取消石棉赔偿并解决与霍尼韦尔的所有诉讼增强资源和灵......