123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- <template>
- <view class='app'>
- <view class="search-wrap">
- <view class="city" @click="navTo('cityList?city='+city)">
- <image class="icon"
- src=""></image>
- <text>{{ city }}</text>
- <image class="c-icon"
- src=""></image>
- </view>
- <input auto-focus class="input" focus maxlength="30" placeholder="请输入地址关键字搜索" @confirm='bindConfirm'
- @input="bindConfirm"></input>
- </view>
- <view class="addr-list">
- <view v-for="(item, index) in list" :key="index" class="addr-item b-b" @click="confirm(item)">
- <text class="title">{{ item.title }}</text>
- <text class="addr">{{ item.address }}</text>
- </view>
- </view>
- </view>
- </template>
- <script>
- const QQMapWX = require('./js/qqmap-wx-jssdk.min.js')
- var qqmapsdk = new QQMapWX({
- key: 'FALBZ-J2G3I-ZY5GX-5ATUZ-GHOOZ-YVFAR'
- })
- export default {
- data() {
- return {
- city: '',
- keyword: '',
- list: []
- }
- },
- onLoad(options) {
- uni.setNavigationBarTitle({
- title: '搜索地址'
- })
- this.city = options.city || '';
- },
- methods: {
- //选择地址
- confirm(item) {
- const pages = getCurrentPages()
- const prePages = pages[pages.length - 2].$vm
- prePages.tempAddress = item;
- prePages.position = {
- longitude: item.location.lng,
- latitude: item.location.lat,
- }
- prePages.map = {
- longitude: item.location.lng,
- latitude: item.location.lat,
- }
- // #ifdef H5 || MP-WEIXIN
- prePages.getAddressList(1); //h5没触发地图regionchange事件,需要手动调用获取新地址列表。微信小程序开发工具自动触发,真机不触发,同样需要调用一下。
- // #endif
- uni.navigateBack({
- delta: 1
- })
- },
- //搜索地址
- searchList() {
- qqmapsdk.getSuggestion({
- keyword: this.keyword,
- policy: 1, //默认0,常规策略 policy=1:本策略主要用于收货地址、上门服务地址的填写,
- page_size: 20, //每页条目数,最大限制为20条,默认值10
- page_index: 1,
- region: this.city || '全国',
- success: res => {
- this.list = res.data;
- },
- fail: err => {
- this.list = [];
- }
- })
- },
- bindConfirm(e) {
- this.keyword = e.detail.value;
- this.searchList()
- },
- navTo(url) {
- uni.navigateTo({
- url
- })
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- view {
- box-sizing: border-box;
- }
- .app {
- padding-top: 100 rpx;
- }
- .search-wrap {
- position: fixed;
- left: 0;
- top: var(--window-top);
- z-index: 90;
- display: flex;
- background-color: #fff;
- align-items: center;
- width: 100%;
- height: 100 rpx;
- padding: 0 30 rpx;
- background-color: #fff;
- .city {
- display: flex;
- align-items: center;
- justify-content: center;
- font-size: 30 rpx;
- color: #333;
- }
- .icon {
- width: 34 rpx;
- height: 34 rpx;
- margin-right: 4 rpx;
- }
- .c-icon {
- width: 22 rpx;
- height: 22 rpx;
- margin-left: 4 rpx;
- }
- .input {
- flex: 1;
- margin-left: 16 rpx;
- padding: 0 28 rpx;
- height: 70 rpx;
- line-height: 70 rpx;
- font-size: 30 rpx;
- color: #333;
- background-color: #f5f5f5;
- border-radius: 100 rpx;
- }
- }
- .addr-list {
- background-color: #fff;
- .addr-item {
- display: flex;
- flex-direction: column;
- padding: 24 rpx 30 rpx;
- position: relative;
- &:after {
- position: absolute;
- z-index: 3;
- left: 0;
- top: auto;
- bottom: 0;
- right: 0;
- height: 0;
- content: '';
- transform: scaleY(.5);
- border-bottom: 1px solid #e5e5e5;
- }
- }
- .left {
- flex: 1;
- display: flex;
- flex-direction: column;
- padding-right: 50 rpx;
- }
- .title {
- font-size: 28 rpx;
- color: #303133;
- }
- .addr {
- margin-top: 10 rpx;
- font-size: 24 rpx;
- color: #909399;
- line-height: 1.4;
- }
- }
- </style>
|