data-stoar is a page parser that will look for script tags on the current page with specific data attributes and pass them back as a formatted object.
npm install data-stoar
yarn add data-stoar
Data is passed to the data-stoar via data-attributes or json script tags in the rendered HTML. If you use the script tag I recommend using the type of "applicaiton/json" that way your browser will not execute the script tag.
<script type="application/json"
data-component="myNewComponent"
data-component-config
data-component-instance="1">
{
"myTestData" : "Data passed to my component",
"myTestData2" : {
foo : "BAR",
baz : "zing"
}
}
</script>
<div
data-component="myNewComponent"
data-component-instance="2"
data-my-special-info="Component info specific to this instance"
data-title-info="The Data Stoar is fantastic">
<h1>My cool component</h1>
</div>
There are three data attributes that data-stoar looks for on a html tag
data-component
This is the name associated with the component when the array of found components is returneddata-component-config
This tells data-stoar that this particular json is a config for all components found on the page of this component type. So this json object will be passed to each component, in the example above, with the typemyNewComponent
.data-component-instance
This attribute will tell data-stoar that you want this json data to go to a specific instance of a component on the page. In the case above1
.- If you have chosen to use data attributes to pass data to the data-stoar then all the other data attributes on the tag will be passed in the data or config objects returned in the data from data-stoar.
In your javascript now you can create a new instance of the data-stoar by doing the following:
import DataStoar from 'data-stoar'
let pageComponents = new DataStoar();
/* Result from the HTML above
pageComponents [
{
"name": "myNewComponent",
"instances": [
{
"id": "1",
"data": {},
"config": {
"myTestData" : "Data passed to my component",
"myTestData2" : {
foo : "BAR",
baz : "zing"
}
}
},
{
"id": "2",
"config": {
"myTestData" : "Data passed to my component",
"myTestData2" : {
foo : "BAR",
baz : "zing"
}
},
"data": {
"mySpecialInfo" : "Component info specific to this instance",
"titleInfo" : "The Data Stoar is fantastic",
"element" : <DOM ELEMENT/>
}
}
}
]
},
]
*/
- Bug fixe for multiple instances of the same component.
- Any extra data attributes on the script tags will now be passed in either the config or the data objects just as they are for html tags.
- In the return object I now pass back the dom element that the data-component attribute was tied to when that element is not a script tag. This allows you to have a handle on the DOM element so you can bind to the targeted element.
- The data attribute in the instance object is no longer an array. This is the breaking Change
- The instance object now returns the config with every instance
- You can now use data attributes to pass data to the data-stoar not just use the json script tag
- Added some more documentation