ホームページ >ウェブフロントエンド >CSSチュートリアル >理解できないかもしれない CSS 属性関数 attr() について話しましょう

理解できないかもしれない CSS 属性関数 attr() について話しましょう

青灯夜游
青灯夜游転載
2021-02-07 10:24:222029ブラウズ

この記事では、CSS 属性関数 attr() について紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

理解できないかもしれない CSS 属性関数 attr() について話しましょう

属性関数 attr() は、HTML 要素の属性値を取得してスタイルで使用するために使用されますが、現時点では、HTML 要素の疑似要素にのみ適用できます。 CSS要素。

理解できないかもしれない CSS 属性関数 attr() について話しましょう

ツールチップの実装

##

nbsp;html>

  
    <meta>
    <meta>
    <title>css attr函数</title>
    <style>
      .tooltip {
        width: 100px;
        position: relative;
        margin: 0 auto;
      }
      .tooltip:hover::after {
        padding: 5px;
        position: absolute;

        /* 在伪元素中作为字符串中使用 */
        content: attr(data-tooltip);
        color: #fff;
        background-color: #000;
        border-radius: 10px;
        top: 25px;
        left: 0;
      }

      /* 箭头 */
      .tooltip:hover .arrow::after {
        content: "";
        position: absolute;
        bottom: -5px;
        left: 20%;
        margin-left: -5px;
        border-width: 5px;
        border-style: solid;
        border-color: transparent transparent black transparent;
      }

    </style>
  
  
    <div>
      Hover me
      <span></span>
    </div>
  
構文内の実験的なプロパティ (現在、すべてのブラウザでサポートされていません)

新しい構文では、さまざまなタイプの CSS プロパティがサポートされています。具体的なサポートについては、MDN ドキュメント#仕様「MDN」を参照してください。たとえば、マージントップを設定する必要がある場合、通常はクラス名を見つけて設定する必要があります。手間を省くために、CSS クラス名の記述に集中して、それをグローバルにインポートして、この書き方はある程度便利にはなりましたが、カスタマイズが足りません 上マージンを15pxにしたい場合は、新たにクラス名を追加する必要があり、やはり面倒です。

<div></div>

//style
.mt10{
    margin-top: 10px;
}
ただし、実験的な属性がサポートしている場合は、次のように記述できます。

<div></div>

//style

[mt] {
    margin-top: attr(mt,0);
}
この記述方法はコンポーネント開発と非常によく似ています。特定のサイズの px 値を指定する必要はありません。任意のサイズの PX 値を HTML 要素に直接指定できます。また、 CSS ベースであり、JS の参加を必要としないため、より軽量になります。ただし、残念ながら現在すべてのブラウザがサポートしていないため、サポートされなくなるのは長期間であると予想されます。幸いなことに、情報を検索している過程で、Zhang Xinxu がすでにこの可能性を検討し、この機能用に Polyfill を作成していることがわかりました。

Polyfill attr() 実験的な属性の原則
CSS カスタム属性を使用して attr の属性値を渡します

      .test-attr {
        --mbNum: attr(mb px);
        margin-bottom: var(--mbNum);
        --mlNum: attr(ml px);
        margin-left: var(--mlNum);
      }
その後、attr() を含むすべてのカスタム属性名を取得しますfunction

    // 获取页面中所有的CSS自定义属性
    var isSameDomain = function (styleSheet) {
        if (!styleSheet.href) {
            return true;
        }

        return styleSheet.href.indexOf(window.location.origin) === 0;
    };

    var isStyleRule = function (rule) {
        return rule.type === 1;
    };

    var arrCSSCustomProps = (function () {
        return [].slice.call(document.styleSheets).filter(isSameDomain).reduce(function (finalArr, sheet) {
            return finalArr.concat([].slice.call(sheet.cssRules).filter(isStyleRule).reduce(function (propValArr, rule) {
                var props = [].slice.call(rule.style).map(function (propName) {
                    return [
                        propName.trim(),
                        rule.style.getPropertyValue(propName).trim()
                    ];
                }).filter(function ([propName]) {
                    return propName.indexOf('--') === 0;
                });

                return [].concat(propValArr, props);
            }, []));
        }, []);
    })();
Print arrCSSCustomProps and get

理解できないかもしれない CSS 属性関数 attr() について話しましょう

最後のステップは、Dom をトラバースすることです。対応するカスタム属性が設定されている場合、 attr を通じて属性値を定義し、CSS で解析できるカスタム属性値に変換します。var

    // attr()语法转换成目前CSS变量可识别的语法
    var funAttrVar2NormalVar = function (objParseAttr, valueAttr) {
        // attr()语法 attr( <attr-name> <type-or-unit>? [, <attr-fallback> ]? )
        // valueVar示意:attr(bgcolor color, deeppink)
        // valueAttr示意: 'deepskyblue'或者null

        var attrName = objParseAttr.attrName;
        var typeOrUnit = objParseAttr.typeOrUnit;

        // typeOrUnit值包括:
        // string | color | url | integer | number | length | angle | time | frequency | cap | ch | em | ex | ic | lh | rlh | rem | vb | vi | vw | vh | vmin | vmax | mm | Q | cm | in | pt | pc | px | deg | grad | rad | turn | ms | s | Hz | kHz | %

        var arrUnits = ['ch', 'em', 'ex', 'ic', 'lh', 'rlh', 'rem', 'vb', 'vi', 'vw', 'vh', 'vmin', 'vmax', 'mm', 'cm', 'in', 'pt', 'pc', 'px', 'deg', 'grad', 'rad', 'turn', 'ms', 's', 'Hz', 'kHz', '%'];

        var valueVarNormal = valueAttr;
        // 如果是string类型
        switch (typeOrUnit) {
            case 'string': {
                valueVarNormal = '"' + valueAttr + '"';
                break;
            }
            case 'url': {
                if (/^url\(/i.test(valueAttr) == false) {
                    valueVarNormal = 'url(' + valueAttr + ')';
                }
                break;
            }
        }

        // 数值变单位的处理
        if (arrUnits.includes(typeOrUnit) && valueAttr.indexOf(typeOrUnit) == -1 && parseFloat(valueAttr) == valueAttr) {
            valueVarNormal = parseFloat(valueAttr) + typeOrUnit;
        }

        return valueVarNormal;
    };

        var valueVarNormal = funAttrVar2NormalVar(objParseAttr, strHtmlAttr);

        console.log(valueVarNormal); //100px
        // 设置
        node.style.setProperty(cssProp, valueVarNormal);  // margin-bottom : 100px</attr-fallback></type-or-unit></attr-name>
objParseAttr は attr (mb px) で解析されたオブジェクトで、valueAttr はカスタム属性、この例では 100 です。 ##最後に

attr() と互換性実験関数は非常に強力で、非常に柔軟です。後で、この記述方法を必要とするいくつかの一般的に使用される属性を統合し、それらを npm パッケージにカプセル化して、日常的な開発を容易にする予定です。アプリケーション。この記事に関連するコードについては、https://github.com/Kerinlin/CSS-Function/tree/main/Attribute Function

プログラミング関連の知識については、こちらをご覧ください: 理解できないかもしれない CSS 属性関数 attr() について話しましょうProgramming教えます! !

以上が理解できないかもしれない CSS 属性関数 attr() について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。