# prop()

{% tabs %}
{% tab title="💾 程式" %}

```javascript
// ⭐️ prop(style, propName[,val])
//
//    get: 
//      • style.paddingLeft                 // get DOM style prop
//      • prop(style, 'padding-left')       // get CSS prop ⭐️
//      • prop(style, '--css-var')          // get CSS var ⭐️
//      
//    set: 
//      • prop(style, 'padding-left', '8px') // set CSS prop ⭐️
//      • prop(style, '--css-var', '4px')    // set CSS var ⭐️
//      • style.paddingLeft = '8px'          // set DOM style prop
function prop(style, propName, val=undefined){
  
    const camelCase = !propName.includes('-');
  
    // set prop if necessary
    if (val) {
      if (camelCase) style[propName] = val; // style.propName = val
      else style.setProperty(propName, val);// style.setProp('prop-name', val)
    }
  
    // return prop value
    return camelCase 
      ? style[propName]                    // style.propName
      : style.getPropertyValue(propName);  // style.getProp('prop-name') 
};
```

{% endtab %}

{% tab title="👥 相關" %}

* [style.prop()](https://lochiwei.gitbook.io/web/browser/dom/type/cssstyledeclaration)
* [elem.styleProp()](https://lochiwei.gitbook.io/web/browser/dom/type/element/+ext/.styleprop)
* [elem.attr()](https://lochiwei.gitbook.io/web/browser/dom/type/element/+ext/.attr)
  {% endtab %}

{% tab title="📘 手冊" %}

* MDN ⟩ CSSStyleDeclaration ⟩&#x20;
  * .[setProperty](https://developer.mozilla.org/en-US/docs/Web/API/CSSStyleDeclaration/setProperty)()
  * .[getPropertyValue](https://developer.mozilla.org/en-US/docs/Web/API/CSSStyleDeclaration/getPropertyValue)()
    {% endtab %}
    {% endtabs %}
