|
@@ -1,804 +1,374 @@
|
|
|
<template>
|
|
|
- <!-- 商城 -->
|
|
|
- <view class="">
|
|
|
- <!-- <view class="index-navbar"> -->
|
|
|
- <view style="position: relative">
|
|
|
- <!-- 自定义导航栏 -->
|
|
|
- <image
|
|
|
- src="../../static/images/index/back.png"
|
|
|
- style="
|
|
|
- width: 750rpx;
|
|
|
- height: 1200rpx;
|
|
|
- position: absolute;
|
|
|
- top: 0;
|
|
|
- z-index: -1;
|
|
|
- "
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <u-navbar
|
|
|
- bgColor="rgba(255, 215,215, 1)"
|
|
|
- :placeholder="true"
|
|
|
- :fixed="true"
|
|
|
- >
|
|
|
- <view class="u-nav-slot" slot="left" style="display: flex">
|
|
|
- <view
|
|
|
- class=""
|
|
|
- style="width: 40rpx; height: 40rpx; position: relative"
|
|
|
- >
|
|
|
- <u-badge
|
|
|
- :absolute="true"
|
|
|
- :offset="[0, -8]"
|
|
|
- :type="type"
|
|
|
- max="99"
|
|
|
- :value="unReadCount"
|
|
|
- ></u-badge>
|
|
|
- <image
|
|
|
- @click="tochat"
|
|
|
- src="../../static/images/index/xiaoxi.png"
|
|
|
- mode=""
|
|
|
- style="width: 40rpx; height: 40rpx"
|
|
|
- >
|
|
|
- </image>
|
|
|
- </view>
|
|
|
- <image
|
|
|
- @click="counter"
|
|
|
- src="../../static/images/index/compile.png"
|
|
|
- mode=""
|
|
|
- style="width: 40rpx; height: 40rpx; margin-left: 22rpx"
|
|
|
- ></image>
|
|
|
- <image
|
|
|
- src="../../static/images/index/dianhua.png"
|
|
|
- mode=""
|
|
|
- style="width: 40rpx; height: 40rpx; margin-left: 22rpx"
|
|
|
- @click="callphone"
|
|
|
- ></image>
|
|
|
- </view>
|
|
|
- <view class="u-nav-slot" slot="center" style="width: 320rpx">
|
|
|
- <u-subsection
|
|
|
- bgColor="rgba(248, 50, 36, 0.1)"
|
|
|
- activeColor="#F83224"
|
|
|
- inactiveColor="#222"
|
|
|
- :list="list"
|
|
|
- :current="current"
|
|
|
- @change="sectionChange"
|
|
|
- ></u-subsection>
|
|
|
- </view>
|
|
|
- </u-navbar>
|
|
|
- <view class="" style="margin-top: 30rpx; padding: 0 24rpx">
|
|
|
- <!-- 搜索 -->
|
|
|
- <view class="search">
|
|
|
- <view class="u-flex">
|
|
|
- <u-icon name="search" size="32"></u-icon>
|
|
|
- <input
|
|
|
- type="text"
|
|
|
- v-model="keyword"
|
|
|
- :placeholder="i18n.Searchcon"
|
|
|
- />
|
|
|
- </view>
|
|
|
- <view class="right" @click="search">
|
|
|
- {{ i18n.search }}
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <!-- tabs -->
|
|
|
- <view
|
|
|
- class=""
|
|
|
- style="
|
|
|
- display: flex;
|
|
|
- margin-top: 20rpx;
|
|
|
- align-items: center;
|
|
|
- justify-content: space-between;
|
|
|
- "
|
|
|
- >
|
|
|
- <u-tabs :list="list1" @change="changetab"></u-tabs>
|
|
|
- <view class="border"> </view>
|
|
|
- <view
|
|
|
- class="u-flex"
|
|
|
- style="margin-left: 24rpx; width: 100rpx"
|
|
|
- @click="shoptype"
|
|
|
- >
|
|
|
- <image
|
|
|
- src="../../static/images/index/fenlei.png"
|
|
|
- style="width: 24rpx; height: 24rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <text class="fenlei">{{ i18n.sort }}</text>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <!-- 轮播图 -->
|
|
|
- <view class="" style="margin-top: 20rpx">
|
|
|
- <u-swiper radius="10" :indicator="true" :list="banner"></u-swiper>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <view class="shopback">
|
|
|
- <view class="u-flex u-row-between">
|
|
|
- <!-- 百亿补贴 -->
|
|
|
- <view class="bigbox" @click="subsidy(1)">
|
|
|
- <view class="u-flex">
|
|
|
- <image
|
|
|
- v-if="language == 'zh-CN'"
|
|
|
- src="../../static/images/index/butie.png"
|
|
|
- style="width: 104rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'en-US'"
|
|
|
- src="../../static/images/index/butie1.png"
|
|
|
- style="width: 200rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'es-ES'"
|
|
|
- src="../../static/images/index/butie2.png"
|
|
|
- style="width: 260rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'it-IT'"
|
|
|
- src="../../static/images/index/butie3.png"
|
|
|
- style="width: 152rpx; height: 22rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <view class="biaoqian" style="background: #f35d22">{{
|
|
|
- i18n.expensive
|
|
|
- }}</view>
|
|
|
- </view>
|
|
|
- <view
|
|
|
- class="u-flex"
|
|
|
- style="flex-wrap: wrap; justify-content: space-between"
|
|
|
- >
|
|
|
- <view
|
|
|
- v-for="(item, idx) in subsidylist"
|
|
|
- class="ssbox"
|
|
|
- style="margin-top: 16rpx"
|
|
|
- >
|
|
|
- <view class="" style="position: relative">
|
|
|
- <image
|
|
|
- :src="item.image"
|
|
|
- style="width: 144rpx; height: 144rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <view
|
|
|
- v-if="language == 'zh-CN'"
|
|
|
- class="u-flex u-row-center"
|
|
|
- style="position: absolute; bottom: 10rpx; width: 144rpx"
|
|
|
- >
|
|
|
- <view class="u-flex">
|
|
|
- <view
|
|
|
- class="tag u-flex"
|
|
|
- style="background: rgba(243, 93, 34, 1)"
|
|
|
- >
|
|
|
- <image
|
|
|
- src="../../static/images/index/down.png"
|
|
|
- style="
|
|
|
- width: 28rpx;
|
|
|
- height: 28rpx;
|
|
|
- position: relative;
|
|
|
- z-index: 3;
|
|
|
- "
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <text>{{ i18n.fill }}</text>
|
|
|
- <text>{{
|
|
|
- (item.price * 1000 - item.discount_price * 1000) /
|
|
|
- 1000 +
|
|
|
- i18n.RMB
|
|
|
- }}</text>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <view class="money" style="text-align: center">
|
|
|
- ¥{{ item.discount_price }}
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <!-- 拼包好物 -->
|
|
|
- <view class="">
|
|
|
- <view class="smallbox" @click="subsidy(2)">
|
|
|
- <view class="u-flex">
|
|
|
- <image
|
|
|
- v-if="language == 'zh-CN'"
|
|
|
- src="../../static/images/index/pinbao.png"
|
|
|
- style="width: 164rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <image
|
|
|
- v-if="language == 'en-US'"
|
|
|
- src="../../static/images/index/pinbao1.png"
|
|
|
- style="width: 200rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'es-ES'"
|
|
|
- src="../../static/images/index/pinbao2.png"
|
|
|
- style="width: 126rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'it-IT'"
|
|
|
- src="../../static/images/index/pinbao3.png"
|
|
|
- style="width: 126rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <view
|
|
|
- v-if="language == 'zh-CN'"
|
|
|
- class="biaoqian"
|
|
|
- style="background: rgba(255, 148, 21, 1)"
|
|
|
- >
|
|
|
- {{ i18n.lowest }}1元
|
|
|
- </view>
|
|
|
- <view
|
|
|
- v-else
|
|
|
- class="biaoqian"
|
|
|
- style="background: rgba(255, 148, 21, 1)"
|
|
|
- >{{ i18n.lowest }}1RMB
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <view
|
|
|
- class="u-flex"
|
|
|
- style="flex-wrap: wrap; justify-content: space-between"
|
|
|
- >
|
|
|
- <view
|
|
|
- v-for="(item, idx) in packlist"
|
|
|
- class="ssbox"
|
|
|
- style="margin-top: 16rpx"
|
|
|
- >
|
|
|
- <view class="" style="position: relative">
|
|
|
- <image
|
|
|
- :src="item.image"
|
|
|
- style="width: 144rpx; height: 144rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <view
|
|
|
- class="u-flex u-row-center"
|
|
|
- style="position: absolute; bottom: 10rpx; width: 144rpx"
|
|
|
- >
|
|
|
- <view class="u-flex">
|
|
|
- <!-- <image src="../../static/images/index/label.png"
|
|
|
- style="width: 28rpx;height: 28rpx;position: relative;z-index: 3;"
|
|
|
- mode="">
|
|
|
- </image> -->
|
|
|
- <view
|
|
|
- v-if="item.is_discount == 0"
|
|
|
- class="tag u-flex"
|
|
|
- style="background-color: rgba(251, 73, 70, 1)"
|
|
|
- >
|
|
|
- <image
|
|
|
- src="../../static/images/index/down.png"
|
|
|
- style="
|
|
|
- width: 28rpx;
|
|
|
- height: 28rpx;
|
|
|
- position: relative;
|
|
|
- z-index: 3;
|
|
|
- "
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <text>{{
|
|
|
- (item.price * 1000 - item.discount_price * 1000) /
|
|
|
- 1000 +
|
|
|
- i18n.RMB
|
|
|
- }}</text>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <view class="smallbox" @click="subsidy(3)">
|
|
|
- <view class="u-flex">
|
|
|
- <image
|
|
|
- v-if="language == 'zh-CN'"
|
|
|
- src="../../static/images/index/postage.png"
|
|
|
- style="width: 116rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <image
|
|
|
- v-if="language == 'en-US'"
|
|
|
- src="../../static/images/index/postage1.png"
|
|
|
- style="width: 130rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'es-ES'"
|
|
|
- src="../../static/images/index/postage2.png"
|
|
|
- style="width: 200rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <image
|
|
|
- v-if="language == 'it-IT'"
|
|
|
- src="../../static/images/index/postage3.png"
|
|
|
- style="width: 190rpx; height: 26rpx"
|
|
|
- mode=""
|
|
|
- >
|
|
|
- </image>
|
|
|
- <view class="biaoqian" style="background: rgba(248, 50, 36, 1)">{{
|
|
|
- i18n.Something
|
|
|
- }}</view>
|
|
|
- </view>
|
|
|
- <view
|
|
|
- class="u-flex"
|
|
|
- style="flex-wrap: wrap; justify-content: space-between"
|
|
|
- >
|
|
|
- <view
|
|
|
- v-for="(item, idx) in shippList"
|
|
|
- class="ssbox"
|
|
|
- style="margin-top: 8rpx"
|
|
|
- >
|
|
|
- <view class="" style="position: relative">
|
|
|
- <image
|
|
|
- :src="item.image"
|
|
|
- style="width: 124rpx; height: 124rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <view class="shopname" v-if="language == 'zh-CN'">
|
|
|
- {{ item.name_cn }}
|
|
|
- </view>
|
|
|
- <view class="shopname" v-if="language == 'en-US'">
|
|
|
- {{ item.name_en }}
|
|
|
- </view>
|
|
|
- <view class="shopname" v-if="language == 'es-ES'">
|
|
|
- {{ item.name_es }}
|
|
|
- </view>
|
|
|
- <view class="shopname" v-if="language == 'it-IT'">
|
|
|
- {{ item.name_ita }}
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- <view class="u-flex u-row-between" style="flex-wrap: wrap">
|
|
|
- <view
|
|
|
- class="bigbox"
|
|
|
- v-for="(item, index) in recomlist"
|
|
|
- style="position: relative"
|
|
|
- @click="todetail(item.id)"
|
|
|
- >
|
|
|
- <view
|
|
|
- v-if="item.is_discount == 0 || item.mer_is_discount == 0"
|
|
|
- class="discount"
|
|
|
- >
|
|
|
- {{ i18n.discount }}
|
|
|
- </view>
|
|
|
- <image
|
|
|
- :src="item.image"
|
|
|
- style="
|
|
|
- width: 340rpx;
|
|
|
- height: 340rpx;
|
|
|
- margin-left: -20rpx;
|
|
|
- margin-top: -18rpx;
|
|
|
- "
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <view class="title" v-if="language == 'zh-CN'">
|
|
|
- {{ item.name_cn }}
|
|
|
- </view>
|
|
|
- <view class="title" v-if="language == 'en-US'">
|
|
|
- {{ item.name_en }}
|
|
|
- </view>
|
|
|
- <view class="title" v-if="language == 'es-ES'">
|
|
|
- {{ item.name_es }}
|
|
|
- </view>
|
|
|
- <view class="title" v-if="language == 'it-IT'">
|
|
|
- {{ item.name_ita }}
|
|
|
- </view>
|
|
|
- <view class="">
|
|
|
- <text class="money"> ¥{{ item.discount_price }} </text>
|
|
|
- <text class="weight"> ¥{{ item.weight }}/kg </text>
|
|
|
- </view>
|
|
|
- <view
|
|
|
- v-if="item.label_arr"
|
|
|
- class="u-flex"
|
|
|
- style="
|
|
|
- flex-wrap: wrap;
|
|
|
- margin-top: 18rpx;
|
|
|
- column-gap: 6px;
|
|
|
- overflow: hidden;
|
|
|
- "
|
|
|
- >
|
|
|
- <!-- <view v-for="(child,idx) in item.label_arr" :key="idx" class="taber"
|
|
|
- style="border: 1rpx solid #E5BC78;color: #E5BC78;">
|
|
|
- <text>{{child.name_cn}}</text>
|
|
|
- </view> -->
|
|
|
- <view
|
|
|
- v-for="(child, idx) in item.label_arr.slice(0, 3)"
|
|
|
- :key="idx"
|
|
|
- class="taber"
|
|
|
- style="
|
|
|
- border: 1rpx solid rgba(237, 9, 9, 1);
|
|
|
- color: rgba(237, 9, 9, 1);
|
|
|
- "
|
|
|
- >
|
|
|
- <text v-if="language == 'zh-CN'">
|
|
|
- {{ child.name_cn }}
|
|
|
- </text>
|
|
|
- <text v-if="language == 'en-US'">
|
|
|
- {{ child.name_en }}
|
|
|
- </text>
|
|
|
- <text v-if="language == 'es-ES'">
|
|
|
- {{ child.name_es }}
|
|
|
- </text>
|
|
|
- <text v-if="language == 'it-IT'">
|
|
|
- {{ child.name_ita }}
|
|
|
- </text>
|
|
|
- </view>
|
|
|
- <!-- <view class="taber" style="border: 1rpx solid #E5BC78;color: #E5BC78;">以旧换新</view> -->
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
-
|
|
|
- <u-popup :show="show" mode="center" :round="16" bgColor="transparent">
|
|
|
- <view style="position: relative" @click="advert">
|
|
|
- <image
|
|
|
- :src="configimage"
|
|
|
- style="width: 570rpx; height: 764rpx; border-radius: 16rpx"
|
|
|
- mode=""
|
|
|
- ></image>
|
|
|
- <view class="" style="text-align: center" @click.stop="show = false">
|
|
|
- <image
|
|
|
- src="../../static/images/index/close.png"
|
|
|
- mode=""
|
|
|
- style="width: 70rpx; height: 70rpx"
|
|
|
- >
|
|
|
- </image>
|
|
|
- </view>
|
|
|
- </view>
|
|
|
- </u-popup>
|
|
|
- <view class="" style="height: 160rpx" v-if="recomlist.length > 3"></view>
|
|
|
- <kj-tabbar :value1="0" ref="kjTabbar"></kj-tabbar>
|
|
|
- </view>
|
|
|
+ <!-- 商城 -->
|
|
|
+ <view class="">
|
|
|
+ <!-- <view class="index-navbar"> -->
|
|
|
+ <view style="position: relative;">
|
|
|
+ <!-- 自定义导航栏 -->
|
|
|
+ <image src="../../static/images/index/back.png"
|
|
|
+ style="width: 750rpx;height: 1200rpx;position: absolute;top: 0;z-index: -1;" mode=""></image>
|
|
|
+ <u-navbar bgColor='rgba(255, 215,215, 1)' :placeholder='true' :fixed='true'>
|
|
|
+ <view class="u-nav-slot" slot="left" style="display: flex;">
|
|
|
+ <view class="" style="width: 40rpx;height:40rpx;position: relative;">
|
|
|
+ <u-badge :absolute='true' :offset="[0,-8]" :type="type" max="99" :value="unReadCount"></u-badge>
|
|
|
+ <image @click="tochat" src="../../static/images/index/xiaoxi.png" mode=""
|
|
|
+ style="width: 40rpx;height: 40rpx;">
|
|
|
+ </image>
|
|
|
+ </view>
|
|
|
+ <image @click="counter" src="../../static/images/index/compile.png" mode=""
|
|
|
+ style="width: 40rpx;height: 40rpx;margin-left: 22rpx;"></image>
|
|
|
+ <image src="../../static/images/index/dianhua.png" mode=""
|
|
|
+ style="width: 40rpx;height: 40rpx;margin-left: 22rpx;" @click="callphone"></image>
|
|
|
+ </view>
|
|
|
+ <view class="u-nav-slot" slot="center" style="width: 320rpx;">
|
|
|
+ <u-subsection bgColor='rgba(248, 50, 36, 0.1)' activeColor='#F83224' inactiveColor='#222'
|
|
|
+ :list="list" :current="current" @change="sectionChange"></u-subsection>
|
|
|
+ </view>
|
|
|
+ </u-navbar>
|
|
|
+ </view>
|
|
|
+ <swiper style="height: calc(100vh - 300rpx);" class="index-swiper" :circular="false" :autoplay="false" :current="current" @change="swipertotabs" >
|
|
|
+ <!-- 商城 -->
|
|
|
+ <swiper-item>
|
|
|
+ <view >
|
|
|
+ <kj-express></kj-express>
|
|
|
+ </view>
|
|
|
+ </swiper-item>
|
|
|
+ <swiper-item>
|
|
|
+ <view >
|
|
|
+ <kj-index></kj-index>
|
|
|
+ </view>
|
|
|
+ </swiper-item>
|
|
|
+ </swiper>
|
|
|
+ <view class="" style="height: 160rpx;" ></view>
|
|
|
+ <kj-tabbar :value1=0 ref="kjTabbar"></kj-tabbar>
|
|
|
+ </view>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
-import { conn } from "@/utils/WebIM";
|
|
|
-import { recom } from "../../network/shopApi.js";
|
|
|
-export default {
|
|
|
- data() {
|
|
|
- return {
|
|
|
- recomlist: [], //推荐列表
|
|
|
- //顶部分段器
|
|
|
- // list: [],
|
|
|
- current: 1,
|
|
|
- //tabs
|
|
|
- list1: [
|
|
|
- {
|
|
|
- name: "推荐",
|
|
|
- },
|
|
|
- ],
|
|
|
- //轮播图
|
|
|
- banner: [
|
|
|
- "https://cdn.uviewui.com/uview/swiper/swiper1.png",
|
|
|
- "https://cdn.uviewui.com/uview/swiper/swiper2.png",
|
|
|
- "https://cdn.uviewui.com/uview/swiper/swiper3.png",
|
|
|
- ],
|
|
|
- show: true,
|
|
|
- timer: "",
|
|
|
- language: "zh-CN",
|
|
|
- subsidylist: [], //百万补贴
|
|
|
- packlist: [], //拼包好物
|
|
|
- shippList: [], //海外包邮
|
|
|
- keyword: "",
|
|
|
- page: 1,
|
|
|
- index: 0,
|
|
|
- parent_id: "",
|
|
|
- last_page: "",
|
|
|
- configimage: "",
|
|
|
- url: "",
|
|
|
- unReadCount: 0,
|
|
|
- type: "error",
|
|
|
- };
|
|
|
- },
|
|
|
- computed: {
|
|
|
- i18n() {
|
|
|
- return this.$t("index");
|
|
|
- },
|
|
|
- list() {
|
|
|
- var list = [];
|
|
|
- list = [this.i18n.border, this.i18n.shop];
|
|
|
- return list;
|
|
|
- },
|
|
|
- },
|
|
|
- onReachBottom() {
|
|
|
- if (this.page < this.last_page) {
|
|
|
- if (this.current != 0) {
|
|
|
- this.page++;
|
|
|
- this.goods(this.parent_id);
|
|
|
- }
|
|
|
- } else {
|
|
|
- this.$u.toast(this.i18n.Nofurtherdata);
|
|
|
- }
|
|
|
- },
|
|
|
- onLoad(options) {
|
|
|
- // this.seater()
|
|
|
- if (options.current) {
|
|
|
- this.current = options.current;
|
|
|
- }
|
|
|
- //商品推荐
|
|
|
- this.getlista();
|
|
|
- },
|
|
|
- onShow() {
|
|
|
- this.config();
|
|
|
- // tabs列表
|
|
|
- this.category();
|
|
|
- //百万补贴
|
|
|
- this.subsid();
|
|
|
- //拼包好物
|
|
|
- this.pack();
|
|
|
- //海外包邮
|
|
|
- this.shipp();
|
|
|
- this.recommend();
|
|
|
- if (uni.getStorageSync("language") != "") {
|
|
|
- this.language = uni.getStorageSync("language");
|
|
|
- }
|
|
|
- this.HXlogin();
|
|
|
- this.$refs.kjTabbar.getNumber();
|
|
|
- },
|
|
|
- methods: {
|
|
|
- //获取快递列表
|
|
|
- getlista() {
|
|
|
- uni.$u.http
|
|
|
- .get("/api/express-company", {})
|
|
|
- .then((res) => {
|
|
|
- uni.setStorageSync("radiolist1", res);
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- HXlogin() {
|
|
|
- if (uni.getStorageSync("user_no") && uni.getStorageSync("pwd")) {
|
|
|
- var user_no = uni.getStorageSync("user_no");
|
|
|
- var pwd = uni.getStorageSync("pwd");
|
|
|
- conn
|
|
|
- .open({
|
|
|
- user: user_no,
|
|
|
- pwd: pwd,
|
|
|
- appKey: conn.appkey,
|
|
|
- })
|
|
|
- .then(() => {
|
|
|
- console.log("res");
|
|
|
- this.getlist();
|
|
|
- })
|
|
|
- .catch((reason) => {
|
|
|
- console.log("失败", reason);
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- getlist() {
|
|
|
- this.unReadCount = 0;
|
|
|
- conn
|
|
|
- .getServerConversations({
|
|
|
- pageSize: 50,
|
|
|
- cursor: "",
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- console.log(res);
|
|
|
- res.data.conversations.forEach((item) => {
|
|
|
- this.unReadCount += item.unReadCount;
|
|
|
- });
|
|
|
- console.log(this.unReadCount);
|
|
|
- });
|
|
|
- },
|
|
|
- callphone() {
|
|
|
- uni.$u.http
|
|
|
- .get("/api/config", {
|
|
|
- params: {
|
|
|
- module: "basic",
|
|
|
- },
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- console.log(res);
|
|
|
- uni.makePhoneCall({
|
|
|
- phoneNumber: res.service_mobile,
|
|
|
- });
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- advert() {
|
|
|
- uni.navigateTo({
|
|
|
- url: this.url,
|
|
|
- });
|
|
|
- },
|
|
|
- //广告弹窗
|
|
|
- config() {
|
|
|
- uni.$u.http
|
|
|
- .get("api/config", {
|
|
|
- params: {
|
|
|
- module: "advertising",
|
|
|
- },
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- console.log(res);
|
|
|
- this.configimage = res.image;
|
|
|
- this.url = res.url;
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //海外包邮接口
|
|
|
- shipp() {
|
|
|
- uni.$u.http
|
|
|
- .post("api/goods/shipping")
|
|
|
- .then((res) => {
|
|
|
- this.shippList = res.data.splice(0, 2);
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //拼包好物接口
|
|
|
- pack() {
|
|
|
- uni.$u.http
|
|
|
- .post("/api/goods/pack")
|
|
|
- .then((res) => {
|
|
|
- this.packlist = res.data.splice(0, 2);
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //百万补贴接口
|
|
|
- subsid() {
|
|
|
- uni.$u.http
|
|
|
- .post("/api/goods/subsidy")
|
|
|
- .then((res) => {
|
|
|
- console.log(res);
|
|
|
- this.subsidylist = res.data.splice(0, 4);
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //标签切换
|
|
|
- changetab(e) {
|
|
|
- this.page = 1;
|
|
|
- this.last_page = 0;
|
|
|
- this.index = e.index;
|
|
|
- this.parent_id = e.id;
|
|
|
- if (this.index == 0) {
|
|
|
- this.recommend();
|
|
|
- } else {
|
|
|
- this.recomlist = [];
|
|
|
- this.goods(this.parent_id);
|
|
|
- }
|
|
|
- },
|
|
|
- search() {
|
|
|
- if (this.index == 0) {
|
|
|
- this.recommend();
|
|
|
- } else {
|
|
|
- this.recomlist = [];
|
|
|
- this.goods(this.parent_id);
|
|
|
- }
|
|
|
- },
|
|
|
- //商品推荐
|
|
|
- recommend() {
|
|
|
- uni.$u.http
|
|
|
- .post("/api/goods/recommend", {
|
|
|
- keyword: this.keyword,
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- this.recomlist = res;
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //商品分类列表
|
|
|
- category() {
|
|
|
- uni.$u.http
|
|
|
- .get("/api/goods/category", {
|
|
|
- params: {
|
|
|
- parent_id: 0,
|
|
|
- },
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- const categoryArr = res;
|
|
|
- this.list1 = [
|
|
|
- {
|
|
|
- name: "",
|
|
|
- },
|
|
|
- ];
|
|
|
- if (this.language == "en-US") {
|
|
|
- categoryArr.forEach((item) => {
|
|
|
- item.name = item.name_en;
|
|
|
- });
|
|
|
- this.list1[0].name = "recommend";
|
|
|
- }
|
|
|
- if (this.language == "es-ES") {
|
|
|
- categoryArr.forEach((item) => {
|
|
|
- item.name = item.name_es;
|
|
|
- });
|
|
|
- this.list1[0].name = "recomendación";
|
|
|
- }
|
|
|
- if (this.language == "it-IT") {
|
|
|
- categoryArr.forEach((item) => {
|
|
|
- item.name = item.name_ita;
|
|
|
- });
|
|
|
- this.list1[0].name = "raccomandata";
|
|
|
- }
|
|
|
-
|
|
|
- if (this.language == "zh-CN") {
|
|
|
- categoryArr.forEach((item) => {
|
|
|
- item.name = item.name_cn;
|
|
|
- });
|
|
|
- this.list1[0].name = "推荐";
|
|
|
- }
|
|
|
- this.list1 = this.list1.concat(categoryArr);
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //商品列表
|
|
|
- goods(id) {
|
|
|
- uni.$u.http
|
|
|
- .get("/api/goods", {
|
|
|
- params: {
|
|
|
- parent_id: id,
|
|
|
- limit: 10,
|
|
|
- page: this.page,
|
|
|
- keyword: this.keyword,
|
|
|
- },
|
|
|
- })
|
|
|
- .then((res) => {
|
|
|
- this.recomlist = this.recomlist.concat(res.data);
|
|
|
- this.last_page = res.last_page;
|
|
|
- })
|
|
|
- .catch(() => {});
|
|
|
- },
|
|
|
- //百万补贴跳转
|
|
|
- subsidy(item) {
|
|
|
- uni.navigateTo({
|
|
|
- url: "/pageA/subsidy?show=" + item,
|
|
|
- });
|
|
|
- },
|
|
|
- //物流计算器
|
|
|
- counter() {
|
|
|
- uni.navigateTo({
|
|
|
- url: "/pageA/counter",
|
|
|
- });
|
|
|
- },
|
|
|
- //消息
|
|
|
- tochat() {
|
|
|
- uni.navigateTo({
|
|
|
- url: "/pageA/chat/news",
|
|
|
- });
|
|
|
- },
|
|
|
- //商品分类
|
|
|
- shoptype() {
|
|
|
- uni.navigateTo({
|
|
|
- url: "/pageA/shoptype",
|
|
|
- });
|
|
|
- },
|
|
|
- //分段器切换
|
|
|
- sectionChange(index) {
|
|
|
- this.current = index;
|
|
|
- console.log(index);
|
|
|
- if (this.current == 0) {
|
|
|
- uni.switchTab({
|
|
|
- url: "/pages/express/express?current=0",
|
|
|
- });
|
|
|
- this.current = 1;
|
|
|
- }
|
|
|
- },
|
|
|
- //详情
|
|
|
- todetail(id) {
|
|
|
- uni.navigateTo({
|
|
|
- url: "/pageA/productdetails?id=" + id,
|
|
|
- });
|
|
|
- },
|
|
|
- },
|
|
|
-};
|
|
|
+ import {
|
|
|
+ conn,
|
|
|
+ } from '@/utils/WebIM';
|
|
|
+ import {
|
|
|
+ recom
|
|
|
+ } from "../../network/shopApi.js";
|
|
|
+ export default {
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ recomlist: [], //推荐列表
|
|
|
+ //顶部分段器
|
|
|
+ // list: [],
|
|
|
+ current: 1,
|
|
|
+ //tabs
|
|
|
+ list1: [{
|
|
|
+ name: '推荐',
|
|
|
+ }],
|
|
|
+ //轮播图
|
|
|
+ banner: [
|
|
|
+ 'https://cdn.uviewui.com/uview/swiper/swiper1.png',
|
|
|
+ 'https://cdn.uviewui.com/uview/swiper/swiper2.png',
|
|
|
+ 'https://cdn.uviewui.com/uview/swiper/swiper3.png',
|
|
|
+ ],
|
|
|
+ show: true,
|
|
|
+ timer: '',
|
|
|
+ language: 'zh-CN',
|
|
|
+ subsidylist: [], //百万补贴
|
|
|
+ packlist: [], //拼包好物
|
|
|
+ shippList: [], //海外包邮
|
|
|
+ keyword: '',
|
|
|
+ page: 1,
|
|
|
+ index: 0,
|
|
|
+ parent_id: '',
|
|
|
+ last_page: '',
|
|
|
+ configimage: '',
|
|
|
+ url: '',
|
|
|
+ unReadCount: 0,
|
|
|
+ type: "error",
|
|
|
+ }
|
|
|
+ },
|
|
|
+ computed: {
|
|
|
+ i18n() {
|
|
|
+ return this.$t('index')
|
|
|
+ },
|
|
|
+ list() {
|
|
|
+ var list = []
|
|
|
+ list = [this.i18n.border, this.i18n.shop]
|
|
|
+ return list
|
|
|
+ }
|
|
|
+ },
|
|
|
+ onReachBottom() {
|
|
|
+ // if (this.page < this.last_page) {
|
|
|
+ // if (this.current != 0) {
|
|
|
+ // this.page++
|
|
|
+ // this.goods(this.parent_id)
|
|
|
+ // }
|
|
|
+ // } else {
|
|
|
+ // this.$u.toast(this.i18n.Nofurtherdata)
|
|
|
+ // }
|
|
|
+ },
|
|
|
+ onLoad(options) {
|
|
|
+ // this.seater()
|
|
|
+ // if (options.current) {
|
|
|
+ // this.current = options.current
|
|
|
+ // }
|
|
|
+ // //商品推荐
|
|
|
+ // this.getlista()
|
|
|
+ },
|
|
|
+ onShow() {
|
|
|
+ // this.config()
|
|
|
+ // // tabs列表
|
|
|
+ // this.category()
|
|
|
+ // //百万补贴
|
|
|
+ // this.subsid()
|
|
|
+ // //拼包好物
|
|
|
+ // this.pack()
|
|
|
+ // //海外包邮
|
|
|
+ // this.shipp()
|
|
|
+ // this.recommend()
|
|
|
+ // if (uni.getStorageSync('language') != '') {
|
|
|
+ // this.language = uni.getStorageSync('language')
|
|
|
+ // }
|
|
|
+ // this.HXlogin()
|
|
|
+ this.$refs.kjTabbar.getNumber();
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ //左右切换
|
|
|
+ swipertotabs(e){
|
|
|
+ this.current = e.detail.current
|
|
|
+ },
|
|
|
+ //分段器切换
|
|
|
+ sectionChange(index) {
|
|
|
+ this.current = index;
|
|
|
+ // if (this.current == 0) {
|
|
|
+ // uni.switchTab({
|
|
|
+ // url: '/pages/express/express?current=0'
|
|
|
+ // })
|
|
|
+ // this.current = 1
|
|
|
+ // }
|
|
|
+ },
|
|
|
+ // //获取快递列表
|
|
|
+ // getlista() {
|
|
|
+ // uni.$u.http.get('/api/express-company', {}).then((res) => {
|
|
|
+ // uni.setStorageSync('radiolist1', res)
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // HXlogin() {
|
|
|
+ // if (uni.getStorageSync('user_no') && uni.getStorageSync('pwd')) {
|
|
|
+ // var user_no = uni.getStorageSync('user_no')
|
|
|
+ // var pwd = uni.getStorageSync('pwd')
|
|
|
+ // conn.open({
|
|
|
+ // user: user_no,
|
|
|
+ // pwd: pwd,
|
|
|
+ // appKey: conn.appkey
|
|
|
+ // }).then(() => {
|
|
|
+ // console.log('res');
|
|
|
+ // this.getlist()
|
|
|
+ // }).catch(reason => {
|
|
|
+ // console.log('失败', reason);
|
|
|
+ // })
|
|
|
+
|
|
|
+ // }
|
|
|
+ // },
|
|
|
+ // getlist() {
|
|
|
+ // this.unReadCount = 0
|
|
|
+ // conn.getServerConversations({
|
|
|
+ // pageSize: 50,
|
|
|
+ // cursor: ''
|
|
|
+ // }).then((res) => {
|
|
|
+ // console.log(res);
|
|
|
+ // res.data.conversations.forEach((item) => {
|
|
|
+ // this.unReadCount += item.unReadCount
|
|
|
+ // })
|
|
|
+ // console.log(this.unReadCount);
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ callphone() {
|
|
|
+ uni.$u.http.get('/api/config', {
|
|
|
+ params: {
|
|
|
+ module: 'basic'
|
|
|
+ }
|
|
|
+ }).then((res) => {
|
|
|
+ console.log(res);
|
|
|
+ uni.makePhoneCall({
|
|
|
+ phoneNumber: res.service_mobile
|
|
|
+ })
|
|
|
+ }).catch(() => {
|
|
|
+
|
|
|
+ })
|
|
|
+
|
|
|
+ },
|
|
|
+ // advert() {
|
|
|
+ // uni.navigateTo({
|
|
|
+ // url: this.url
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //广告弹窗
|
|
|
+ // config() {
|
|
|
+ // uni.$u.http.get('api/config', {
|
|
|
+ // params: {
|
|
|
+ // module: 'advertising'
|
|
|
+ // }
|
|
|
+ // }).then((res) => {
|
|
|
+ // console.log(res);
|
|
|
+ // this.configimage = res.image
|
|
|
+ // this.url = res.url
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //海外包邮接口
|
|
|
+ // shipp() {
|
|
|
+ // uni.$u.http.post('api/goods/shipping').then((res) => {
|
|
|
+ // this.shippList = res.data.splice(0, 2)
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //拼包好物接口
|
|
|
+ // pack() {
|
|
|
+ // uni.$u.http.post('/api/goods/pack').then((res) => {
|
|
|
+ // this.packlist = res.data.splice(0, 2)
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //百万补贴接口
|
|
|
+ // subsid() {
|
|
|
+ // uni.$u.http.post('/api/goods/subsidy').then((res) => {
|
|
|
+ // console.log(res);
|
|
|
+ // this.subsidylist = res.data.splice(0, 4)
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //标签切换
|
|
|
+ // changetab(e) {
|
|
|
+ // this.page = 1
|
|
|
+ // this.last_page = 0
|
|
|
+ // this.index = e.index
|
|
|
+ // this.parent_id = e.id
|
|
|
+ // if (this.index == 0) {
|
|
|
+ // this.recommend()
|
|
|
+ // } else {
|
|
|
+ // this.recomlist = []
|
|
|
+ // this.goods(this.parent_id)
|
|
|
+ // }
|
|
|
+ // },
|
|
|
+ // search() {
|
|
|
+ // if (this.index == 0) {
|
|
|
+ // this.recommend()
|
|
|
+ // } else {
|
|
|
+ // this.recomlist = []
|
|
|
+ // this.goods(this.parent_id)
|
|
|
+ // }
|
|
|
+ // },
|
|
|
+ // //商品推荐
|
|
|
+ // recommend() {
|
|
|
+ // uni.$u.http.post('/api/goods/recommend', {
|
|
|
+ // keyword: this.keyword
|
|
|
+ // }).then((res) => {
|
|
|
+ // this.recomlist = res
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //商品分类列表
|
|
|
+ // category() {
|
|
|
+ // uni.$u.http.get('/api/goods/category', {
|
|
|
+ // params: {
|
|
|
+ // parent_id: 0
|
|
|
+ // }
|
|
|
+ // }).then((res) => {
|
|
|
+ // const categoryArr = res
|
|
|
+ // this.list1 = [{
|
|
|
+ // name: ''
|
|
|
+ // }]
|
|
|
+ // if (this.language == 'en-US') {
|
|
|
+ // categoryArr.forEach(item => {
|
|
|
+ // item.name = item.name_en
|
|
|
+ // })
|
|
|
+ // this.list1[0].name = 'recommend'
|
|
|
+ // }
|
|
|
+ // if (this.language == 'es-ES') {
|
|
|
+ // categoryArr.forEach(item => {
|
|
|
+ // item.name = item.name_es
|
|
|
+ // })
|
|
|
+ // this.list1[0].name = 'recomendación'
|
|
|
+ // }
|
|
|
+ // if (this.language == 'it-IT') {
|
|
|
+ // categoryArr.forEach(item => {
|
|
|
+ // item.name = item.name_ita
|
|
|
+ // })
|
|
|
+ // this.list1[0].name = 'raccomandata'
|
|
|
+ // }
|
|
|
+
|
|
|
+ // if (this.language == 'zh-CN') {
|
|
|
+ // categoryArr.forEach(item => {
|
|
|
+ // item.name = item.name_cn
|
|
|
+ // })
|
|
|
+ // this.list1[0].name = '推荐'
|
|
|
+ // }
|
|
|
+ // this.list1 = this.list1.concat(categoryArr)
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //商品列表
|
|
|
+ // goods(id) {
|
|
|
+ // uni.$u.http.get('/api/goods', {
|
|
|
+ // params: {
|
|
|
+ // parent_id: id,
|
|
|
+ // limit: 10,
|
|
|
+ // page: this.page,
|
|
|
+ // keyword: this.keyword
|
|
|
+ // }
|
|
|
+ // }).then((res) => {
|
|
|
+ // this.recomlist = this.recomlist.concat(res.data)
|
|
|
+ // this.last_page = res.last_page
|
|
|
+ // }).catch(() => {
|
|
|
+
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //百万补贴跳转
|
|
|
+ // subsidy(item) {
|
|
|
+ // uni.navigateTo({
|
|
|
+ // url: '/pageA/subsidy?show=' + item
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+ // //物流计算器
|
|
|
+ counter() {
|
|
|
+ uni.navigateTo({
|
|
|
+ url: '/pageA/counter'
|
|
|
+ })
|
|
|
+ },
|
|
|
+ // //消息
|
|
|
+ tochat() {
|
|
|
+ uni.navigateTo({
|
|
|
+ url: '/pageA/chat/news'
|
|
|
+ })
|
|
|
+ },
|
|
|
+ // //商品分类
|
|
|
+ // shoptype() {
|
|
|
+ // uni.navigateTo({
|
|
|
+ // url: '/pageA/shoptype'
|
|
|
+ // })
|
|
|
+ // },
|
|
|
+
|
|
|
+ //详情
|
|
|
+ // todetail(id) {
|
|
|
+ // uni.navigateTo({
|
|
|
+ // url: '/pageA/productdetails?id=' + id
|
|
|
+ // })
|
|
|
+ // }
|
|
|
+ }
|
|
|
+ }
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
-page {
|
|
|
- background-color: rgba(0, 0, 0, 0);
|
|
|
-}
|
|
|
+ page {
|
|
|
+ background-color: rgba(0, 0, 0, 0)
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
.discount {
|
|
|
// width: 100rpx;
|