https://github.com/matthiaskainer/pure-lit
Register your lit-elements as a pure functions.
https://github.com/matthiaskainer/pure-lit
html javascript lit lit-html web-component web-components
Last synced: 4 months ago
JSON representation
Register your lit-elements as a pure functions.
- Host: GitHub
- URL: https://github.com/matthiaskainer/pure-lit
- Owner: MatthiasKainer
- License: isc
- Created: 2020-07-04T18:36:12.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-25T15:30:54.000Z (5 months ago)
- Last Synced: 2024-10-15T17:34:33.189Z (4 months ago)
- Topics: html, javascript, lit, lit-html, web-component, web-components
- Language: TypeScript
- Homepage: https://pure-lit.org
- Size: 1.82 MB
- Stars: 25
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- Contributing: CONTRIBUTING.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# pure-lit
[data:image/s3,"s3://crabby-images/8d71c/8d71c18b7158ac8c31960e38bd7b833220d6a15f" alt="Version"](https://www.npmjs.com/package/pure-lit)
[data:image/s3,"s3://crabby-images/155b5/155b57a282e20daf72e2a742f73d88019a8828fb" alt="Size"](https://bundlephobia.com/result?p=pure-lit)
[data:image/s3,"s3://crabby-images/36b33/36b333e43e5f8738dba9f4610b8408aff2a957c3" alt="vulnerabilities"](https://snyk.io/test/github/MatthiasKainer/pure-lit?targetFile=package.json)
[data:image/s3,"s3://crabby-images/ae42a/ae42a90fbaf78070d9a3c0c199e54d6cd3a6ca4a" alt="dependencies"](https://bundlephobia.com/result?p=pure-lit)
data:image/s3,"s3://crabby-images/4c935/4c935f36be08bc81bc5998e8f16329cdd9cb5008" alt="Statements"
data:image/s3,"s3://crabby-images/b9e9c/b9e9c11f916b23e9e2e946c0be350f9d1235dc29" alt="Branch"
data:image/s3,"s3://crabby-images/7c746/7c7461878e54711dee250fa42d2ff6463b95fd16" alt="Functions"
data:image/s3,"s3://crabby-images/84567/845674ed10ae81128a62d8063ba66d37a586a1c2" alt="Lines"> [lit](https://lit.dev/) with pure functions.
## Install
`npm install pure-lit`
or add it to your page as module like this:
``
## Getting started
[data:image/s3,"s3://crabby-images/64dbf/64dbf59b78b46925f7b3bb542c9892c882528f1e" alt="pure-lit.org"](https://pure-lit.org)
The quickest way of getting started is by using JavaScript modules.
Create a file `index.html` that looks like this:
```html
Awesome pure-lit
import { html } from "https://unpkg.com/lit@latest?module";
import { pureLit } from "https://unpkg.com/pure-lit@latest?module";pureLit(
"hello-you",
async ({ who }) => {
return html`<div>Hello ${who}!</div>`;
},
{
defaults: { who: "" },
}
);
```
Open it in the browser. Done.
## Adding some state
pureLit exports the hooks from [lit-element-state-decoupler](https://github.com/MatthiasKainer/lit-element-state-decoupler) and [lit-element-effect](https://github.com/MatthiasKainer/lit-element-effect) which you can use to manage your state inside the functional components.
You can import them via
```typescript
import { pureLit, useState, useReducer, useWorkflow, useEffect, useOnce } from "pure-lit";
```and then use them like this:
```typescript
pureLit("hello-world", (element) => {
const counter = useState(element, 0);
return html` counter.set(counter.get() + 1)}">You clicked me ${counter.get()} times!`
});
```