@taufik-nurrohman/document

1.1.1 • Public • Published

Document Utility

HTML document object utility.

Usage

CommonJS

const {setElement} = require('@taufik-nurrohman/document');

console.log(setElement('div', 'Content goes here.', {
    'class': 'bar foo',
    'id': 'baz'
}));

ECMAScript

import {setElement} from '@taufik-nurrohman/document';

console.log(setElement('div', 'Content goes here.', {
    'class': 'bar foo',
    'id': 'baz'
}));

Methods

fromElement(node)

Convert element to array of element name, element content and element attributes.

getAttribute(node, attribute, parseValue = true)

getAttributes(node, parseValue = true)

getChild(parent, index = 0)

getChildFirst(parent)

getChildLast(parent)

getChildren(parent, index)

getClass(node)

getClasses(node, toArray = true)

getCookie(cookie, parseValue = true)

getCookies(parseValue = true)

getData(node, parseValue = true)

getDatum(node, datum, parseValue = true)

getElement(query, scope = document)

getElementIndex(node, anyNode)

getElements(query, scope = document)

getFormElement(nameOrIndex)

getFormElements()

getHTML(node, trim = true)

getName(node)

Get element name.

getNext(node, anyNode)

getParent(node, query)

Get element’s parent.

getParentForm(node)

Get closest <form> element from current element.

getPrev(node, anyNode)

getScriptElements()

getStyle(node, style, parseValue = true)

getStyles(node, styles, parseValue = true)

getStyleElements()

getState(node, state)

getText(node, trim = true)

getType(node)

hasAttribute(node, attribute)

hasClass(node, class)

hasParent(node, query)

hasState(node, state)

isComment(node)

isDocument(node)

isElement(node)

isNode(node)

isParent(node, parent, query)

isText(node)

isWindow(node)

letAttribute(node, attribute)

letAttributes(node, attributes)

// Remove all attribute(s)
letAttributes(node);

// Remove `class` and `id` attribute only
letAttributes(node, ['class', 'id']);

// Remove `class` and `id` attribute only
const removeValueAttribute = false;
letAttributes(node, {
    'class': true,
    'id': true,
    'value': removeValueAttribute // Keep this attribute
});

letChildFirst(parent)

letChildLast(parent)

letChildren(parent)

letClass(node, class)

letClasses(node, classes)

// Remove all class(es)
letClasses(node);

// Remove `bar` and `foo` class only
letClasses(node, ['bar', 'foo']);

// Remove `bar` and `foo` class only
const isButtonDisabled = false;
letClasses(node, {
    'active': isButtonDisabled, // Keep this class
    'bar': true,
    'foo': true
});

letCookie(cookie)

letCookies(cookies)

letData(node, data)

// Remove all `data-*` attribute(s)
letData(node);

// Remove `data-bar` and `data-foo` attribute only
letData(node, ['bar', 'foo']);

// Remove `data-bar` and `data-foo` attribute only
const removeBazData = false;
letData(node, {
    'bar': true,
    'baz': removeBazData, // Keep this attribute
    'foo': true
});

letDatum(node, datum)

letElement(node)

letHTML(node)

letNext(node)

letPrev(node)

letState(node)

letStyle(node, style)

letStyles(node, styles)

// Remove all style(s)
letStyles(node);

// Remove `left` and `top` style only
letStyles(node, ['left', 'top']);

// Remove `left` and `top` style only
const removePositionStyle = false;
letStyles(node, {
    'left': true,
    'position': removePositionStyle, // Keep this style
    'top': true
});

letText(node)

replaceClass(node, from, to)

replaceClasses(node, classes)

setAttribute(node, attribute, value)

setAttributes(node, attributes)

// Add `bar` and `foo` attribute(s)
// Remove the `baz` attribute if exists
setAttributes(node, {
    'bar': 100,
    'baz': false,
    'foo': 1
});

setChildFirst(parent, node)

setChildLast(parent, node)

setClass(node, class)

setClasses(node, classes)

// Set class value(s) to `['bar', 'foo']`
setClasses(node, 'bar foo');

// Add `bar` and `foo` to the class value(s)
setClasses(node, ['bar', 'foo']);

// Add `bar` and `foo` to the class value(s)
// Remove the `baz` value if exists
setClasses(node, {
    'bar': true,
    'baz': false,
    'foo': true
});

setCookie(cookie, value, days = 1)

setCookies(cookies, days = 1)

setData(node, data)

// Add `data-bar` and `data-foo` attribute(s)
// Remove the `data-baz` attribute if exists
setData(node, {
    'bar': 100,
    'baz': false,
    'foo': 1
});

setDatum(node, datum, value)

setElement(name|node, content, attributes)

Create a HTML element or update the existing HTML element.

console.log(setElement('div', 'Content goes here.', {
    'id': 'foo-bar'
}));

console.log(setElement('input', false, {
    'name': 'title',
    'type': 'text',
    'value': 'Title Goes Here'
}));

console.log(setElement('input', {
    'name': 'title',
    'type': 'text',
    'value': 'Title Goes Here'
}));
let input = getElement('input[name="title"][type="text"]');

console.log(setElement(input, {
    'value': 'Title Goes Here'
}));

setHTML(node)

setNext(current, node)

setPrev(current, node)

setState(node, state, value)

setStyle(node, style, value)

setStyles(node, styles)

// Add `left` and `top` style(s)
// Remove `bottom` and `right` style(s) if exist
setStyles(node, {
    'bottom': false,
    'left': 0,
    'right': false,
    'top': 0
});

setText(node)

toElement(array)

Convert array of element name, element content and element attributes to element.

toString(node)

Get element’s outer HTML.

toggleClass(node, class, force)

toggleClasses(node, classes, force)

toggleState(node, state)

Toggle element state if available.

const button = getElement('button');
const details = getElement('details');

button.addEventListener('click', () => {
    toggleState(details, 'open');
});

toggleStates(node, states)

Properties

B

Return the <body> element.

D

Return the document object.

H

Return the <head> element.

R

Return the <html> element.

W

Return the window object.

theHistory

Return the window.history object.

theLocation

Return the window.location object.

theScript

Return the current <script> element.

Readme

Keywords

Package Sidebar

Install

npm i @taufik-nurrohman/document

Weekly Downloads

91

Version

1.1.1

License

MIT

Unpacked Size

43.5 kB

Total Files

5

Last publish

Collaborators

  • taufik-nurrohman