ant-design/components/cascader/demo/custom-render.md

71 lines
1.3 KiB
Markdown
Raw Normal View History

---
order: 8
title:
zh-CN: 自定义已选项
en-US: Custom render
---
## zh-CN
例如给最后一项加上邮编链接。
## en-US
For instance, add an external link after the selected value.
````jsx
import { Cascader } from 'antd';
const options = [{
value: 'zhejiang',
2016-09-10 18:23:24 +08:00
label: 'Zhejiang',
children: [{
value: 'hangzhou',
2016-09-10 18:23:24 +08:00
label: 'Hangzhou',
children: [{
value: 'xihu',
2016-09-10 18:23:24 +08:00
label: 'West Lake',
code: 752100,
}],
}],
}, {
value: 'jiangsu',
2016-09-10 18:23:24 +08:00
label: 'Jiangsu',
children: [{
value: 'nanjing',
2016-09-10 18:23:24 +08:00
label: 'Nanjing',
children: [{
value: 'zhonghuamen',
2016-09-10 18:23:24 +08:00
label: 'Zhong Hua Men',
code: 453400,
}],
}],
}];
function handleAreaClick(e, label, option) {
e.stopPropagation();
2016-09-10 18:23:24 +08:00
console.log('clicked', label, option);
}
const displayRender = (labels, selectedOptions) => labels.map((label, i) => {
const option = selectedOptions[i];
if (i === labels.length - 1) {
return (
<span key={option.value}>
{label} (<a onClick={e => handleAreaClick(e, label, option)}>{option.code}</a>)
</span>
);
}
return <span key={option.value}>{label} / </span>;
});
ReactDOM.render(
<Cascader
options={options}
defaultValue={['zhejiang', 'hangzhou', 'xihu']}
displayRender={displayRender}
style={{ width: 200 }}
/>
, mountNode);
````