滑动输入条

滑动型输入器,展示当前值和可选范围。

如何使用

非内置模块,需要额外在 json-schema 注册 withSliderWidget

注意事项

  • 强制忽略 exclusiveMinimumexclusiveMaximum

代码演示

基础样例

最简单的用法。

expand code expand code
import { Component, inject } from '@angular/core';

import { YelonFormModule, SFSchema } from '@yelon/form';
import type { SFSliderWidgetSchema } from '@yelon/form/widgets/slider';
import { NzMessageService } from 'ng-zorro-antd/message';

@Component({
  selector: 'form-slider-simple',
  template: ` <sf [schema]="schema" (formSubmit)="submit($event)" /> `,
  standalone: true,
  imports: [YelonFormModule]
})
export class FormSliderSimpleComponent {
  private readonly msg = inject(NzMessageService);
  schema: SFSchema = {
    properties: {
      count: {
        type: 'number',
        title: '数量',
        ui: {
          widget: 'slider'
        } as SFSliderWidgetSchema,
        default: 10
      },
      // 双滑块模式
      range: {
        type: 'number',
        title: '范围',
        ui: {
          widget: 'slider',
          range: true
        } as SFSliderWidgetSchema,
        default: [10, 20]
      }
    }
  };

  submit(value: {}): void {
    this.msg.success(JSON.stringify(value));
  }
}

API

schema属性

成员说明类型默认值
[minimum]最小值number0
[maximum]最大值number100
[multipleOf]倍数number1

ui属性

成员说明类型默认值
[range]当添加该属性时,启动双滑块模式Boolean-
[marks]刻度标记NzMarks-
[dots]是否只能拖拽到刻度上Booleanfalse
[included]是否包含。marks 不为空对象时有效,值为 true 时表示值为包含关系,false 表示并列Booleantrue
[vertical]竖直显示。添加该属性时,Slider 为垂直方向。booleanfalse
[afterChange]onmouseup 触发时机一致,把当前值作为参数传入。(value: NzSliderValue) => void-
[formatter]Slider 会把当前值传给 nzTipFormatter,并在 Tooltip 中显示 nzTipFormatter 的返回值,若为 null,则隐藏 Tooltip(value: number) => string-
Loading...