返回顶部
首页 > 资讯 > 前端开发 > VUE >冷门的css属性有哪些及怎么使用
  • 292
分享到

冷门的css属性有哪些及怎么使用

2024-04-02 19:04:59 292人浏览 泡泡鱼
摘要

这篇“冷门的CSS属性有哪些及怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“冷门的

这篇“冷门的CSS属性有哪些及怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“冷门的css属性有哪些及怎么使用”文章吧。

一、开胃菜 css画背景图: paint

    我们开发中使用的背景图大部分是(png, WEBp等)图片svg矢量图canvas画图, 但是其实我们也可以选择css直接画图, 那css这种甚至都"称不上"编程语言的家伙怎么绘制复杂的图片那?

冷门的css属性有哪些及怎么使用

1: 为元素赋予css属性

div class="box"></div>
.box {
    width: 180px;
    height: 180px;
    border: 1px solid; 
    background: paint(xxxx); // 主角在此
  }

    paint(xxxx); 这里填入的是绘图的"方法名", 往下看就知道啥是"方法名"了, 之所以我这里写"xxxx"非常随意, 是因为我想表达这个名字随便起。

2: 引入js文件

    <script>
      if (window.CSS) {
        // 因为加载文件 需要启动server
        CSS.paintWorklet.addModule("./paint-grid.js");
      }
    </script>

    用法有点诡异, 但核心其实是引入了一个js文件

3: js文件内定义导出的方法

    paint-grid.js文件:

reGISterPaint(
  "xxxx", // 这就是: 方法名
  class {
    paint(context, size) {
      context.fillStyle = 'red';
      context.fillRect(10, 10, 39, 39);
    }
  }
);

    paint方法里面就类似canvas了, 可以正常使用部分js代码。

    当前的效果展示:
冷门的css属性有哪些及怎么使用

4: 可多导出

    当看到需要指定绘制的"方法名"而不是"文件名", 我就知道他一定可以导出多个喽:

registerPaint(
  "xxxx1",
  class {
    paint(context, size) {
      context.fillStyle = 'red';
      context.fillRect(10, 10, 39, 39);
    }
  }
);

registerPaint(
  "xxxx2",
  class {
    paint(context, size) {
      context.fillStyle = 'green';
      context.fillRect(10, 10, 39, 39);
    }
  }
);

两个元素的样式设置

      .box {
        background: paint(xxxx1);
      }
      .box2 {
        margin-top: 20px;
        background: paint(xxxx2);
      }

冷门的css属性有哪些及怎么使用

5: 变量赋予背景灵动

    我们时长遇到需要绘制"非固定大小背影", 此时在paint-grid.jswindow是获取不到的, 但是我们可以使用css变量:

// 在全局定义方便js修改
  :root {
    --bg-size: 60;
  }

    paint-grid.js文件

registerPaint(
  "xxxx1",
  class {
    static get inputProperties() {
      return ["--bg-size"];
    }
    paint(context, size, properties) {
      var bgSize = properties.get('--bg-size');
      context.fillStyle = "red";
      context.fillRect(10, 10, bgSize, bgSize);
    }
  }
);

    inputProperties定义了需要获取哪些属性, paint的第三个参数可以接收这些属性, 这样瞬间就感觉这个属性还有点用啦。
冷门的css属性有哪些及怎么使用

6: 注意事项

  • 不能在js文件的绘制方法里面写alert, 会导致报错阻断绘制:
    冷门的css属性有哪些及怎么使用

  • 要注意维护 paint-grid.js文件与css文件的相关性,  因为大家写代码会下意识的不会认为js方法被css文件里的属性所使用, 这就导致可能后续无删除或者是不敢删除等问题。

  • 适合处理简单的图形, 如果复杂度高了或者还需借助其他"库"的情况, 则不建议使用。

二、字体三连 (镂空、渐变、背景)

1: 镂空字不算罕见

  p {
    font-size: 150px;
    color: white;
    -webkit-text-stroke: 6px red;
  }

冷门的css属性有哪些及怎么使用

2: 渐变色文字

      p {
        font-size: 150px;
        color: white;
        -webkit-text-stroke: 6px red;
        background-color: rosybrown;
        background-image: -webkit-linear-gradient(top, red, #fd8403, yellow);
        -webkit-background-clip: text;
        color: transparent;
      }
 <p>
  高
  <br>
  低
 </p>

冷门的css属性有哪些及怎么使用

3: 文字背景

   我们把"白金之星"(jojo的奇妙冒险中的'人物')的图片作为文字的背景:
冷门的css属性有哪些及怎么使用

      div {
        font-size: 150px;
        background: url(../imgs/jojo.webp) no-repeat;
        background-size: 100%;
        background-origin: border-box;
        -webkit-background-clip: text;
        color: transparent;
      }

冷门的css属性有哪些及怎么使用

    这里的关键点是-webkit-background-clip: text, 意思是将dom内文字以外的区域裁剪掉, 所以就剩文字区域了, 然后文字再设置成透明的。

三、他来了他来了, 他带着炫酷的过场动画走来了

    先看一下咱们用css字体属性做的动动画效果:

冷门的css属性有哪些及怎么使用

    倒计时骨王登场:

冷门的css属性有哪些及怎么使用

    这里的思路就是利用文字的背景图属性, 但是难点是如何让文字变大。

1: 难点与坑点

    文字变大有什么难的? 你可能会说这些so简单, 我们设置文字所在的span标签position: absolute;定位在父级中间不就OK了? 但是如果这样设置就会导致-webkit-background-clip: text;失效, 也就是文本脱离了文档流。

    有同学有会想到 transfORM:scale(1.5); 来动态控制文字的变大, 但是transform依然会使-webkit-background-clip: text;失效。

    所以我想到的是在div中设置flex让文字上下左右居中, 然后调大font-size属性。

    还有一个问题就是背景色问题, 因为设置了背景图的同时没法设置文字外层的背景色。

2: 实现思路

    首先总共需要三层结构, 第一层wrap负责黑色背景色以及overflow: hidden;来截断我们的文字变大, 第二层box负责文字的居中, 并且设置font-size属性让内部元素继承, 第三层span标签负责文字①②③的存放, 因为要控制这些文字的显隐所以需要dom标签包裹。

3: 实现代码

    代码有些粗鄙没有润色

<!DOCTYPE html>
<html>
  <head>
    <style>
      #wrap {
        background-color: black;
        width: 500px;
        height: 500px;
        margin: 0 auto;
        overflow: hidden;
      }
      .box0 {
        background: url(../imgs/jojo.webp) no-repeat;
      }
      .box1 {
        background: url(../imgs/一起干饭.jpeg) no-repeat;
      }
      .box2 {
        background: url(../imgs/gat.webp) no-repeat;
      }
      #box {
        width: 500px;
        height: 500px;
        font-size: 150px;
        margin: 0 auto;
        background-size: 500px 500px;
        background-position: center;
        -webkit-background-clip: text;
        -webkit-text-fill-color: rgba(0, 0, 0, 0.2);
        display: flex;
        justify-content: center;
        align-items: center;
      }
      .text {
        display: none;
      }
    </style>
  </head>
  <body>
    <div id="wrap">
      <div id="box">
        <span>①</span>
        <span>②</span>
        <span>③</span>
      </div>
    </div>
    <script>
      const oBox = document.getElementById("box");
      const textArr = document.getElementsByClassName('text')

      let i = 0;
      let n = 800;
      setInterval(()=>{
        oBox.style.fontSize = n + 'px';
         n+=3
         if(n > 800){
            n = 10;
            textArr[1].style.display = 'none'
            textArr[2].style.display = 'none'
            textArr[0].style.display = 'none'
            textArr[i].style.display = 'block'
            oBox.classList.remove('box1')
            oBox.classList.remove('box2')
            oBox.classList.remove('box3')
            oBox.classList.add(`box${i}`)
            i++
            if(i > 2){
              i = 0
            }
         }
      },5)
    </script>
  </body>
</html>

    把文案改成 "◤ ◢ ✿" 就会出现第一个动图的效果啦!

四、引号: quotes

    所谓引号就相当于给书名加上'书名号', 给语言加上'冒号双引号', 当然他还有一些神奇玩法。

冷门的css属性有哪些及怎么使用

1: 基本使用

 <div class="box">jojo的奇妙冒险</div>
    <style>
      .box {
        quotes: "《" "》";
      }
      .box::before {
        content: open-quote;
      }
      .box:after {
        content: close-quote;
      }
    </style>

效果图:
冷门的css属性有哪些及怎么使用

    这里要注意的是如果没写content: open-quote;会导致前后'书名号'都消失, 但是唯独没写content: close-quote;则会保留展示"《"。

2: 看似鸡肋?

    当前这个基础写法也太鸡肋了, 不就是给"《"起了个别名叫open-quote吗? 并且关键是占用了我的beforeafter, 感觉画蛇添足, 比如我可以用如下的方法进行替换:

  :root {
    --open: "《";
    --close: "》";
  }
  div::before {
    content: var(--open);
  }
  div::after {
    content: var(--close);
  }
<div class="box">jojo的奇妙冒险</div>

3: 套娃高手 quotes 雄起

   其实quotes的看家本领是它可以接受n个参数!

  .box {
    quotes: "--- start" "---- end" "《" "》";
  }
  .box::before {
    content: open-quote;
  }
  .box:after {
    content: close-quote;
  }
    <div class="box">
        <div class="box">jojo的奇妙冒险</div>
        <div class="box">Overlord</div>
        <div class="box">艾尔登法环</div>
    </div>

冷门的css属性有哪些及怎么使用

   神奇的事情出现了, 当出现嵌套结构的时候, 内部的元素会使用第三个与第四个参数作为"引号", 套娃事件出现啦:

  .box {
    quotes: "--- start" "---- end" "(" ")" "《" "》";
  }
  .box::before {
    content: open-quote;
  }
  .box:after {
    content: close-quote;
  }
<div class="box">
  <div class="box">
    <span class="box">jojo的奇妙冒险</span>
  </div>
  <div class="box">
    <span class="box">Overlord</span>
  </div>
  <div class="box">
    <span class="box">艾尔登法环</span>
  </div>
</div>

冷门的css属性有哪些及怎么使用

    说实话这个套娃能力还挺厉害的, 并且我们可以讲 close-quote属性置空, 我想到的就是列表:

  .box {
    quotes: "--- start" "---- end" "1: " "" "-- 2:" "" "---- 3: " "" "------ 4: " "";
  }
  .box::before {
    content: open-quote;
  }
  .box:after {
    content: close-quote;
  }
    <div class="box">
      <div class="box">
        第一:
        <div class="box">
          第二:
          <div class="box">第三:</div>
        </div>
        <div class="box">
          第二:
          <div class="box">
            第三:
            <div class="box">第四:</div>
          </div>
        </div>
      </div>
      <div class="box">
        第一:
        <div class="box">第二:</div>
      </div>
    </div>

冷门的css属性有哪些及怎么使用

   要注意不写close-quote会让css找不到在哪里结束, 所以最好写上并给空值。

五、还原大师: all

CSS all 简写属性 将除了 unicode-bidi 与 direction 之外的所有属性重设至其初始值,或继承值。

   这是一个比较强硬的属性, 可以把几乎所有css属性进行重置:

   我们先设置一下基础的环境

  .wrap {
    font-size: 30px;
    font-weight: 900;
  }
  .box {
    width: 100px;
    height: 100px;
    border: 1px solid;
    background-color: red;
    color: white;
  }
  .box1 {
    all: initial;
  }
  .box2 {
    all: inherit;
  }
  .box3 {
    all: revert;
  }
  <body>
    <div class="wrap">
      <div class="box">你好</div>
      <div class="box box1">你好: initial</div>
      <div class="box box2">你好: inherit</div>
      <div class="box box3">你好: revert</div>
    </div>
  </body>

冷门的css属性有哪些及怎么使用

1: initial : 还原为初始值

顾名思义这里是将 div身上的所有属性都重置了, 不管是"背景颜色"还是"字体颜色", 甚至宽高, 所以这里属于是完全初始化了。

   但是有个大坑, 他会把div原本的display: block改变成display: inline, 也就是说all: initial;将所有属性置为空了, 而不会根据标签属性进行筛选, 所以这个属性有点太绝对了要小心使用。

2: inherit: 集成值保留

   依然是顾名思义,  将所有属性设置为 "继承父级", 并且还原自身的属性, 比如宽高都没有了但是继承了字体大小与字体粗细。

   不是所有css属性的默认值都是'继承', 比如说position的默认值就不是集成, 但是position可以设置为position: inherit;, 这就埋下了隐患请看下一条属性。

3: revert: 还原

   虽然看起来效果与inherit几乎一样, 但是实质上有大区别, 比如如果此时wrap父元素设置position: absolute;, 那么设置了all: inherit的元素为position: absolute;, 设置了all:revert的元素是position: static, 也就是说目标元素单纯的还原成最开始的样式, 剔除掉了后期设置的属性, 但保留一些默认的继承属性, 这个属性虽然兼容性超差但最牛!

4: all的优先级

.box{
    all: revert;
    background-color: red;
}

    这里的背景色是可以设置成功的, 所以all应该算一锤子买卖, 只把设置all属性之前的样式重置。

// 父级
  .box {
    background-color: red !important;
  }
 .box1 {
   all: revert;
 }

    上面是不生效的, 因为all只能重置优先级不如自己选择器的属性, 所以需要all: revert!important;

六、目标元素样式 :target

    这个属性让页面的url参数dom元素互动起来

1: 跳转选中

    比如当前urlhttps://www.xxxxxxxxxxx.com/#target_id则:

  :target {
    background-color: red;
    font-size: 200px;
  }
<div id="target_id">
    你好
</div>

冷门的css属性有哪些及怎么使用

2: 跳转后动画

    我想到的是每次选中元素后让元素有个动画效果, 实在太简单了就不演示了, 说一下这个属性的鸡肋点吧, 比如无法同时传递多个id,  或者传递class, 并且他让css属性与dom结构之间绑定关系变弱了代码不方便维护与阅读。

七、输入框的placeholder样式设置: placeholder-shown

    可以设置当input组件中展示placeholder时的样式:

      input:placeholder-shown {
        background-color: lightblue;
      }

      input {
        width: 300px;
        height: 60px;
      }
 <input placeholder="展示我时为蓝色" />

冷门的css属性有哪些及怎么使用

输入内容则还原
冷门的css属性有哪些及怎么使用

八、换行展示的艺术: hyphens

    当英文单词必须折行时我们是否需要一个'连字符':

<div class="box">
      The auto setting's behavior depends on the language being properly tagged
      so that the appropriate hyphenation rules can be selected.
    </div>
  .box {
    border: 1px solid black;
    width: 200px;
    height: 100px;
  }

冷门的css属性有哪些及怎么使用

    主角暴风登场

      .box {
        border: 1px solid black;
        width: 200px;
        height: 100px;
        hyphens: auto;
      }

冷门的css属性有哪些及怎么使用

    比较可惜的是无法自由定义'连字符'的样式, 否则一定有点有趣。

九、滚动的优质体验: scroll-snap-type

冷门的css属性有哪些及怎么使用

    定义一个滚动时的"临时停顿点", 这个问题直接看gif动画比较直接:

冷门的css属性有哪些及怎么使用

    简单来看就是每次惯性滑动都会停留在特定元素所在位置, 有点像滚动的'锚点':

<!DOCTYPE html>
<html>
  <head>
    <style>
      .box {
        width: 200px;
        height: 150px;
        border: 1px solid;
        border-left: 5px solid black;
        border-right: 5px solid black;
        margin: 40px;
        overflow: auto;
        scroll-snap-type: y mandatory;
      }
      .item {
        border-top: 1px solid red;
        height: 150px;
        
        scroll-snap-align: start none;
      }
    </style>
  </head>
  <body>
    <div class="box">
      <div class="item">11111</div>
      <div class="item">22222</div>
      <div class="item">33333</div>
      <div class="item">44444</div>
      <div class="item">55555</div>
      <div class="item">66666</div>
    </div>
  </body>
</html>

     scroll-snap-type: y mandatory;设置了y轴滚动时尽量停留在'元素点位'上, scroll-snap-align: start none;目标元素自身的滚动起始方向用来对齐, 也就是告诉浏览器滚动后要停留在子元素的哪里。

     在子元素身上设置scroll-margin-top: 20px 可以设置一定的检测距离, 并附加回弹效果:

冷门的css属性有哪些及怎么使用

以上就是关于“冷门的css属性有哪些及怎么使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网VUE频道。

--结束END--

本文标题: 冷门的css属性有哪些及怎么使用

本文链接: https://lsjlt.com/news/98771.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 冷门的css属性有哪些及怎么使用
    这篇“冷门的css属性有哪些及怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“冷门的...
    99+
    2024-04-02
  • FlexBox模型的属性有哪些及怎么使用
    本篇内容介绍了“FlexBox模型的属性有哪些及怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Fl...
    99+
    2024-04-02
  • 实用的CSS属性有哪些
    这期内容当中小编将会给大家带来有关实用的CSS属性有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 1. Outline在调试CSS问题的时候,我常常在指定...
    99+
    2024-04-02
  • css的浮动属性是什么以及其属性值有哪些
    这篇文章将为大家详细讲解有关css的浮动属性是什么以及其属性值有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。在css中,浮动属性是“float”,用于...
    99+
    2024-04-02
  • HTML5新的表单属性有哪些及怎么使用
    本篇内容主要讲解“HTML5新的表单属性有哪些及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5新的表单属性有哪些及怎么使用”吧! 新的 fo...
    99+
    2024-04-02
  • CSS的position属性有哪些
    这篇文章给大家分享的是有关CSS的position属性有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   1、absolute(绝对定位)   absolute是生成觉...
    99+
    2024-04-02
  • css中overflow属性的属性值有哪些
    css 中 overflow 属性有以下属性值:visible:允许内容溢出元素边框hidden:隐藏溢出的内容scroll:显示滚动条,允许滚动查看溢出内容auto:内容溢出时显示滚动...
    99+
    2024-04-28
    css overflow
  • CSS中有哪些常用的属性
    本篇内容主要讲解“CSS中有哪些常用的属性”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS中有哪些常用的属性”吧!CSS 指的是层叠样式表 (Cascading Style Sheets),...
    99+
    2023-06-27
  • CSS filter属性的作用有哪些
    CSS filter属性用于对元素进行图像处理,可以改变图像的颜色、亮度、对比度、饱和度等。具体的作用包括:1. blur:模糊图像...
    99+
    2023-09-05
    CSS
  • css中overflow属性的使用技巧有哪些
    这篇文章给大家分享的是有关css中overflow属性的使用技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   一:overflow基本属性   overflow基...
    99+
    2024-04-02
  • textbox的属性有哪些及怎么设置
    1. 文本内容属性:text,用于获取或设置文本框的内容。设置方法:textbox.text = "文本内容"2. 最大长度属性:M...
    99+
    2023-06-12
    textbox的属性
  • CSS的必记属性有哪些
    本篇文章为大家展示了CSS的必记属性有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Text    color 设置text的颜色...
    99+
    2024-04-02
  • css中的position属性有哪些
    这篇文章将为大家详细讲解有关css中的position属性有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   position属性介绍   (1)css中pos...
    99+
    2024-04-02
  • CSS的分类属性有哪些
    这篇文章主要介绍“CSS的分类属性有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS的分类属性有哪些”文章能帮助大家解决问题。 CSS 分类属性允许你控制...
    99+
    2024-04-02
  • CSS的尺寸属性有哪些
    这篇文章主要介绍了CSS的尺寸属性有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 属性 描述 CSS ...
    99+
    2024-04-02
  • css中的Hyperlink属性有哪些
    这篇文章主要为大家展示了“css中的Hyperlink属性有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中的Hyperlink属性有哪些”这篇文章吧...
    99+
    2024-04-02
  • Css的列表属性有哪些
    这篇文章主要介绍了Css的列表属性有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、类型list-style-type: none(无...
    99+
    2024-04-02
  • CSS的文字属性有哪些
    这篇文章将为大家详细讲解有关CSS的文字属性有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、color : #999999; 2、font-family : 宋体...
    99+
    2024-04-02
  • CSS的字体属性有哪些
    小编给大家分享一下CSS的字体属性有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 属性刻画 font 简写属性。...
    99+
    2024-04-02
  • CSS的背景属性有哪些
    这篇文章主要为大家展示了“CSS的背景属性有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“CSS的背景属性有哪些”这篇文章吧。 属性 刻划 ...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作