--- localeCode: zh-CN order: 25 category: 输入类 title: Rating 评分 icon: doc-rating brief: 展示评分的组件。 --- ## 代码演示 ### 如何引入 ```jsx import import { Rating } from '@douyinfe/semi-ui'; ``` ### 基本用法 最简单的用法,支持两种尺寸 `default`, `small`。 **v >= 0.35.0** 后支持传入 number 类型自定义尺寸。具体可以参考[自定义](#自定义) ```jsx live=true import React from 'react'; import { Rating } from '@douyinfe/semi-ui'; () => (


); ``` ### 半星 通过设置 `allowHalf` 属性可以支持选择半星。`0.28.0` 版本之后,设置 `allowHalf` 属性支持**展示**除0.5以外的小数。 ```jsx live=true import React from 'react'; import { Rating } from '@douyinfe/semi-ui'; () => (

); ``` ### 只读 通过设置 `disabled` 属性将无法进行交互。 ```jsx live=true import React from 'react'; import { Rating } from '@douyinfe/semi-ui'; () => ( ); ``` ### 点击清除 通过设置 `allowClear` 属性允许再次点击时清除数值,默认为 `true`。 ```jsx live=true import React from 'react'; import { Rating } from '@douyinfe/semi-ui'; () => (
允许再次点击清除


禁止再次点击清除
); ``` ### 文案展现 给评分组件加上文案展示。 ```jsx live=true import React, { useState } from 'react'; import { Rating } from '@douyinfe/semi-ui'; () => { const [value, setValue] = useState(0); const change = (val) => setValue(val); const desc = ['terrible', 'bad', 'normal', 'good', 'wonderful']; return (
How was the help you received: {value ? {desc[value - 1]} : ''}
); }; ``` ### 自定义 自定义评分字符、个数及尺寸。 > **v >= 0.35.0** 自定义尺寸需要配合自定义的字符才能生效。 ```jsx live=true import React from 'react'; import { Rating } from '@douyinfe/semi-ui'; import { IconLikeHeart } from '@douyinfe/semi-icons'; () => (
)} defaultValue={3}/>

)} defaultValue={3}/>



); ``` ## API参考 | 属性 | 说明 | 类型 | 默认值 | |-------|-------------|-----------------|--------| | allowClear | 是否允许再次点击后清除 | boolean | true | | allowHalf | 是否允许半选 | boolean | false | | autoFocus | 自动获取焦点 | boolean | false | | character | 自定义字符 | ReactNode | `` | | className | 自定义样式类名 | string | - | | count | star 总数 | number | 5 | | defaultValue | 默认值 | number | 0 | | disabled | 只读,无法进行交互 | boolean | false | | onBlur | 失去焦点时的回调 | function() | - | | onChange | 选择时的回调 | function(value: number) | - | | onFocus | 获取焦点时的回调 | function() | - | | onHoverChange | 鼠标经过时数值变化的回调 | function(value: number) | - | | onKeyDown | 按键回调 | function(e: event) | - | | size | 尺寸, `default`, `small`,**v >= 0.35.0** 后支持传入 number 类型自定义尺寸 | string \| number | `default` | | style | 自定义样式对象 | object | - | | tooltips | 自定义每项的提示信息 | string[] | - | | value | 当前受控值 | number | - | ## Accessibility ### ARIA - Rating 具有 aria-checked 表示当前是否选中,aria-posinset 表示在列表的位置,aria-setsize 表示列表的长度 ## 设计变量