mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-12 15:19:58 +08:00
e7aa014c31
* docs: init * chore: all types * docs: faq * chore: fix lint
49 lines
1.3 KiB
TypeScript
49 lines
1.3 KiB
TypeScript
import React, { useState } from 'react';
|
|
import type { CarouselProps, RadioChangeEvent } from 'antd';
|
|
import { Carousel, Radio } from 'antd';
|
|
|
|
type DotPosition = CarouselProps['dotPosition'];
|
|
|
|
const contentStyle: React.CSSProperties = {
|
|
height: '160px',
|
|
color: '#fff',
|
|
lineHeight: '160px',
|
|
textAlign: 'center',
|
|
background: '#364d79',
|
|
};
|
|
|
|
const App: React.FC = () => {
|
|
const [dotPosition, setDotPosition] = useState<DotPosition>('top');
|
|
|
|
const handlePositionChange = ({ target: { value } }: RadioChangeEvent) => {
|
|
setDotPosition(value);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<Radio.Group onChange={handlePositionChange} value={dotPosition} style={{ marginBottom: 8 }}>
|
|
<Radio.Button value="top">Top</Radio.Button>
|
|
<Radio.Button value="bottom">Bottom</Radio.Button>
|
|
<Radio.Button value="left">Left</Radio.Button>
|
|
<Radio.Button value="right">Right</Radio.Button>
|
|
</Radio.Group>
|
|
<Carousel dotPosition={dotPosition}>
|
|
<div>
|
|
<h3 style={contentStyle}>1</h3>
|
|
</div>
|
|
<div>
|
|
<h3 style={contentStyle}>2</h3>
|
|
</div>
|
|
<div>
|
|
<h3 style={contentStyle}>3</h3>
|
|
</div>
|
|
<div>
|
|
<h3 style={contentStyle}>4</h3>
|
|
</div>
|
|
</Carousel>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default App;
|