--- order: 9 title: zh-CN: 搜索框 en-US: Search Box --- ## zh-CN 带有搜索按钮的自动补全输入框。 ## en-US Autocomplete select with search field. ````jsx import { Input, Select, Button, Icon } from 'antd'; import jsonp from 'fetch-jsonp'; import querystring from 'querystring'; import classNames from 'classnames'; const Option = Select.Option; let timeout; let currentValue; function fetch(value, callback) { if (timeout) { clearTimeout(timeout); timeout = null; } currentValue = value; function fake() { const str = querystring.encode({ code: 'utf-8', q: value, }); jsonp(`https://suggest.taobao.com/sug?${str}`) .then(response => response.json()) .then((d) => { if (currentValue === value) { const result = d.result; const data = []; result.forEach((r) => { data.push({ value: r[0], text: r[0], }); }); callback(data); } }); } timeout = setTimeout(fake, 300); } const SearchInput = React.createClass({ getInitialState() { return { data: [], value: '', focus: false, }; }, handleChange(value) { this.setState({ value }); fetch(value, data => this.setState({ data })); }, handleSubmit() { console.log('输入框内容是: ', this.state.value); }, handleFocus() { this.setState({ focus: true }); }, handleBlur() { this.setState({ focus: false }); }, render() { const btnCls = classNames({ 'ant-search-btn': true, 'ant-search-btn-noempty': !!this.state.value.trim(), }); const searchCls = classNames({ 'ant-search-input': true, 'ant-search-input-focus': this.state.focus, }); const options = this.state.data.map(d => ); return (
); }, }); ReactDOM.render( , mountNode); ````