# Vue Range Component

> Vue range component. Use our custom range inputs for consistent cross-browser styling and built-in customization.

## Overview

Create custom `<input type="range">` controls with `<CFormRange>`. The track (the background) and thumb (the value) are both styled to appear the same across browsers. As only Edge Legacy and Firefox supports "filling" their track from the left or right of the thumb as a means to visually indicate progress, we do not currently support it.

```html
<template>
  <CFormRange id="customRange1" label="Example range" />
</template>

<script setup>
import { CFormRange } from '@coreui/vue'
</script>
```
  
</Example>

## Disabled

Add the `disabled` boolean attribute on an input to give it a grayed out appearance and remove pointer events.

```html
<template>
  <CFormRange id="disabledRange" disabled label="Disabled range" />
</template>

<script setup>
import { CFormRange } from '@coreui/vue'
</script>
```
  
</Example>

## Min and max

Range inputs have implicit values for `min` and `max`—`0` and `100`, respectively. You may specify new values for those using the `min` and `max` attributes.

```html
<template>
  <CFormRange label="Example range" :min="0" :max="5" :value="3" id="customRange2" />
</template>

<script setup>
import { CFormRange } from '@coreui/vue'
</script>
```
  
</Example>

## Steps

By default, range inputs "snap" to integer values. To change this, you can specify a `step` value. In the example below, we double the number of steps by using `:step="0.5"`.

```html
<template>
  <CFormRange label="Example range" :min="0" :max="5" :step="0.5" :value="3" id="customRange3" />
</template>

<script setup>
import { CFormRange } from '@coreui/vue'
</script>
```
  
</Example>
