Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/taufik-nurrohman/document
HTML document object utility.
https://github.com/taufik-nurrohman/document
document helper model node object utility
Last synced: about 1 month ago
JSON representation
HTML document object utility.
- Host: GitHub
- URL: https://github.com/taufik-nurrohman/document
- Owner: taufik-nurrohman
- License: mit
- Created: 2020-12-18T14:58:04.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-10-21T11:20:54.000Z (about 1 year ago)
- Last Synced: 2024-05-02T00:23:21.436Z (8 months ago)
- Topics: document, helper, model, node, object, utility
- Language: JavaScript
- Homepage:
- Size: 24.4 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Document Utility
================HTML document object utility.
Usage
-----### CommonJS
~~~ js
const {setElement} = require('@taufik-nurrohman/document');console.log(setElement('div', 'Content goes here.', {
'class': 'bar foo',
'id': 'baz'
}));
~~~### ECMAScript
~~~ js
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 `` 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)
~~~ js
// 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)
~~~ js
// 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)
~~~ js
// 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)
~~~ js
// 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)
~~~ js
// 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)
~~~ js
// 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)
~~~ js
// 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.
~~~ js
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'
}));
~~~~~~ js
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)
~~~ js
// 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.
~~~ js
const button = getElement('button');
const details = getElement('details');button.addEventListener('click', () => {
toggleState(details, 'open');
});
~~~### toggleStates(node, states)
Properties
----------### B
Return the `` element.
### D
Return the `document` object.
### H
Return the `` element.
### R
Return the `` element.
### W
Return the `window` object.
### theHistory
Return the `window.history` object.
### theLocation
Return the `window.location` object.
### theScript
Return the current `` element.