Reactivity

Declare state

logo of Marko Marko

<let/name="John">
<h1>Hello ${name}</h1>

logo of Aurelia 1 Aurelia 1

<template>
  <h1>Hello ${name}</h1>
</template>

Update state

logo of Marko Marko

<let/name="John">
<script>name = "Jane"</script>
<h1>Hello ${name}</h1>

logo of Aurelia 1 Aurelia 1

<template>
  <h1>Hello ${name}</h1>
</template>

Computed state

logo of Marko Marko

<let/count=10>
<const/doubleCount=count * 2>
<div>${doubleCount}</div>

logo of Aurelia 1 Aurelia 1

<template>
  <div>${doubleCount}</div>
</template>

Templating

Minimal template

logo of Marko Marko

<h1>Hello world</h1>

logo of Aurelia 1 Aurelia 1

<template>
  <h1>Hello world</h1>
</template>

Styling

logo of Marko Marko

<h1.title>I am red</h1>
<button style={ "font-size": "10rem" }>I am a button</button>
<button class=scopedButton>I am a style-scoped button</button>

<style>
  .title {
    color: red;
  }
</style>
<style/{ scopedButton }>
  .scopedButton {
    font-size: 10rem;
  }
</style>

logo of Aurelia 1 Aurelia 1

.title {
  color: red;
}

Loop

logo of Marko Marko

<ul>
  <for|color| of=["red", "green", "blue"]>
    <li>${color}</li>
  </for>
</ul>

logo of Aurelia 1 Aurelia 1

<template>
  <ul>
    <li repeat.for="color of colors">${color}</li>
  </ul>
</template>

Event click

logo of Marko Marko

<let/count=0>
<p>Counter: ${count}</p>
<button onClick() { count++ }>+1</button>

logo of Aurelia 1 Aurelia 1

<template>
  <p>Counter: ${count}</p>
  <button click.trigger="incrementCount()">+1</button>
</template>

Dom ref

logo of Marko Marko

<input/inputElement>
<script>
  inputElement().focus();
</script>

logo of Aurelia 1 Aurelia 1

<template>
  <input ref="inputElement" />
</template>

Conditional

logo of Marko Marko

static const TRAFFIC_LIGHTS = ["red", "orange", "green"];
<let/lightIndex=0>
<const/light=TRAFFIC_LIGHTS[lightIndex]>

<button onClick() { lightIndex = (lightIndex + 1) % TRAFFIC_LIGHTS.length }>
  Next light
</button>
<p>Light is: ${light}</p>
<p>
  You must
  <if=light === "red">STOP</if>
  <else if=light === "orange">SLOW DOWN</else>
  <else>GO</else>
</p>

logo of Aurelia 1 Aurelia 1

<template>
  <button click.trigger="nextLight()">Next light</button>
  <p>Light is: ${light}</p>
  <p>
    You must
    <span if.bind="light === 'red'">STOP</span>
    <span if.bind="light === 'orange'">SLOW DOWN</span>
    <span if.bind="light === 'green'">GO</span>
  </p>
</template>

Lifecycle

On mount

logo of Marko Marko

<let/pageTitle="">
<script>pageTitle = document.title</script>
<p>Page title: ${pageTitle}</p>

logo of Aurelia 1 Aurelia 1

<template>
  <p>Page title is: ${pageTitle}</p>
</template>

On unmount

logo of Marko Marko

<let/time=new Date()>
<script>
  const id = setInterval(() => time = new Date(), 1000);
  $signal.onabort = () => clearInterval(id)
</script>
<p>Current time: ${time.toLocaleTimeString()}</p>

logo of Aurelia 1 Aurelia 1

<template>
  <p>Current time: ${time}</p>
</template>

Component composition

Props

logo of Marko Marko

<UserProfile
  name="John"
  age=20
  favouriteColors=["green", "blue", "red"]
  isAvailable
/>

logo of Aurelia 1 Aurelia 1

<template>
  <require from="./user-profile"></require>
  <user-profile
    name.bind="name"
    age.bind="age"
    favourite-colors.bind="colors"
    is-available.bind="available"
  ></user-profile>
</template>

Emit to parent

logo of Marko Marko

<let/isHappy=true>
<p>Are you happy?</p>
<AnswerButton
  onYes() { isHappy = true }
  onNo() { isHappy = false }
/>
<p style={ "font-size": 50 }>${isHappy ? "😀" : "😥"}</p>

logo of Aurelia 1 Aurelia 1

<template>
  <require from="./answer-button"></require>
  <p>Can I come ?</p>
  <answer-button action-handler.call="handleAnswer(reply)"></answer-button>
  <p style="font-size: 50px">${isHappy ? "😀" : "😥"}</p>
</template>

Slot

logo of Marko Marko

<FunnyButton>Click me!</FunnyButton>

logo of Aurelia 1 Aurelia 1

<template>
  <require from="./funny-button"></require>

  <funny-button>Click me !</funny-button>
</template>

Slot fallback

logo of Marko Marko

<FunnyButton/>
<FunnyButton>I got content!</FunnyButton>

logo of Aurelia 1 Aurelia 1

<template>
  <require from="./funny-button"></require>

  <funny-button></funny-button>
  <funny-button>Click me !</funny-button>
</template>

Context

logo of Marko Marko

<let/user={
  id: 1,
  username: "unicorn42",
  email: "[email protected]",
}>
<const/updateUsername(newUsername) {
  user = { ...user, username: newUsername };
}>

<h1>Welcome back, ${user.username}</h1>
<context={ ...user, updateUsername }>
  <UserProfile />
</context>

logo of Aurelia 1 Aurelia 1

Missing snippet Help us to improve Component Party logo

Form input

Input text

logo of Marko Marko

<let/text="Hello world">
<p>${text}</p>
<input value:=text>

logo of Aurelia 1 Aurelia 1

<template>
  <p>${text}</p>
  <input value.bind="text" />
</template>

Checkbox

logo of Marko Marko

<input#is-available
  type="checkbox"
  checked:=input.isAvailable
>
<label for="is-available">Is available</label>

logo of Aurelia 1 Aurelia 1

<template>
  <input id="is-available" type="checkbox" checked.bind="isAvailable" />
  <label for="is-available">Is available</label>: ${isAvailable}
</template>

Radio

logo of Marko Marko

<let/picked="red">

<div>Picked: ${picked}</div>
<input#blue-pill
  type="radio"
  value="blue"
  checkedValue:=picked
>
<label for="blue-pill">Blue pill</label>

<input#red-pill
  type="radio"
  value="red"
  checkedValue:=picked
>
<label for="red-pill">Red pill</label>

logo of Aurelia 1 Aurelia 1

<template>
  <div>Picked: ${picked}</div>

  <input id="blue-pill" checked.bind="picked" type="radio" value="blue" />
  <label for="blue-pill">Blue pill</label>

  <input id="red-pill" checked.bind="picked" type="radio" value="red" />
  <label for="red-pill">Red pill</label>
</template>

Select

logo of Marko Marko

static const colors = [
  { id: 1, text: "red" },
  { id: 2, text: "blue" },
  { id: 3, text: "green" },
  { id: 4, text: "gray", isDisabled: true },
];
<let/selectedColorId=2>

<select value:=selectedColorId>
  <for|{ id, isDisabled, text }| of=colors>
    <option value=id disabled=isDisabled>
      ${text}
    </option>
  </for>
</select>

logo of Aurelia 1 Aurelia 1

<template>
  <select value.bind="selectedColorId">
    <option value="">Select A Color</option>
    <option
      repeat.for="color of colors"
      value.bind="color.id"
      disabled.bind="color.isDisabled"
    >
      ${color.text}
    </option>
  </select>
</template>

Webapp features

Render app

logo of Marko Marko

<!doctype html>
<html>
  <body>
    <div id="app"></div>
    <script type="module" src="./app.js"></script>
  </body>
</html>

logo of Aurelia 1 Aurelia 1

Missing snippet Help us to improve Component Party logo

Fetch data

logo of Marko Marko

<try>
  <await|{ results: users }|=fetch("https://randomuser.me/api/?results=3").then(res => res.json())>
    <ul>
      <for|{ picture, name }| of=users>
        <li>
          <img src=picture.thumbnail alt="user">
          <p>${name.first} ${name.last}</p>
        </li>
      </for>
    </ul>
  </await>
  <@placeholder>
    <p>Fetching users...</p>
  </@placeholder>
  <@catch|error|>
    <p>An error occurred while fetching users</p>
  </@catch>
</try>

logo of Aurelia 1 Aurelia 1

<template>
  <p if.bind="isLoading">Fetching users...</p>
  <p if.bind="error">An error ocurred while fetching users</p>
  <ul if.bind="users">
    <li repeat.for="user of users">
      <img src.bind="user.picture.thumbnail" alt="user" />
      <p>${ user.name.first } ${ user.name.last }</p>
    </li>
  </ul>
</template>