Skip to content

RauliL/pakertaja

Repository files navigation

Pakertaja JavaScript library github-url coveralls npm

Pakertaja is a minimal JavaScript library for constructing DOM elements.

Example

import p from 'pakertaja';

const renderProduct = (title, description) => p.div(
  {
    class: 'product',
    style: {
      background: 'black',
      color: 'white'
    }
  },

  p.h1(title),

  p.p(description),

  p.form(
    p.label({ for: 'quantity' }, 'Quantity: '),
    p.input({ type: 'number', id: 'quantity', min: 10 }),
    p.button(
      'Add to cart',
      {
        type: 'submit',
        onclick(ev) {
          ev.preventDefault();
          alert(`Added ${document.getElementById('quantity').value} products into cart.`);
        }
      }
    )
  )
);

p.append(
  document.body,
  renderProduct(
    'Battlefield Earth DVDs',
    'Critically acclaimed as one of the best movies ever made.'
  )
);

API

p( tagName[, ...args ] )

Constructs and returns HTML element of given tagName, such as div, h1 and so on. Optional arguments might consist from other HTML elements which will be inserted as child elements of the created parent element, text content or objects which contain HTML attributes for the created element.

Shortcuts for most HTML5 elements exist for this function, which allows to create HTML elements of certain type more conveniently. These shortcuts are: html, head, title, base, link, meta, style, script, noscript, body, section, nav, article, aside, h1, h2, h3, h4, h5, h6, header, footer, address, p, hr, br, pre, dialog, blockquote, ol, ul, li, dl, dt, dd, a, q, cite, em, strong, small, mark, dfn, abbr, time, progress, meter, code, var, samp, kbd, sub, sup, span, i, b, bdo, ruby, rt, rp, ins, del, figure, img, iframe, embed, object, param, video, audio, source, canvas, map, area, table, caption, colgroup, col, tbody, thead, tfoot, tr, td, th, form, fieldset, label, input, button, select, datalist, optgroup, option, textarea, output, details, command, bb, menu, legend and div.

Text nodes can also be created with an shortcut function called text and document fragments with fragment.

p.append( root[, ...children ] )

Inserts given child elements to the end of given root element. Child elements might consist from other HTML elements, strings or function callbacks which return strings.

p.prepend( root[, ...children ] )

Inserts given child elements to the beginning of given root element. Child elements might consist from other HTML elements, strings or function callbacks which return strings.

p.escape( input )

Escapes HTML entities from given string input and returns result.

JSX

With TypeScript you can also use Pakertaja with JSX by adding following lines to tsconfig.json file:

{
  "compilerOptions": {
    "jsxFactory": "p",
    "jsxFragmentFactory": "p.fragment"
  }
}

Example

import p from 'pakertaja';

const onClick = (ev: Event) => {
  const quantity = (document.getElementById('quantity') as HTMLInputElement).value;

  ev.preventDefault();
  alert(`Added ${quantity} products into cart.`);
}

const renderProduct = (title: string, description: string): HTMLDivElement => (
  <div class="product" style={{ background: 'black', color: 'white' }}>
    <h1>{title}</h1>
    <p>{description}</p>
    <form>
      <label for="quantity">Quantity:</label>
      <input type="number" id="quantity" min={10} />
      <button type="submit" onclick={onClick}>
        Add to cart
      </button>
    </form>
  </div>
);

p.append(
  document.body,
  renderProduct(
    'Battlefield Earth DVDs',
    'Critically acclaimed as one of the best movies ever made.'
  )
);