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 修改后

目录
相关文章
|
7月前
|
小程序 安全 搜索推荐
【社区每周】新版O站上线,小程序新增无需审核的普通模板(2022年7月第三期)
【社区每周】新版O站上线,小程序新增无需审核的普通模板(2022年7月第三期)
117 12
|
设计模式 缓存 前端开发
一款清新优雅的中后台模板,内置丰富可配置的主题(强烈推荐)
Soybean Admin 是一个基于 Vue3、Vite3、TypeScript、NaiveUI、Pinia 和 UnoCSS 的清新优雅的中后台模版,它使用了最新的前端技术栈,内置丰富的主题配置,有着极高的代码规范,基于 mock 实现的动态权限路由,开箱即用的中后台前端解决方案,也可用于学习参考。
|
5月前
|
前端开发
WordPress主题Rizhuti-V2广告位模块美化
WordPress主题Rizhuti-V2广告位模块美化
46 0
|
3月前
WordPress资源产品展示类主题 官网主题 CeoNova-Pro_v4.4
CeoNova-Pro主题是一款轻量级、且简洁大气、产品官网类主题,定位于高端产品官网、同时包含了知识付费、定制服务、问答社区、论坛交流、网址导航、以及付费产品购买下载等全方位覆盖。
47 0
|
6月前
|
PHP SEO
WordPress强大多功能主题模板The7 v9.16.0
The7可以与WPBakery Page Builder(原Visual Composer)和Ultimate Addons的完全无缝集成。它也与大多数流行的插件完全兼容,例如WooCommerce,WPML,Yoast SEO,All in One WP Migration,W3 Total Cache等。大多数用户均表示:The7是迄今为止与这些插件一起使用的最佳主题!
45 2
|
6月前
|
搜索推荐
CSDN自定义模块全攻略,DIY系统原有样式打造出你的专属个性化主页!
CSDN自定义模块全攻略,DIY系统原有样式打造出你的专属个性化主页!
108 0
|
7月前
实践任务1:利用 HBuilderX制作产品展示模块+实践任务2:利用 HBuilderX制作公司网站首页+实践任务3: 利用 HBuilderX制作公司网站首页实现固定侧边菜单
实践任务1:利用 HBuilderX制作产品展示模块+实践任务2:利用 HBuilderX制作公司网站首页+实践任务3: 利用 HBuilderX制作公司网站首页实现固定侧边菜单
100 3
|
7月前
|
PHP
【ripro美化】moban-child模板子主题原创美化包(适用于各类资源下载站)
RiPro主题版本:8.0 PHP版本要求:7.2 当前版本:V1.4 主题设置:全功能后台设置,无需改代码 主题特色:无需替换RIPRO原主题包任何内容即可实现后台全功能开关修改!!!
54 2
【ripro美化】moban-child模板子主题原创美化包(适用于各类资源下载站)
|
7月前
【ripro美化】全站美化包WordPress RiPro主题二开美化版sucaihu-childV1.9(功能集成到后台)
1、【宝塔】删除ripro文件,上传最新ripro版本,然后上传压缩包内的ripro里面的对应文件到ripro主题对应内覆盖(找到对应路径单个文件去覆盖)。 2、然后上传ripro-chlid子主题美化包到/wp-content/themes路径下 3、注意顺序 原版–>美化包–>后台启用子主题(已启用请忽略)。
182 0
【ripro美化】全站美化包WordPress RiPro主题二开美化版sucaihu-childV1.9(功能集成到后台)
|
7月前
ripro子主题wori-child集成后台美化包(适用于设计素材站+资源下载站等)
新内容如下 1、子主题独立运行,彻底摆脱覆盖原主题文件 2、下载信息插件升级优化 3、细节优化
82 0
ripro子主题wori-child集成后台美化包(适用于设计素材站+资源下载站等)