搜索框。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

效果示例

HTML
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>
    );
  }
}

result. ""

    Not Found. ""