Knob
Quasar Knob is another way of making the user select a Number value from a predefined range. With optional steps included. See demo.
Works well with QField for additional functionality such as a helper, error message placeholder and many others.
Installation
Edit /quasar.conf.js
:framework: {
components: ['QKnob']
}
Basic Usage
<q-knob |
Vue Properties
Supports v-model
which should be a Number.
Vue Property | Type | Description |
---|---|---|
size | String | CSS String determining the width and height of the Knob. Examples: “120px”, “12rem”. |
step | Number | Number representing difference between two values that the model can take. Default: 1 . |
min | Number | Minimum value that the model can take. |
max | Number | Maximum value that the model can take. |
color | String | One from Quasar Color Palette. |
trackColor | String | One from Quasar Color Palette. |
lineWidth | String | Line width of Knob. Default is ‘6px’. |
readonly | Boolean | Sort of a “display” only mode. Model cannot be altered. |
disable | Boolean | When set to true the model cannot be altered. |
Vue Events
Vue Event | Description |
---|---|
@input(newVal) | Triggered immediately on model value change. |
@change(newVal) | Triggered on lazy model value change. |
@drag-value(val) | (v0.15.11+) Triggered while dragging (or clicking) on Knob. |
More Examples
Lazy Input
Vue will soon supply the .lazy
modifier for v-model on components too, but until then, you can use the longer equivalent form:<q-knob
:value="model"
@change="val => { model = val }"
:min="min"
:max="max"
/>
We can go a step further and display the current value while dragging:<!-- v0.15.11+ -->
<q-knob
:value="model"
@change="val => { model = val }"
@drag-value="val => { currentValue = val }"
:min="min"
:max="max"
>
{{ currentValue }}
</q-knob>
Multi-colored with a Euro icon.
<q-knob |
Read-only state (different than disabled, as the mouse pointer doesn’t change).
<q-knob |
Using a QField to highlight error state.
<q-field |