在我之前的开发中,CSS对于我来说,要用什么找什么,对CSS的了解并不算深入;在我刚开始深入学习CSS时,第一个遇到的就是CSS数据类型,我听说过JS、TS的数据类型,CSS怎么也有数据类型?但是随着我对CSS数据类型的了解,CSS的大门也在缓缓为我打开!!!

什么是CSS数据类型?

引用《CSS新世界》中的介绍:

CSS数据类型的定义是CSS属性中具有代表性的值,在规范的语法格式中,使用关键字外加一对尖括号表示。

怎么去理解呢,我们可以去看看官方文档中对于 background-color的描述:

background-color : <color>

上面语法示例中的 <color>就是我们说的CSS数据类型;

掌握CSS数据类型对了解CSS新世界的体系和快速学习CSS新特性非常有帮助!!!!!(切记)

为什么要学习CSS数据类型?

首先我们要知道,在CSS中任何CSS属性值,都一定包含一个或者多个数据类型!

在CSS2时代,CSS数据类型的概念并不重要,因为CSS常用的属性翻来覆去就那么几个,这些属性在我们工作中经常用到,久而久之我们也就都记住了。

但是!在CSS3到来的时代,由于各个CSS模块独立发展,CSS3之后并不会再有统一的大版本变化,而是将CSS各个功能模块拆分为小模块独立发展,这也就导致短时间内大量的CSS新属性如雨后春笋般的冒了出来!

为了加速没有争议的CSS特性的标准化,W3C的CSS工作组做出了一项被称为“Beijing doctrine”的决定,该决定将CSS划分为更小的组件,并把这些组件成为模块。这些模块互相独立,各自按照自己的速度走向标准化。

例如:CSS选择器模块已经到了Level 4 了;弹性布局模块还是 Level 1

如果此时我们还和CSS2那样,只是凭借经验去记忆CSS的属性值,去学习CSS的新特性,那么学习起来肯定是十分痛苦的,因为效率非常低下!!!

因此CSS数据类型的优势就出来了,我们无需记住数量繁多的CSS属性值,只需要记住支持的数据类型即可!!

学习CSS数据类型有什么用?

我们直接来举个例子:

background-image 是一个非常常用的CSS属性,我们来看看它的语法结构:

background-image : <image> | none

上面的 <image> 就是一个CSS数据类型,它包括下面这些类型和函数:

  • <url>
  • <gradient>
  • element()
  • image()
  • image-set()
  • cross-fade()
  • paint()

也就是说,我们可以看到background-image属性不仅支持url函数和渐变图像,还支持element()等函数!!

这是,我突然问你:CSS的mask-image属性支持的属性值有哪些呢?

这么突然疑问,如果你没有用过这个属性,那相比一时半会你也想不出答案,让我们来看看官方文档吧!

mask-image : none | <image> | <mask-source>

这个语法中出现了与background-image 一样的 <image> 数据类型!!!这些就豁然开朗了!

这不就代表,background-image 支持的那些<url><gradient>element()image()等等这些属性在mask-image中都是支持的?

这样,我们通过理解CSS数据类型,就学会了mask-image这个语法的一半!

CSS数据类型的互通互联

CSS数据类型除了可以帮助我们快速学习掌握CSS的语法,还能快速更新整个CSS世界的知识库。

举个例子:

我们都知道 background-image属性是支持 paint()函数的,但是我们现在问你,mask-image属性是否支持paint()函数?

此时,如果你是靠记忆实际属性,由于你大脑中的记忆库里没有相关信息的储备,因此你会疑惑,会不解,随后去翻阅官方文档,甚至还要做一个小demo来确认一下。

但是,如果你记忆的是<image>类型,你可以迅速回答出:肯定支持,因为mask-image属性值支持<image>数据类型,<image>数据类型中存在paint()函数。

因此,大家一定要关注CSS的数据类型,这可以让我们学习CSS得新特性更迅速,理解CSS新特新更轻松!

试着学习几个常见的CSS数据类类型。

在以后的工作生活中!尝试去记住数据类型,而不是去记实际的每个属性的属性值吧;

用记住的数据类型,去延伸出实际的属性值,也许会有额外的收获!!!

你不得不了解的CSS数据类型的更多相关文章

  1. 新手不得不注意HTML CSS 规范

    作为一名新进的程序菜鸟,根本不知道从哪里开始学起好,前辈都说HTML CSS 规范是一个十分需要注意的点,要我记下,特地转来保存一下,大家相互学习 //总论 本规范既然一个开发规范,也是一个脚本语言参 ...

  2. 不值一提,却又不得不提的“CSS文本超出部分省略号代替”

    偶然看到一篇类似css技巧与经验总结的文章,其中有一部分非常熟悉,那就是“css控制元素内文本超出部分使用省略号代替”,一般实际工作中, 很多产品经理会对页面UI有这样的要求.还记得,第一次做这个功能 ...

  3. 2014 年 20 款最好的 CSS 工具

    说到 WEB 设计,不得不介绍介绍 CSS 工具,CSS 工具在这里面扮演很重要的角色,可以简化无数开发者和设计师的工作,写出更好的 CSS 代码. 而网上有非常多的 CSS 工具,帮助设计师和开发者 ...

  4. JavaScript 那些不经意间发生的数据类型自动转换

    JavaScript可以自由的进行数据类型转换,也提供了多种显式转换的方式.但是更多的情况下,是由JavaScript自动转换的,当然这些转换遵循着一定的规则,了解数据类型自由转换的规则是非常必要的. ...

  5. Div+CSS总结

    之前最早接触是在牛腩新闻发布系统中,当时看到这些自己是一头雾水,不过好在我们已经形成了这样的学习习惯,先实践在接触理论,这样再学习理论的时候就会想到当初我是怎样的迷茫,这样自己印象更深刻. DIV+C ...

  6. python常用模块1

    一. 什么是模块: 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的代码 ...

  7. background复合属性详解(上):background-image

    background复合属性是个很复杂的属性,花样非常多,比较神奇的是css3 中支持多图片背景了,这篇文章先讲讲background-image属性,其他背景属性会在后续的文章综合总结. 一.最基本 ...

  8. Python之几种常用模块

    模块 注意事项: 所有的模块导入都应该尽量往上写 内置模块 扩展模块 自定义模块 模块不会重复被导入 : sys.moudles 从哪儿导入模块 : sys.path import import 模块 ...

  9. python学习日记(常用模块)

    模块概念 什么是模块 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的代 ...

  10. 周末班:Python基础之模块

    什么是模块 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写 ...

随机推荐

  1. js 原生数据类型判断

    之前一直使用的jquery的数据类型判断,比如:isArray()等,今天看到了一个判断数据类型的简单的原生方法,分享给大家 Object.prototype.toString 方法返回对象的类型字符 ...

  2. 上分准备 VP Codeforces Round #762 (Div. 3) 4题ABCE

    +00:02 +00:16 +01:08   +02:07 VP 情况  4/8 ABCE ,赛时排名可以到823,什么时候我可以上个青 B 本想写个map的二分的,发现自己不会,写了个普普通通的二分 ...

  3. api进阶Day2(低级流)文件流的输出流、读取流。向文件中写入文本数据、读取文件中的字符串、用lambda表达式创建文件过滤器。

    文件流:输出流: package io; import java.io.FileNotFoundException; import java.io.FileOutputStream; import j ...

  4. Python笔记(5)——if 语句一:条件测试(Python编程:从入门到实践)

    每条if语句的核心都是一个值为True或False的表达式.Python根据条件测试的值为True还是False来决定是否执行if语句中的代码.如果条件测试的值为True,Python就执行紧跟在if ...

  5. C# 根据 RichTextBox 内容 动态 重设其大小 以达到 不会 显示滚动条

    /// <summary> /// 根据内容重设大小以达到不会显示滚动条 /// 测试:正确 /// 时间:202106021957 /// </summary> public ...

  6. 探究Tomcat

    一.什么是Tomcat? 用来装载javaWeb程序,可以称它为Web容器.是一个运行java的网络服务器,底层是Sochet的一个程序,他也是JSP和Servlet的一个容器. 二.什么要用Tomc ...

  7. 去除python中数据的0值

    import numpy as np a = [0, 1, 2] a = np.array(a) a = a[a != 0].tolist() print(a) //a = [1, 2]

  8. 2021SWPUCTF-WEB(三)

    error ​ 双引号没有提示的注入,,那就是报错注入了,肯定是个恶心的东西呜呜呜 ?id=1' and updatexml(1,concat(0x7e,(select right(flag,30) ...

  9. What is Weight Lifting?

    Weight lifting is the process of lifting items of great mass in order to increase the muscle size an ...

  10. rename基本操作

    电脑是Macbook, 用Homebrew先安装rename. 如果没安装Homebrew 直接复制到terminal中回车, 时间稍长. ruby -e "$(curl -fsSL htt ...