Skip to content

Commit

Permalink
[article] Create a lit cheat sheet
Browse files Browse the repository at this point in the history
  • Loading branch information
e111077 committed Nov 23, 2024
1 parent 42d1ed5 commit 29998d8
Show file tree
Hide file tree
Showing 114 changed files with 2,234 additions and 33 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { html, LitElement, css } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
render() {
return html`<p>I'm blue</p><div>I'm red</div>`;
}

static styles = css`
p {
color: blue;
}
div {
color: red;
}
`;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import { html, LitElement, css } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { classMap } from 'lit/directives/class-map.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() counter = 0

firstUpdated() {
setInterval(() => this.counter += 1 , 1000);
}

render() {
const classes = {
red: this.counter % 2 === 0,
blue: this.counter % 2 === 1
};
return html`<p class=${classMap(classes)}>Hello!</p>`;
}

static styles = css`
.red {
color: red;
}
.blue {
color: blue;
}
`;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { html, LitElement } from 'lit';
import { customElement, state } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() private someBoolean = false;

render() {
let someText = html`<p>Some text</p>`;

if (this.someBoolean) {
someText = html`<p>Some other text</p>`;
}

return html`
<button
@click=${() => {this.someBoolean = !this.someBoolean}}>
Toggle template
</button>
<div>This is an inline ternary conditional</div>
${this.someBoolean ? html`<p>Some other text</p>` : html`<p>Some text</p>`}
<div>This is a variable conditional</div>
${someText}
`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "200px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<script type="module" src="./my-element.js"></script>
<style>
.styled my-element::part(paragraph) {
color: yellow;
border-color: white;
padding: 8px;
margin: 2px;
}

.styled {
background-color: black;
}

div {
padding: 4px;
}
</style>

<div class="styled">
<my-element></my-element>
</div>
<div>
<my-element></my-element>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { html, LitElement, css } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
static styles = css`
p {
color: blue;
border: 1px solid black;
padding: 4px;
margin-block: 4px;
}
`;

render() {
return html`<p part="paragraph">This is in a shadow root!</p>`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "120px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element array='1,"2",3,4,"5"'></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
import { html, LitElement } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';import {ComplexAttributeConverter} from 'lit';

/**
* Bidirectionally converts an array from an attribute to a property of the
* following format:
*
* array-attribute='1, "2", 3' to [1, '2', 3]
*/
export const arrayConverter: ComplexAttributeConverter<Array<unknown>> = {
toAttribute: (array: Array<unknown>) => {
return JSON.stringify(array).substring(1, JSON.stringify(array).length - 1);
},
fromAttribute: (value: string) => {
try {
return JSON.parse(`[${value}]`);
} catch {
return [];
}
}
};

@customElement('my-element')
export class MyElement extends LitElement {
@property({ converter: arrayConverter, reflect: true })
array: Array<number|string> = [];

render() {
return this.array.map((item) =>
html`<div>${typeof item}: ${item}</div>`
);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "200px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { html, LitElement } from 'lit';
import { customElement } from 'lit/decorators.js';

export type ScoreEvent = CustomEvent<number>;

@customElement('game-player')
export class GamePlayer extends LitElement {
render() {
return html`
<button @click=${() => this.handleScore(7)}>Touchdown!</button>
<button @click=${() => this.handleScore(3)}>Field goal!</button>
`;
}

handleScore(points: number) {
this.dispatchEvent(new CustomEvent('score', { detail: points, bubbles: true }));
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./score-board.js"></script>

<score-board></score-board>
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"extends": "/samples/v3-base.json",
"files": {
"score-board.ts": {},
"game-player.ts": {},
"index.html": {}
},
"previewHeight": "250px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { html, LitElement } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import './game-player.js';
import type {ScoreEvent} from './game-player.js';

@customElement('score-board')
export class ScoreBoard extends LitElement {
@state() playerOneScore = 0;
@state() playerTwoScore = 0;

render() {
return html`
<h1>${this.playerOneScore} - ${this.playerTwoScore}</h1>
<h2>Player 1</h2>
<game-player @score=${(e: ScoreEvent) => this.playerOneScore += e.detail}></game-player>
<h2>Player 2</h2>
<game-player @score=${(e: ScoreEvent) => this.playerTwoScore += e.detail}></game-player>
`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { html, LitElement } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('hello-world')
export class HelloWorld extends LitElement {
render() {
return html`<p>Hello, world!</p>`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./hello-world.js"></script>

<hello-world></hello-world>
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"hello-world.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { html, LitElement } from 'lit';
import { customElement, query, state } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() inputValue = '';
@state() hasError = false;
@query('input') inputEl!: HTMLInputElement;

render() {
return html`
<!-- custom events -->
<div
@number-error=${this.onNumberError}
@number-success=${this.onNumberSuccess}>
<!-- native events -->
<input @input=${this.onInput} .value=${this.inputValue} />
<button @click=${this.onClick}>Clear</button>
${this.hasError ? html`<b>Only positive numbers are allowed</b>` : ''}
<div>${this.inputValue}</div>
</div>
`;
}

onInput(e: InputEvent) {
this.inputValue = (e.target as HTMLInputElement).value;
if (!this.inputValue.match(/^[0-9]+$/)) {
this.inputEl.dispatchEvent(new Event('number-error', {bubbles: true}));
return;
}

this.inputEl.dispatchEvent(new Event('number-success', {bubbles: true}));
}

onClick() {
this.inputValue = '';
this.inputEl.focus();
}

onNumberError() {
this.hasError = true;
}

onNumberSuccess() {
this.hasError = false;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "170px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import { html, LitElement, css } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('another-element')
export class AnotherElement extends LitElement {
render() {
return html`
<div part="part-1">Part 1</div>
<div part="part-2">Part 2</div>
`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
<script type="module" src="./my-element.js"></script>
<style>
my-element::part(part-1) {
color: blue;
}

my-element::part(part-b) {
color: red;
}
</style>

<my-element></my-element>
Loading

0 comments on commit 29998d8

Please sign in to comment.