欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue2.5开发去哪儿网App 城市列表开发 上

程序员文章站 2022-04-28 22:00:41
1. 在 router目录下 的 index.js文件中,新增路由 import City from '@/pages/city/City' { path: '/city', name: 'City', component: City } 2. 在city 目录下新建city文件夹,然后新建 Cit ......
 一,城市选择页面路由配置                                                                                                                                                                                                    

1. 在 router目录下 的 index.js文件中,新增路由


import city from '@/pages/city/city'
{
  path: '/city',
  name: 'city',
  component: city
}

2. 在city 目录下新建city文件夹,然后新建 city.vue  

<template>
  <div>
 
  </div>
</template>

<script>

export default {
  name: 'city',
  components: {
    
  }
}
</script>

<style lang="stylus" scoped>

</style>

3.在 首页的城市选择处,新增router-link 组件

<router-link to="/city">
<div class="header-right">
城市<span class="iconfont arrow-right">&#xe638;</span>
</div>
</router-link>

二,城市选择                                                                                               

1. header部分  在components 文件中 新增 header.vue

<template>
  <div class="header">
    <div class="header-left">
      <div class="iconfont back-icon">&#xe606;</div>
    </div>
    <div class="header-input">
      <span class="iconfont">&#xe6aa;</span>输入城市/景点/游玩主题
    </div>
    <router-link to="/city">
      <div class="header-right">
        城市<span class="iconfont arrow-right">&#xe638;</span>
      </div>
    </router-link>
  </div>
</template>

<script>
export default {
  name: 'homeheader'
}
</script>
<!--组件样式,不影响其他组件-->
<!--1rem = html front-size = 50px-->
<style lang="stylus" scoped>
 @import "~styles/varibles.styl"
 .header
  display flex
  line-height:$headerheight
  background: $bgcolor
  color: #fff
  .header-left
    margin-left: 0.1rem
    float:left
    width :.64rem
  .header-input
    padding-left:.2rem
    .back-icon
      text-align center
      font-size .4rem
    flex: 1
    height: .64rem
    line-height: .64rem
    margin-top: .12rem
    margin-left: .2rem
    padding-left: .2rem
    color: #ccc
    background: #fff
    border-radius: .1rem
  .header-right
    .arrow-right
      font-size .3rem
      margin-left -.05rem
    min-width: 1.04rem
    padding: 0 .1rem
    float: right
    text-align: center
    color: #ffffff
</style>

2. 在components  中新增  search.vue

<template>
  <div class="search">
    <input type="text" class="search-input" placeholder="输入城市名或拼音">
  </div>
</template>

<script>
export default {
  name: 'citysearch'
}
</script>
<!--组件样式,不影响其他组件-->
<!--1rem = html front-size = 50px-->
<style lang="stylus" scoped>
@import "~styles/varibles.styl"
  .search
    height .72rem
    padding 0 .1rem
    background $bgcolor
    .search-input
      padding 0 .1rem
      box-sizing border-box
      height .62rem
      line-height .62rem
      width 100%
      text-align center
      border-radius .06rem
</style>

目录结构:

Vue2.5开发去哪儿网App 城市列表开发 上

  效果:

Vue2.5开发去哪儿网App 城市列表开发 上

   三,列表布局                                                                                                                                                                                                 

1. 在components 中新建list.vue 

<template>
  <div class="list" ref="wrapper">
    <div>
      <div class="area">
        <div class="title border-topbottom">当前城市</div>
        <div class="button-list">
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
        </div>
      </div>
      <div class="area">
        <div class="title border-topbottom">热门城市</div>
        <div class="button-list">
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
          <div class="button-wrapper">
            <div class="button">北京</div>
          </div>
        </div>
      </div>
      <div class="area">
        <div class="title border-topbottom">a</div>
        <div class="item-list">
          <div class="item border-bottom">阿里尔</div>
          <div class="item border-bottom">阿里尔</div>
          <div class="item border-bottom">阿里尔</div>
          <div class="item border-bottom">阿里尔</div>
          <div class="item border-bottom">阿里尔</div>
        </div>
      </div>
    </div>
  </div>
</template>

样式:

  @import "~styles/varibles.styl"
  .border-topbottom
    &:before
      border-color #ccc
    &:after
      border-color #ccc
  .border-bottom
  &:before
    border-color #ccc
  .list
    overflow hidden
    position absolute
    top 1.58rem
    right 0
    bottom 0
    left 0
    .title
      line-height .54rem
      padding-left .2rem
      background #eee
      color #666
      font-size .26rem
    .button-list
      padding .1rem .6rem .1rem .1rem
      overflow hidden
      .button-wrapper
        float left
        padding .1rem
        .button
          text-align center
          margin .1rem
          border .02rem solid #ccc
          border-radius .06rem
          padding .1rem .5rem
    .item-list
      .item
        line-height .76rem
        padding-left .2rem

2. 使用better-scroll  联级滚动

git地址  :

安装: npm install better-scroll

使用:

citylist.vue

<div class="list" ref="wrapper">
<div>
  ......
  </div>
<div>
import bscroll from 'better-scroll'
export default {
  name: 'citylist',
  mounted: function () {
//this.$refs.wrapper获取dom元素
this.scroll = new bscroll(this.$refs.wrapper)
}
}

 3. 右侧字母表

新建  alphabet.vue

Vue2.5开发去哪儿网App 城市列表开发 上
<template>
  <div>
    <ul class="list">
      <li class="item">a</li>
      <li class="item">a</li>
      <li class="item">a</li>
      <li class="item">a</li>
      <li class="item">a</li>
      <li class="item">a</li>
      <li class="item">a</li>
    </ul>
  </div>
</template>

<script>
export default {
  name: 'cityalphabet'
}
</script>

<style lang="stylus" scoped>
  @import "~styles/varibles.styl"
  .list
    position absolute
    right 0
    top 1.58rem
    bottom 0
    display flex
    width .4rem
    flex-direction column
    justify-content center
    .item
      text-align center
      line-height .4rem
      color $bgcolor
</style>
view code

目前效果:

Vue2.5开发去哪儿网App 城市列表开发 上

4. 动态数据渲染

在static 目录下新建moc 文件夹,添加city.json文件

地址:https://github.com/1417766861/vue2.5-app/blob/master/travel/static/moc/city.json

发送ajax 请求:


import apiurl from '@/config/api_url'

......
data () { return { cities: {}, hotcities: [] } }, methods: { getcityinfo () { axios.get(apiurl.api + 'city.json') .then(this.handlegetcityinfosucc) }, handlegetcityinfosucc (res) { res = res.data if (res.ret && res.data) { this.cities = res.data.cities this.hotcities = res.data.hotcities } } }, mounted () { this.getcityinfo() }

/src/config/api_url.js

export default {
  api: '/static/moc/'
}

给组件添加数据:

    <city-list :cities="cities" :hotcities="hotcities"></city-list>
    <city-alphabet :cities="cities"></city-alphabet>

遍历显示,list.vue

      <div class="area">
        <div class="title border-topbottom">热门城市</div>
        <div class="button-list">
          <div class="button-wrapper" v-for="city in hotcities" :key="city.id">
            <div class="button">{{city.name}}</div>
          </div>
        </div>
      </div>
      <div class="area" v-for="(city,key) in cities" :key="key">
        <div class="title border-topbottom">{{key}}</div>
        <div class="item-list">
          <div class="item border-bottom" v-for="c in city" :key="c.id">{{c.name}}</div>
        </div>
      </div>

遍历显示,alphabet.vue

    <ul class="list">
      <li class="item" v-for="(item,key) in cities" :key="key">{{key}}</li>
    </ul>

效果:

Vue2.5开发去哪儿网App 城市列表开发 上

 

 代码地址:https://github.com/1417766861/vue2.5-app