npm install --save dom-ops
<!DOCTYPE html>
<html>
<head>
<title>dom ops!</title>
</head>
<body>
<div id="location"></div>
<script>
var domOps = require('../index.js'),
div = domOps(document.querySelector('#location'), function(content, data){
return '<p>'+content+'</p>';
});
//Append a bunch of things inside paragraphs to #location
for(var i=0; i<10; i++){
div.append('thing '+i);
}
</script>
</body>
</html>
Construct a new dom-ops object for a DOM element.
The template callback is optional. If you supply a template callback every dom operation method from a domOps instance will use that callback as a filter before the dom operation.
In the following documentation everywhere you see the word toAdd this is a value that can be any of these:
- DOM element
- HTML string
- Array of elements
- An array like object (DOM library instance)
The return value from the template callback should be the same types as toAdd.
Any time you see the word data this means a value of any kind that is passed to the template function passed to the domOps
constructor.
The word element refers to a DOM element passed to the first argument of domOps
constructor.
Append element to parent.
Append a value to element.
Prepend a value to element.
Insert a value at index, or before the specified child.
Replace a child at index, or the matched child with toAdd.
Remove the child at index, or the matched child. Returns the removed child.
If you pass an index you'll get the template returned. If you pass a child node remove will return that.
Get the index of the child of element.
indexOf will still work if you have a template set. If the child is not a direct descendant of element a search through parent nodes is done before the index is looked for.
Any children of children of children, ... and so on passed to indexOf will get the index of the the top most parent that is a child of element.
indexOf is used internally so DOM operations like replace will work to replace any value added by itself, or contained in a template you provide. Alternatively you can just pass an index to a method that accepts an index.
Keep reference variables to the children of a template if you need to operate on those later.
If you use operations like append with strings the same strings can be used with indexOf. The look up for a string in indexOf is not discriminatory in any way so know that only the first match will be used. The algorithm is very simple so there will sometimes be false positives if your input string is not very unique.
Match the element, or children based on a regular expression.
The second argument is optional.
A regular expression in the first argument matches textContent of elements. Matched elements are returned in an array.
If you pass a string to the first argument match
will look for attribute names that are the same as that string.
The regular expression in the second argument will match on attribute values, and return those elements that have those attributes matched.
//All elements with textContent = "contents of element" return.
var listOfElements = div.match(/contents of element/);
//All elements with the attribute data-store = "something" are returned.
var elmentsWithAttribute = div.match('data-store', /something/);
Get the child, or child template at the child index of element.
Pass a string to set innerHTML. Pass nothing to get innerHTML returned.
The html
method is mostly for completeness. It could mostly be useful for clearing the contents of element.
The template callback is not called with the html
method.
The element set with the constructor.
A reference to the element's children. These will be templates if you provide one.
A reference to the element's classList object property. For using DOM classList operations.
The last added child of element.
A reference to the element's style property.
Get a DOM element, or fragment from a value.
value can be any of these:
- DOM element
- HTML string
- Array of elements
- An array like object (DOM library instance)
See dom-from for more details.
Add a CSS link to the head node.
See link-css.
This module is only for DOM operations. Hopefully it will stay that way. :)