2小时-带你实现-360官网-主题换肤功能

简介: 2小时-带你实现-360官网-主题换肤功能

css不是一门变量语言?css不支持变量?css不支持函数编程?

本次公开课将会带你敲开css高级用法的大门,让你的css能力得到一个质的提升!

然后要注意的事,重点吸收的部分是less,原生的css变量 只是作为一个了解即可。

技术预备

为了更好的吸收本章节技术,你需要具备 基本的前端能力哦。

  1. HTML
  2. CSS
  3. JAVASCRIPT

css的使用回顾

我们以前在css中编写可以复用的代码,大部分都是通过 的方式来实现 如,

.hidden{
  display: none;
}
.center-block{
  margin: 0 auto;
}
.text-center{
  text-align: center;
}

但是稍微碰到复杂一点的需求,就发现无法很好的解决了。如:

不同颜色的外观


.color1_outline{
  background-color: blue;
  border-top: 1px solid blue;
  box-shadow: 0 0 1px 1px blue;
}
.colo2r_outline{
  background-color: red;
  border-top: 1px solid red;
  box-shadow: 0 0 1px 1px red;
}



可以看到,上述的两个类,只是颜色名不一样,剩下的代码其实是一样的,但是却无法很好的维护这段代码。

又或者如:

多个盒子中的背景位置 等比例变化


.box1{
  background-position: 10px 10px;
}
.box2{
  background-position: 20px 20px;
}
.box3{
  background-position: 30px 30px;
}
.box4{
  background-position: 40px 40px;
}
......box5

可以看到,以上代码是存在同样的规律的,有编程思维的可爱的人儿瞬间就想到 使用循环来处理,可惜 css 不支持!

css中的变量

css其实也可以像JavaScript一样,支持变量的功能的!

IE和 Opera 不支持哦

初体验

  1. 声明变量 使用 -- 关键字
  2. 调用变量 使用 var() 函数


div {
      width: 200px;
      height: 200px;
      /* 声明变量 */
      --color: red;
      /* 使用变量 必须放在var函数内 */
      background-color: var(--color);
    }

带默认参数

在使用变量时,如果变量不存在,可以带上默认参数


div {
      height: 500px;
      /* 默认参数  200px */
      padding-top: var(--padding-top,200px);
      /* 默认参数 10px solid red */
      border: var(--border, 10px solid red);
      /* 默认参数  linear-gradient(yellow,red) */
      background-image: var(--img,linear-gradient(yellow,red));
    }
 

变量拼接

css变量还可以进行拼接使用,如


div {
      height: 500px;
      /* 直接拼接 */
      border: var(--b, 1px) solid red;
    }
    div::after {
      --title: "我的页面";
      /* 字符串拼接 */
      content: var(--title) '二〇一九年五月三十日 18:15:24';
    }

变量计算

css的变量不能直接进行计算,必须结合 calc 属性。


div {
      --h: 5;
      --w: 200px;
      /* calc 中  var(--nums) + 100px =  200px + 100px    */
      width: calc( var(--nums) + 100px );
      /* calc 中 var(--h) * 100px = 5 * 100px  */
      height: calc(var(--h) * 100px);
      background-color: red;
    }

作用域

作用域可以简单理解为 css中的层叠

如:

common.css


body{
  --color:red;
}
index.css


body{
  background-color: var(--color);
}

less 预处理器

Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量、Mixin、函数等特性,使 CSS 更易维护和扩展

其他的还有 sass stylues

技术介绍

我们主要来讲解less中的以下技术,掌握以下技术可以让我们再去写 css代码时,速度将得到一个质的提升。

  1. 变量 variable
  2. 混合 mixin
  3. 嵌套
  4. 循环 loop

less的执行过程

  1. 编写符合less语法的less文件
  2. 使用工具将less文件编译成对应的css文件
  1. vscode中 下载 easy less 插件 即可
  1. 页面中引入 编译好的css文件

变量

变量就相当于一个盒子,只要箱子里的东西被改变了,那么谁用到了的这个箱子,都得跟着一起改变


// 声明变量 @变量名:值;
@color:red;
// 使用变量
body{
  background: @color;
}
需要注意的是,不能在单独的两个less文件中引用变量,这两个less文件必须是导入的关系。
如:
index.html


<link rel="stylesheet" href="./common.css">
  <link rel="stylesheet" href="./index.css">
common.less


@color:red;
index.less


body{
  /* 找不到 变量@color */
    color:@color;
}
改成 导入 的 关系 即可。
index.html



<link rel="stylesheet" href="./index.css">
common.less



@color:red;
index.less


@import "common.less";
body{
    color:@color;
}

混合 mixin

可以理解为自定义函数,提供了强大的代码段的复用功能

  1. 声明混合 使用 .关键字
  2. 使用混合 直接 .混合名() 即可


/* 1 声明函数 @c为参数 black 为默认值  */
.changeColor(@c:black){
  background-color: red;
  color: red;
  border: 1px solid @c;
  font-size: 100px;
}
/* 2 使用函数 */
div{
  .changeColor(yellow);
   width:100px;
}

嵌套

嵌套为 less中尤为重要的知识,提供了很简洁操作 同层级元素的语法。

p a 为 div的子元素,p a 是同层级的关系


div{
  background-color: red;
  p{
    background-color: blue;
  }
  >a{
    color: olive;
  }
}

循环 loop

需要注意的是,less中的循环,底层是通过递归来实现的!所以,可能需要多花一点时间去研究。

可以很方便为我们生成如下有规律的代码段


.box1{
  background-position: 10px 10px;
}
.box2{
  background-position: 20px 20px;
}
.box3{
  background-position: 30px 30px;
}
.box4{
  background-position: 40px 40px;
}

使用


/* 1 定义循环函数 */
.loop(@counter) when (@counter > 0) {
  /* 2 钻进去 3 2 1 */
  .loop((@counter - 1));
  /* 3 钻出来 1 2 3 */
  .box@{counter} {
    background-position: @counter*10px @counter*10px;
  }
}
.loop(3);


案例实战

360 修改前

360 修改后

目录
相关文章
|
2天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1517 4
|
29天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
5天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
502 19
|
2天前
|
存储 SQL 关系型数据库
彻底搞懂InnoDB的MVCC多版本并发控制
本文详细介绍了InnoDB存储引擎中的两种并发控制方法:MVCC(多版本并发控制)和LBCC(基于锁的并发控制)。MVCC通过记录版本信息和使用快照读取机制,实现了高并发下的读写操作,而LBCC则通过加锁机制控制并发访问。文章深入探讨了MVCC的工作原理,包括插入、删除、修改流程及查询过程中的快照读取机制。通过多个案例演示了不同隔离级别下MVCC的具体表现,并解释了事务ID的分配和管理方式。最后,对比了四种隔离级别的性能特点,帮助读者理解如何根据具体需求选择合适的隔离级别以优化数据库性能。
179 1
|
8天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
21天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
9天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
451 5
|
7天前
|
存储 人工智能 搜索推荐
数据治理,是时候打破刻板印象了
瓴羊智能数据建设与治理产品Datapin全面升级,可演进扩展的数据架构体系为企业数据治理预留发展空间,推出敏捷版用以解决企业数据量不大但需构建数据的场景问题,基于大模型打造的DataAgent更是为企业用好数据资产提供了便利。
314 2
|
23天前
|
人工智能 IDE 程序员
期盼已久!通义灵码 AI 程序员开启邀测,全流程开发仅用几分钟
在云栖大会上,阿里云云原生应用平台负责人丁宇宣布,「通义灵码」完成全面升级,并正式发布 AI 程序员。
|
25天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2608 22
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析