搜索组件SearchBar
earchBar
搜索框。SearchBar UI 提供与WeLink规范一致的视图。 组件提供了搜索框、搜索结果、搜索按钮的样式。
参数说明
名称 | 类型 | 默认值 | 说明 | |
---|---|---|---|---|
autocomplete | 'off' | |||
defaultValue | string | default | 搜索框的值 | |
lang | object | language | 取消按钮显示字样, 例如:{ cancel: '取消' } | |
onCancel | func | undefined | 取消 | |
onChange | func | undefined | 搜索框的input的onChange事件 | |
onClear | func | undefined | 清除按钮事件 | |
onSubmit | func | undefined | 搜索按钮事件 | |
placeholder | string | '搜索' | 搜索框为空时显示的文字,默认为搜索 | |
searchName | string | 'q' | 搜索框input的name |
import React from 'react';
import {
// main component
SearchBar,
// for display data
Panel,
PanelHeader,
PanelBody,
PanelFooter,
MediaBox,
MediaBoxHeader,
MediaBoxBody,
MediaBoxTitle,
MediaBoxDescription,
Cell,
CellBody,
CellFooter
} from '@wecode/react-weui';
const sampleData = [
'Aaren',
'Bab',
'Cacilia',
'Dacey',
'Eachelle',
'Fae',
'Gabbey',
'Hadria',
'Ianthe',
'Jacenta',
'Kacey',
'La Verne',
'Mab',
'Nada',
'Octavia',
'Page',
'Queenie',
'Rachael',
'Saba',
'Tabatha',
'Ula',
'Val',
'Wallie',
'Xaviera',
'Yalonda',
'Zabrina'
];const appMsgIcon = (
<img
src=""
alt=""
/>
);const CellMore = () => (
<Cell access link>
<CellBody>More</CellBody>
<CellFooter />
</Cell>
);export default class SearchBarDemo extends React.Component {
state = {
searchText: '',
results: []
}; handleChange(text, e) {
const keywords = [text];
let results = sampleData.filter(/./.test.bind(new RegExp(keywords.join('|'), 'i'))); if (results.length > 3) results = results.slice(0, 3);
this.setState({
results,
searchText: text
});
} render() {
const { searchText, results } = this.state;
return (
<section>
<SearchBar
onChange={this.handleChange.bind(this)}
defaultValue={searchText}
placeholder="Female Name Search"
onSubmit={(text, e) => {
console.log('~~~~~~~', text);
e.preventDefault();
document.activeElement.blur();
}}
lang={{
cancel: 'Cancel'
}}
/> <Panel style={{ display: searchText ? null : 'none', marginTop: 0 }}>
<PanelHeader>Female Name Search</PanelHeader>
<PanelBody>
{results.length > 0 ? (
results.map((item, i) => (
<MediaBox key={i} type="appmsg" href="javascript:void(0);">
<MediaBoxHeader>{appMsgIcon}</MediaBoxHeader>
<MediaBoxBody>
<MediaBoxTitle>{item}</MediaBoxTitle>
<MediaBoxDescription>You may like this name.</MediaBoxDescription>
</MediaBoxBody>
</MediaBox>
))
) : (
<MediaBox> Can not find any!</MediaBox>
)}
</PanelBody>
<PanelFooter href="javascript:void(0);">
<CellMore />
</PanelFooter>
</Panel>
</section>
);
}
}
- 点赞
- 收藏
- 关注作者
评论(0)