Rumah > hujung hadapan web > tutorial css > Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

青灯夜游
Lepaskan: 2022-09-13 10:38:04
ke hadapan
2111 orang telah melayarinya

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

Mungkin kita kadang-kadang secara tidak sedar percaya bahawa atribut css sudah mencukupi dalam perkembangan sebenar semasa, tetapi suatu ketika dahulu kita tiba-tiba terfikir: "Adakah mungkin pemikiran kita terhad? menggunakan atribut CSS, dengan itu kehilangan kreativiti", sama seperti ciptaan . Sebelum ini, kebanyakan orang akan berfikir bahawa 骑马 cukup pantas untuk memenuhi keperluan mereka, jadi saya menyusun nota pembelajaran saya secara khusus dan khususnya saya pergi untuk mempelajari beberapa atribut css yang tidak popular, dan ia ternyata sangat membuahkan hasil, jadi hari ini saya akan memberikan anda sifat-sifat imaginatif ini di sini, dan bersedia untuk mengalami pesona css bersama-sama.

1. Lukisan latar belakang css pembuka selera: cat

Kebanyakan imej latar belakang yang digunakan dalam pembangunan kami ialah (png, webp等)图片, svg矢量图, canvas画图, Tetapi dalam sebenarnya, kita juga boleh memilih css untuk melukis gambar secara langsung. Lalu bagaimanakah lelaki seperti css yang tidak "memanggil" bahasa pengaturcaraan melukis gambar yang kompleks [Pembelajaran yang disyorkan: tutorial video css ]

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

1: Berikan atribut css kepada elemen

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

paint(xxxx); Isikan lukisan di sini "Nama kaedah", anda akan tahu apa itu "nama kaedah" apabila anda melihat ke bawah Sebab mengapa saya menulis "xxxx" di sini adalah sangat santai, kerana saya ingin menyatakan bahawa nama itu boleh dipilih secara santai.

2: Import fail js

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

Penggunaannya agak pelik, tetapi intinya adalah untuk memperkenalkan js文件.

3: Tentukan kaedah eksport dalam fail js

paint-grid.jsFail:

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

paintKaedahnya serupa dengan canvas, anda boleh menggunakan sebahagian daripada kod js seperti biasa.

Paparan kesan semasa:
Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

4: Pelbagai eksport mungkin

Apabila anda melihat "nama kaedah" yang diperlukan untuk ditentukan untuk lukisan " dan bukannya "nama fail", saya tahu dia boleh mengeksport berbilang:

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);
    }
  }
);
Salin selepas log masuk

Tetapan gaya untuk dua elemen

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

5: Pembolehubah memberikan fleksibiliti latar belakang

Kami sering menghadapi keperluan untuk melukis "saiz tidak tetap belakang". >, tetapi Kita boleh menggunakan paint-grid.js:windowcss变量

dan
// 在全局定义方便js修改
  :root {
    --bg-size: 60;
  }
Salin selepas log masuk
Fail

paint-grid.js

dan
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);
    }
  }
);
Salin selepas log masuk
untuk menentukan atribut yang perlu diperolehi, dan parameter ketiga daripada

boleh menerima atribut ini, jadi saya serta-merta merasakan atribut ini agak berguna. inputPropertiespaint
Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

6: Nota

    tidak boleh menulis
  • dalam kaedah lukisan fail

    , ya Mengakibatkan pelaporan ralat dan lukisan menyekat: jsalert
    Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

  • Beri perhatian untuk mengekalkan korelasi antara fail
  • dan fail

    , kerana apabila orang menulis kod , mereka secara tidak sedar tidak akan berfikir bahawa Kaedah paint-grid.js digunakan oleh atribut dalam fail css, yang mungkin membawa kepada masalah seperti kegagalan untuk memadam pada masa hadapan atau takut untuk memadam. jscss

  • sesuai untuk memproses grafik mudah Jika kerumitan tinggi atau "perpustakaan" lain diperlukan, tidak disyorkan untuk menggunakannya.
2 Tiga fon berturut-turut (berongga, kecerunan, latar belakang)

1: Fon berongga bukan perkara biasa

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

2: Teks warna kecerunan

      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;
      }
Salin selepas log masuk
 <p>
  高
  <br>
  低
 </p>
Salin selepas log masuk

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

3: Latar belakang teks

   我们把"白金之星"(jojo的奇妙冒险中的'人物')的图片作为文字的背景:
Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

    倒计时骨王登场:

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

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: 实现代码

    代码有些粗鄙没有润色

nbsp;html>

  
    <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>
  
  
    <div>
      <div>
        <span>①</span>
        <span>②</span>
        <span>③</span>
      </div>
    </div>
    <script>
      const oBox = document.getElementById("box");
      const textArr = document.getElementsByClassName(&#39;text&#39;)

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

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

四、引号: quotes

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

1: 基本使用

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

效果图:
Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

2: 看似鸡肋?

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

  :root {
    --open: "《";
    --close: "》";
  }
  div::before {
    content: var(--open);
  }
  div::after {
    content: var(--close);
  }
Salin selepas log masuk
<div>jojo的奇妙冒险</div>
Salin selepas log masuk

3: 套娃高手 quotes 雄起

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

   要注意不写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;
  }
Salin selepas log masuk
  
    <div>
      <div>你好</div>
      <div>你好: initial</div>
      <div>你好: inherit</div>
      <div>你好: revert</div>
    </div>
  
Salin selepas log masuk

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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;
}
Salin selepas log masuk

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

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

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

六、目标元素样式 :target

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

1: 跳转选中

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

  :target {
    background-color: red;
    font-size: 200px;
  }
Salin selepas log masuk
<div>
    你好
</div>
Salin selepas log masuk

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

2: 跳转后动画

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

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

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

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

      input {
        width: 300px;
        height: 60px;
      }
Salin selepas log masuk
 <input>
Salin selepas log masuk

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

输入内容则还原
Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

八、换行展示的艺术: hyphens

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

    主角暴风登场

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

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

nbsp;html>

  
    <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-margin-top:20px; */
        scroll-snap-align: start none;
      }
    </style>
  
  
    <div>
      <div>11111</div>
      <div>22222</div>
      <div>33333</div>
      <div>44444</div>
      <div>55555</div>
      <div>66666</div>
    </div>
  
Salin selepas log masuk

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

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

Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel

end

     这次神奇的css之旅就是这样, 希望与你一起进步。

(学习视频分享:web前端

Atas ialah kandungan terperinci Mari kita bincangkan tentang 9 sifat CSS yang tidak popular dalam satu artikel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
css
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan