Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

html5 web component

(function() {
  const template = document.createElement('template');

  template.innerHTML = `
    <style>
      button,
      span {
        font-size: 3rem;
        font-family: monospace;
        padding: 0 .5rem;
      }

      button {
        background: pink;
        color: black;
        border: 0;
        border-radius: 6px;
        box-shadow: 0 0 5px rgba(173, 61, 85, .5);
      }

      button:active {
        background: #ad3d55;
        color: white;
      }
    </style>
    <div>
      <button type="button" increment>+</button>
      <span></span>
      <button type="button" decrement>-</button>
    </div>
  `;

  class MyCounter extends HTMLElement {
    constructor() {
      super();

      this.increment = this.increment.bind(this);
      this.decrement = this.decrement.bind(this);

      this.attachShadow({ mode: 'open' });
      this.shadowRoot.appendChild(template.content.cloneNode(true));

      this.incrementBtn = this.shadowRoot.querySelector('[increment]');
      this.decrementBtn = this.shadowRoot.querySelector('[decrement]');
      this.displayVal = this.shadowRoot.querySelector('span');
    }

    connectedCallback() {
      this.incrementBtn.addEventListener('click', this.increment);
      this.decrementBtn.addEventListener('click', this.decrement);

      if (!this.hasAttribute('value')) {
        this.setAttribute('value', 1);
      }
    }

    increment() {
      // using +myVariable coerces myVariable into a number,
      // we do this because the attribute's value is received as a string
      const step = +this.step || 1;
      const newValue = +this.value + step;

      if (this.max) {
        this.value = newValue > +this.max ? +this.max : +newValue;
      } else {
        this.value = +newValue;
      }
    }

    decrement() {
      const step = +this.step || 1;
      const newValue = +this.value - step;

      if (this.min) {
        this.value = newValue <= +this.min ? +this.min : +newValue;
      } else {
        this.value = +newValue;
      }
    }

    static get observedAttributes() {
      return ['value'];
    }

    attributeChangedCallback(name, oldValue, newValue) {
      this.displayVal.innerText = this.value;
    }

    get value() {
      return this.getAttribute('value');
    }

    get step() {
      return this.getAttribute('step');
    }

    get min() {
      return this.getAttribute('min');
    }

    get max() {
      return this.getAttribute('max');
    }

    set value(newValue) {
      this.setAttribute('value', newValue);
    }

    set step(newValue) {
      this.setAttribute('step', newValue);
    }

    set min(newValue) {
      this.setAttribute('min', newValue);
    }

    set max(newValue) {
      this.setAttribute('max', newValue);
    }

    disconnectedCallback() {
      this.incrementBtn.removeEventListener('click', this.increment);
      this.decrementBtn.removeEventListener('click', this.decrement);
    }
  }

  window.customElements.define('my-counter', MyCounter);
})();
Comment

PREVIOUS NEXT
Code Example
Javascript :: self excuting arrow function 
Javascript :: desc sorting in array of objects javascript 
Javascript :: Wikibreak enforcer 
Javascript :: add attribute jquery 
Javascript :: como gerar numeros aleatorios em javascript a partir de uma função 
Javascript :: cloning an element 
Javascript :: fade animation vuetify js 
Javascript :: $(document).ready(function () { $(".inputs").click(function () { alert($(this).id); }); }); 
Javascript :: how to check jasmine version 
Javascript :: seperate array by comma in vue 
Javascript :: Cannot coerce `dirty` to string because boolean [1] should not be coerced. 
Javascript :: split name js 
Javascript :: complite nodejs remove ubuntu 
Javascript :: Getting current location from browser Chrome and Firefox console 
Javascript :: RTC measure react native undefined 
Javascript :: es6 spread operator 
Javascript :: react using props and parent state 
Javascript :: html document from string javascript 
Javascript :: jquery check screen width 
Javascript :: _.isEqual Underscore Example 
Javascript :: javascript get css property 
Javascript :: react native uncaught error main has not been registered stackoverflow 
Javascript :: como contar los checkbox jquery 
Javascript :: facebook access token 
Javascript :: auto refresh vue pwa 
Javascript :: normalisation in js 
Javascript :: declare multiple variable javascript 
Javascript :: javascript program to find largest of 2 numbers 
Javascript :: pageSize useEffect 
Javascript :: setCount 
ADD CONTENT
Topic
Content
Source link
Name
5+2 =