Guide
Essentials
- Installation
- Introduction
- The Kdu Instance
- Template Syntax
- Computed Properties and Watchers
- Class and Style Bindings
- Conditional Rendering
- List Rendering
- Event Handling
- Form Input Bindings
- Components Basics
Components In-Depth
- Component Registration
- Props
- Custom Events
- Slots
- Dynamic & Async Components
- Handling Edge Cases
Transitions & Animation
- Enter/Leave & List Transitions
- State Transitions
Reusability & Composition
- Mixins
- Custom Directives
- Render Functions & JSX
- Plugins
- Filters
Tooling
- Single File Components
- TypeScript Support
- Production Deployment
Scaling Up
- Routing
- State Management
- Server-Side Rendering
- Security
Internals
- Reactivity in Depth
Migrating
- Migration to Kdu 2.7
Meta
- Meet the Team
Class and Style Bindings
A common need for data binding is manipulating an element’s class list and its inline styles. Since they are both attributes, we can use k-bind
to handle them: we only need to calculate a final string with our expressions. However, meddling with string concatenation is annoying and error-prone. For this reason, Kdu provides special enhancements when k-bind
is used with class
and style
. In addition to strings, the expressions can also evaluate to objects or arrays.
Binding HTML Classes
Object Syntax
We can pass an object to k-bind:class
to dynamically toggle classes:
|
The above syntax means the presence of the active
class will be determined by the truthiness of the data property isActive
.
You can have multiple classes toggled by having more fields in the object. In addition, the k-bind:class
directive can also co-exist with the plain class
attribute. So given the following template:
|
And the following data:
|
It will render:
|
When isActive
or hasError
changes, the class list will be updated accordingly. For example, if hasError
becomes true
, the class list will become "static active text-danger"
.
The bound object doesn’t have to be inline:
|
|
This will render the same result. We can also bind to a computed property that returns an object. This is a common and powerful pattern:
|
|
Array Syntax
We can pass an array to k-bind:class
to apply a list of classes:
|
|
Which will render:
|
If you would like to also toggle a class in the list conditionally, you can do it with a ternary expression:
|
This will always apply errorClass
, but will only apply activeClass
when isActive
is truthy.
However, this can be a bit verbose if you have multiple conditional classes. That’s why it’s also possible to use the object syntax inside array syntax:
|
With Components
This section assumes knowledge of Kdu Components. Feel free to skip it and come back later.
When you use the class
attribute on a custom component, those classes will be added to the component’s root element. Existing classes on this element will not be overwritten.
For example, if you declare this component:
|
Then add some classes when using it:
|
The rendered HTML will be:
|
The same is true for class bindings:
|
When isActive
is truthy, the rendered HTML will be:
|
Binding Inline Styles
Object Syntax
The object syntax for k-bind:style
is pretty straightforward - it looks almost like CSS, except it’s a JavaScript object. You can use either camelCase or kebab-case (use quotes with kebab-case) for the CSS property names:
|
|
It is often a good idea to bind to a style object directly so that the template is cleaner:
|
|
Again, the object syntax is often used in conjunction with computed properties that return objects.
Array Syntax
The array syntax for k-bind:style
allows you to apply multiple style objects to the same element:
|
Auto-prefixing
When you use a CSS property that requires vendor prefixes in k-bind:style
, for example transform
, Kdu will automatically detect and add appropriate prefixes to the applied styles.
Multiple Values
2.5.0+
Starting in 2.5.0+ you can provide an array of multiple (prefixed) values to a style property, for example:
|
This will only render the last value in the array which the browser supports. In this example, it will render display: flex
for browsers that support the unprefixed version of flexbox.