列表找房(一)——顶部搜索栏-基本布局 & 跳转主页-this.props.history.push(‘home‘)

列表找房——顶部搜索栏-基本布局 & this.props.history.push(’/home’)

列表找房业务分析

  • 页面顶部有一个搜索栏,点击左侧箭头回到主页
  • 组合筛选条件栏
    • 前三个筛选条件弹窗类似
    • 最后一个筛选条件弹窗不同
  • 筛选结果列表展示(基于长列表缓存组件)

顶部搜索栏

基本布局

在src/views/Find/index.js中

<Flex className='header'>
  <i className="iconfont icon-back" />
  <Flex className='search-box searchHeader'>
    {/* 左侧白色区域 */}
    <Flex className="search">
      {/* 位置 */}
      <div className="location" >
        <span className="name">北京</span>
        <i className="iconfont icon-arrow" />
      </div>

      {/* 搜索表单 */}
      <div className="form" >
        <i className="iconfont icon-seach" />
        <span className="text">请输入小区或地址</span>
      </div>
    </Flex>
    {/* 右侧地图图标 */}
    <i className="iconfont icon-map" />
  </Flex>
</Flex>

在src/views/Find/index.scss中

.header {
  position: absolute;
  top: 0;
  width: 100%;
  height: 45px;
  padding: 0 10px;
  background-color: #f6f5f6;
  .icon-back {
    font-size: 16px;
    color: #999;
  }
  .searchHeader {
    position: relative;
    top: 0;
    padding: 0;
    .icon-map {
      color: #00ae66;
    }
    .search {
      height: 30px;
    }
  }
}
// 顶部导航
.search-box {
  position: absolute;
  top: 5px;
  width: 100%;
  padding: 0 20px;

  // 左侧白色区域
  .search {
    flex: 1;
    height: 34px;
    margin: 0 10px;
    padding: 5px 5px 5px 8px;
    border-radius: 3px;
    background-color: #fff;

    // 位置
    .location {
      .icon-arrow {
        margin-left: 2px;
        font-size: 12px;
        color: #7f7f80;
      }
    }

    // 搜索表单
    .form {
      border-left: solid 1px #e5e5e5;
      margin-left: 12px;
      line-height: 16px;

      .icon-seach {
        vertical-align: middle;
        padding: 0 2px 0 12px;
        color: #9c9fa1;
        font-size: 15px;
      }

      .text {
        padding-left: 4px;
        font-size: 13px;
        color: #9c9fa1;
      }
    }
  }

  // 右侧地图图标
  .icon-map {
    font-size: 25px;
    color: #fff;
  }
}

显示效果为

在这里插入图片描述

获取当前城市
  • 使用封装好的方法获取当前城市
componentDidMount () {
  // 获取当前城市名称
  getCurrentCity().then(res =>{
    this.setState({
      currentCity: res.label
    })
  })
}
  • 跳转到主页
      <i className="iconfont icon-back" onClick={() => {
            // 控制路由跳转到主页面
            this.props.history.push('/home')
          }}/>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值