index.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927
  1. <template>
  2. <view class="uni-flex lists jz_lists uni-column jz_myfit jz_agent cart jz_cart ">
  3. <view class="tab-search uni-column" style="background-color: #F1F1F1;">
  4. <view class="tabList">
  5. <scroll-view class="uni-flex uni-swiper-tab" scroll-x :scroll-left="scrollLeft" id="tab-bars">
  6. <view v-for="(tab, i) in categorys" :key="i" class="swiper-tab-list" :id="'tab' + tab.id" :data-current="index" @click="changeTab(i, tab)">
  7. <view class="productTitle-item uni-flex uni-column">
  8. <view :class="['picname', curIndex == i ? 'activeLine' : '']">{{ tab.title }}</view>
  9. </view>
  10. </view>
  11. </scroll-view>
  12. </view>
  13. <view class="search uni-flex ">
  14. <view class="uni-flex-item uni-flex search-input">
  15. <input
  16. placeholder="请选择地区"
  17. @input="inputChange"
  18. v-model="key"
  19. :focus="isFocus"
  20. @focus="focus"
  21. @blur="blur"
  22. class="uni-flex-item"
  23. disabled="disabled"
  24. @click="showMulLinkageThreePicker"
  25. />
  26. <view class="icon icon-del uni-flex justify-align-center" style="height: 100%;" @click.stop="clear" v-if="isDelShow"><icon type="clear" size="12"></icon></view>
  27. </view>
  28. <view class="searchBtn uni-flex justify-align-center" @click="search">
  29. <image src="../../../static/search02.png"></image>
  30. <text>搜索</text>
  31. </view>
  32. </view>
  33. </view>
  34. <view class="agent-product uni-flex uni-column">
  35. <view class="agentTop uni-flex space-between" id="list">
  36. <view class="topItem uni-flex uni-column align-items " v-if="item.agency == 2" v-for="(item, key) in products" :key="key" @click.stop="selected(products, key)">
  37. <view class="uni-flex topItem-wrap">
  38. <image
  39. class="image topImg"
  40. :class="{ lazy: !item.display }"
  41. :id="'lazy' + key"
  42. :data-index="0"
  43. @load="imageOnLoad(item, key)"
  44. :src="item.display ? item.pic : ''"
  45. />
  46. <view class="loadbox" :class="{ loaded: item.loaded }"><view class="load"></view></view>
  47. </view>
  48. <view class=" uni-flex uni-column">
  49. <view class="uni-flex agencyTitle justify-align-center" v-if="!item.show">{{ item.title }}</view>
  50. <view class=" agencyTitle titleSingle " v-if="item.show">{{ item.title }}</view>
  51. <view class="uni-flex justify-align-center" style="color: #f00000;" v-if="user.agency == 1">¥{{ item.salePrice.toFixed(2) }}</view>
  52. </view>
  53. <view class="selectBtn uni-flex ">
  54. <image src="../../../static/select.png" v-if="!item.select"></image>
  55. <image src="../../../static/selectActive.png" v-if="item.select"></image>
  56. </view>
  57. </view>
  58. </view>
  59. <view class="agentBottom uni-flex space-between"></view>
  60. </view>
  61. <load-more :loadingType="loadingType" :contentText="contentText" class="loadMore"></load-more>
  62. <backTop :src="backTop.src" :scrollTop="backTop.scrollTop"></backTop>
  63. <mpvue-city-picker
  64. :themeColor="themeColor"
  65. ref="mpvueCityPicker"
  66. :pickerValueDefault="cityPickerValueDefault"
  67. @onCancel="onCancel"
  68. @onConfirm="onConfirm"
  69. @onReset="onReset"
  70. ></mpvue-city-picker>
  71. <view class="uni-flex uni-row footer" v-if="products.length > 0&&isShow==true">
  72. <view class="uni-flex uni-flex-item ">
  73. <view class="uni-flex item-sel ">
  74. <view :class="[yuan, { bg: allSelect }]" @click="AllSelect()"><text v-if="allSelect" class="gou"></text></view>
  75. </view>
  76. <view class="uni-flex uni-flex-item itemAll">全选</view>
  77. <view class="uni-flex uni-flex-item3"></view>
  78. <view class="uni-flex uni-flex-item3 justify-align-center">
  79. <view class="uni-flex uni-flex-item btn" @click="js()" :class="{ activeBg: bgChange }">加入购物车({{ allNum }})</view>
  80. </view>
  81. </view>
  82. </view>
  83. </view>
  84. </template>
  85. <script>
  86. import { mapState, mapMutations } from 'vuex';
  87. import mpvueCityPicker from '@/components/mpvue-citypicker/mpvueCityPicker.vue';
  88. import util from '../../../common/util.js';
  89. import address from '../../../common/getAddessId.js';
  90. import amap from '../../../common/amap-wx.js';
  91. import loadMore from '@/components/uni-load-more.vue';
  92. import backTop from '@/components/uni-top.vue';
  93. import cart from '../../../common/cart.js';
  94. var index;
  95. export default {
  96. computed: {
  97. ...mapState(['hasLogin', 'forcedLogin', 'jyyUser'])
  98. },
  99. components: {
  100. loadMore,
  101. backTop,
  102. mpvueCityPicker
  103. },
  104. data() {
  105. return {
  106. isShow: false,
  107. newProducts: [],
  108. allNum: 0,
  109. filterCount: 0,
  110. allSelect: false,
  111. bgChange: false,
  112. cityPickerValueDefault: [0, 0, 1],
  113. themeColor: '#007AFF',
  114. pickerText: '',
  115. amapPlugin: null,
  116. amapKey: '408ca849e7fb38410487446db08ec898',
  117. addressName: '',
  118. backTop: {
  119. src: '../../../static/top.png',
  120. scrollTop: 0
  121. },
  122. loadingType: 0,
  123. contentText: {
  124. contentdown: '上拉显示更多',
  125. contentrefresh: '正在加载...',
  126. contentnomore: '没有更多数据了'
  127. },
  128. active: false,
  129. isDelShow: false,
  130. isFocus: false,
  131. sortNavfixed: false,
  132. show: false,
  133. windowHeight: 0,
  134. type: 0,
  135. cates: [
  136. {
  137. css: '',
  138. id: '0',
  139. no: '000',
  140. show: '0',
  141. subs: [],
  142. title: '全部品牌'
  143. }
  144. ],
  145. categorys: [
  146. {
  147. ico: '../../../static/merchant/all.png',
  148. id: '000',
  149. no: '000',
  150. title: '全部品牌'
  151. }
  152. ],
  153. category: {},
  154. products: [],
  155. curIndex: 0,
  156. key: '',
  157. id: '000',
  158. scrollLeft: 0,
  159. scrollY: 0,
  160. agentStatus: 1,
  161. user: {},
  162. addressId: '',
  163. popupType: '',
  164. popupContent: '',
  165. popupShow: false
  166. };
  167. },
  168. onPageScroll(e) {
  169. this.backTop.scrollTop = e.scrollTop;
  170. util.loads(this.products, 'list', this.windowHeight);
  171. uni.createSelectorQuery()
  172. .selectAll('#list')
  173. .boundingClientRect(datas => {
  174. this.sortNavfixed = parseInt(datas[0].top) < 78 ? true : false;
  175. })
  176. .exec();
  177. },
  178. onShow() {},
  179. onLoad(e) {
  180. this.user = JSON.parse(this.jyyUser);
  181. index = 1;
  182. this.windowHeight = uni.getSystemInfoSync().windowHeight;
  183. this.getCategory();
  184. if (e.n > 4) {
  185. setTimeout(() => {
  186. this.public(e.n, e);
  187. }, 200);
  188. }
  189. // #ifdef MP-WEIXIN
  190. this.amapPlugin = new amap.AMapWX({
  191. key: this.amapKey
  192. });
  193. this.getRegeo();
  194. // #endif
  195. // #ifdef H5
  196. uni.getLocation({
  197. type: 'wgs84',
  198. geocode: true,
  199. success: res => {
  200. let gitude = res.longitude + ',' + res.latitude;
  201. let that = this;
  202. uni.request({
  203. url: 'https://restapi.amap.com/v3/geocode/regeo',
  204. method: 'POST',
  205. header: {
  206. 'content-type': 'application/x-www-form-urlencoded'
  207. },
  208. data: {
  209. output: 'JSON',
  210. location: gitude,
  211. key: 'bf5fad85b6706db59ac208af908aa99e'
  212. },
  213. success: result => {
  214. let addresss = result.data.regeocode.addressComponent;
  215. console.log(address);
  216. let province = addresss.province;
  217. let city = addresss.city;
  218. let district = addresss.district;
  219. that.addressName = province + '-' + city + '-' + district;
  220. that.addressId = address.getAddressid(province, city, district);
  221. that.key = that.addressName;
  222. that.getData();
  223. },
  224. fail: () => {},
  225. complete: () => {}
  226. });
  227. }
  228. });
  229. // #endif
  230. },
  231. onPullDownRefresh() {
  232. this.getData();
  233. setTimeout(function() {
  234. uni.stopPullDownRefresh();
  235. }, 1000);
  236. },
  237. onReachBottom() {
  238. this.getData();
  239. },
  240. watch: {},
  241. methods: {
  242. ...mapMutations(['setAgency']),
  243. //单选
  244. selected(e, index) {
  245. this.newProducts = [];
  246. let select = e[index].select;
  247. e[index].select = !select;
  248. this.$set(this.products[index], 'select', e[index].select);
  249. //判断商品是否全部选中,是的话,全选也选中
  250. let json = this.products.length;
  251. for (let j = 0; j < this.products.length; j++) {
  252. if (this.products[j].agency == 2) {
  253. this.newProducts.push(this.products[j]);
  254. }
  255. }
  256. let all = true;
  257. console.log(this.newProducts);
  258. for (let i = 0; i < this.newProducts.length; i++) {
  259. all *= this.newProducts[i].select;
  260. }
  261. if (all == true) {
  262. this.allSelect = true;
  263. } else {
  264. this.allSelect = false;
  265. }
  266. this.allSl();
  267. },
  268. // 全选
  269. AllSelect() {
  270. let selected = this.allSelect;
  271. this.allSelect = !selected;
  272. let arr = this.products;
  273. for (let i = 0; i < arr.length; i++) {
  274. if (arr[i].agency == 2) {
  275. //循环商品为选中
  276. if (this.allSelect == true) {
  277. this.products[i].select = true;
  278. }
  279. if (this.allSelect == false) {
  280. this.products[i].select = false;
  281. }
  282. }
  283. }
  284. this.allSl(); //商品数量
  285. },
  286. //结算商品数量
  287. allSl() {
  288. let js = 0;
  289. let arr = this.products;
  290. for (let i = 0; i < arr.length; i++) {
  291. js += this.products[i].select;
  292. }
  293. this.allNum = js;
  294. if (this.allNum > 0) {
  295. this.bgChange = true;
  296. } else {
  297. this.bgChange = false;
  298. }
  299. },
  300. // 结算
  301. js() {
  302. let idStr = '';
  303. for (let i = 0; i < this.products.length; i++) {
  304. if (this.products[i].select) {
  305. idStr += this.products[i].id + ',';
  306. }
  307. }
  308. let str = idStr.slice(0, idStr.length - 1);
  309. if (str == '') {
  310. uni.showToast({
  311. title: '请选择商品!',
  312. icon: 'none'
  313. });
  314. return;
  315. }
  316. uni.showLoading({
  317. title: '操作中'
  318. });
  319. uni.request({
  320. url: this.webUrl + 'FlashCart',
  321. method: 'POST',
  322. header: {
  323. 'content-type': 'application/x-www-form-urlencoded'
  324. },
  325. data: {
  326. userId: this.user.id,
  327. id: str
  328. },
  329. success: res => {
  330. uni.hideLoading();
  331. if (res.data.result.length > 0) {
  332. cart.addCart(res.data.result);
  333. //cart.updateCart();
  334. uni.switchTab({
  335. url: '../cart/cart'
  336. });
  337. } else {
  338. uni.showToast({
  339. title: '操作失败',
  340. icon: 'none'
  341. });
  342. }
  343. },
  344. fail: () => {},
  345. complete: () => {}
  346. });
  347. },
  348. onConfirm(e) {
  349. this.pickerText = e.label;
  350. this.key = this.pickerText;
  351. this.addressId = e.id;
  352. },
  353. getRegeo() {
  354. uni.showLoading({
  355. title: '获取信息中'
  356. });
  357. this.amapPlugin.getRegeo({
  358. success: data => {
  359. let province = data[0].regeocodeData.addressComponent.province;
  360. let city = data[0].regeocodeData.addressComponent.city;
  361. let district = data[0].regeocodeData.addressComponent.district;
  362. this.addressName = province + '-' + city + '-' + district;
  363. this.addressId = address.getAddressid(province, city, district);
  364. this.key = this.addressName;
  365. this.getData();
  366. uni.hideLoading();
  367. }
  368. });
  369. },
  370. showMulLinkageThreePicker() {
  371. this.$refs.mpvueCityPicker.show();
  372. },
  373. focus() {
  374. this.active = true;
  375. //HM修改 增加获取焦点判断
  376. if (this.key != '') {
  377. this.isDelShow = true;
  378. }
  379. },
  380. inputChange(event) {
  381. var keyword = event.detail.value;
  382. this.$emit('input', keyword);
  383. if (this.key) {
  384. this.isDelShow = true;
  385. }
  386. },
  387. blur() {
  388. this.isFocus = false;
  389. if (!this.key) {
  390. this.active = false;
  391. }
  392. },
  393. clear() {
  394. //HM修改 收起键盘
  395. uni.hideKeyboard();
  396. this.isFocus = false;
  397. this.key = '';
  398. this.active = false;
  399. //HM修改 清空内容时候触发组件input
  400. this.isDelShow = false;
  401. },
  402. search() {
  403. index = 1;
  404. this.loadingType = 0;
  405. this.allNum = 0;
  406. this.allSelect = false;
  407. this.bgChange = false;
  408. this.products = [];
  409. this.getData();
  410. },
  411. onCancel(e) {
  412. //console.log(e)
  413. },
  414. onReset() {
  415. this.pickerText = '';
  416. this.key = '';
  417. },
  418. getData() {
  419. if (this.loadingType !== 0) {
  420. return;
  421. }
  422. uni.request({
  423. url: this.webUrl + 'List',
  424. method: 'POST',
  425. header: {
  426. 'content-type': 'application/x-www-form-urlencoded'
  427. },
  428. data: {
  429. pageNum: index,
  430. brand: this.id,
  431. area: this.key,
  432. userid: this.user.id,
  433. pageSize: 100,
  434. agentStatus: 1,
  435. agency: this.user.agency
  436. },
  437. success: res => {
  438. if (res.data.result.ratioProducts.length > 0) {
  439. this.products = this.products.concat(res.data.result.ratioProducts);
  440. for (let i = 0; i < this.products.length; i++) {
  441. if (this.products[i].agency == 2) {
  442. this.isShow = true;
  443. break
  444. }else{
  445. this.isShow = false;
  446. }
  447. }
  448. setTimeout(() => {
  449. util.loads(this.products, 'list', this.windowHeight);
  450. }, 500);
  451. } else {
  452. this.loadingType = 2;
  453. return;
  454. }
  455. if (index == parseInt(res.data.result.pages)) {
  456. this.loadingType = 2;
  457. return;
  458. } else {
  459. this.loadingType = 0;
  460. }
  461. index++;
  462. },
  463. fail: () => {},
  464. complete: () => {}
  465. });
  466. },
  467. getElSize(id) {
  468. //得到元素的size
  469. return new Promise((res, rej) => {
  470. uni.createSelectorQuery()
  471. .select('#' + id)
  472. .fields(
  473. {
  474. size: true,
  475. scrollOffset: true
  476. },
  477. data => {
  478. res(data);
  479. }
  480. )
  481. .exec();
  482. });
  483. },
  484. async public(i, e) {
  485. this.id = e.id;
  486. let index = i;
  487. let tabBars = await this.getElSize('tab-bars'),
  488. tabBarScrollLeft = tabBars.scrollLeft; //点击的时候记录并设置scrollLeft
  489. let width = 0;
  490. for (let j = 0; j < index; j++) {
  491. let result = await this.getElSize('tab' + this.categorys[j].id);
  492. width += result.width;
  493. }
  494. let winWidth = uni.getSystemInfoSync().windowWidth,
  495. nowElement = await this.getElSize('tab' + this.categorys[index].id),
  496. nowWidth = nowElement.width;
  497. if (width + nowWidth - tabBarScrollLeft > winWidth - nowWidth) {
  498. this.scrollLeft = width + nowWidth * 3 - winWidth;
  499. }
  500. if (width < tabBarScrollLeft) {
  501. this.scrollLeft = width;
  502. }
  503. },
  504. changeTab(i, e) {
  505. if (this.curIndex === i) {
  506. return false;
  507. } else {
  508. this.public(i, e);
  509. this.isClickChange = true;
  510. this.curIndex = i;
  511. index = 1;
  512. this.loadingType = 0;
  513. this.products = [];
  514. this.allNum = 0;
  515. this.allSelect = false;
  516. this.bgChange = false;
  517. this.getData();
  518. setTimeout(() => {
  519. util.loads(this.products, 'list', this.windowHeight);
  520. }, 500);
  521. }
  522. },
  523. imageOnLoad(e) {
  524. e.loaded = true;
  525. },
  526. getCategory() {
  527. uni.request({
  528. url: this.webUrl + 'Brands',
  529. method: 'POST',
  530. header: {
  531. 'content-type': 'application/x-www-form-urlencoded'
  532. },
  533. success: res => {
  534. this.cates = this.cates.concat(res.data.result.brands);
  535. this.categorys = this.categorys.concat(res.data.result.brands);
  536. },
  537. fail: () => {},
  538. complete: () => {}
  539. });
  540. }
  541. }
  542. };
  543. </script>
  544. <style>
  545. /*----- 改动的 */
  546. /* #ifdef H5 */
  547. .jz_cart .footer{
  548. bottom: 0!important;
  549. }
  550. /* #endif */
  551. .activeBg {
  552. background: #dd0101 !important;
  553. }
  554. .jz_cart.jz_agent .btn {
  555. border-radius: 6rpx;
  556. background: #cdcdcd;
  557. letter-spacing: 4rpx;
  558. }
  559. .jz_agent .center {
  560. width: 100%;
  561. }
  562. .jz_agent .selectContent {
  563. padding: 0 20upx;
  564. }
  565. .jz_agent .selectBtn {
  566. position: absolute;
  567. right: 0upx;
  568. bottom: 0upx;
  569. }
  570. .jz_agent .selectBtn image {
  571. width: 40upx;
  572. height: 40upx;
  573. }
  574. .jz_agent .agencyStatus {
  575. position: absolute;
  576. top: 50%;
  577. left: 50%;
  578. margin-left: -50upx;
  579. margin-top: -50upx;
  580. width: 100upx;
  581. height: 100upx;
  582. background: rgba(0, 0, 0, 0.4);
  583. z-index: 888;
  584. border-radius: 50%;
  585. color: #ffffff;
  586. }
  587. .jz_agent .loadMore {
  588. margin-bottom: 100upx;
  589. }
  590. .jz_agent .agent-product .agentTop .topItem {
  591. position: relative;
  592. padding-bottom: 40upx;
  593. border-radius: 8upx;
  594. box-shadow: 0 0 10rpx 0 #b2b2b2;
  595. margin-bottom: 30upx;
  596. }
  597. .jz_agent .beginCard_btn {
  598. position: fixed;
  599. left: 0;
  600. bottom: 20upx;
  601. width: 100%;
  602. z-index: 999;
  603. }
  604. .jz_agent .beginCard_btn button {
  605. display: block;
  606. width: 550upx;
  607. height: 115upx;
  608. line-height: 115rpx;
  609. font-size: 28rpx;
  610. background: url(../../../static/btn.png) no-repeat;
  611. background-size: 550upx 115upx;
  612. color: #ffffff;
  613. }
  614. .jz_agent .checkStyle {
  615. position: absolute;
  616. top: 0upx;
  617. left: -16upx;
  618. width: 0;
  619. height: 0;
  620. z-index: 100;
  621. border-top: 50upx solid #11c200;
  622. border-right: 50upx solid transparent;
  623. }
  624. .jz_agent .checkStyleActick {
  625. position: absolute;
  626. top: 0upx;
  627. left: -16upx;
  628. width: 0;
  629. height: 0;
  630. z-index: 100;
  631. border-top: 50upx solid #ff0000;
  632. border-right: 50upx solid transparent;
  633. }
  634. .jz_agent .topItem {
  635. position: relative;
  636. z-index: 666;
  637. overflow: hidden;
  638. }
  639. .jz_agent .swiper-tab-list {
  640. width: 170upx !important;
  641. }
  642. .jz_lists scroll-view.uni-swiper-tab {
  643. padding-top: 0upx !important;
  644. }
  645. .jz_myfit.jz_lists scroll-view.uni-swiper-tab {
  646. padding-top: 0upx !important;
  647. margin-bottom: 0upx !important;
  648. padding-bottom: 0upx;
  649. }
  650. .jz_agent .agencyBtn {
  651. color: #09bb07;
  652. background: #11c200 !important;
  653. padding: 0 10upx;
  654. }
  655. .jz_agent .agent-product {
  656. margin-top: 235upx !important;
  657. }
  658. /* ------改动的 */
  659. .jz_agent .agencyTitle.titleSingle {
  660. margin: 0 auto;
  661. width: 210upx;
  662. font-size: 26upx;
  663. overflow: hidden;
  664. text-overflow: ellipsis;
  665. white-space: nowrap;
  666. text-align: center;
  667. }
  668. .jz_agent .topItem-wrap {
  669. width: 224upx;
  670. height: 224upx;
  671. position: relative;
  672. }
  673. .jz_agent .agencyTitle {
  674. width: 224upx;
  675. overflow: hidden;
  676. white-space: nowrap;
  677. }
  678. .jz_agent .search-input .icon-del.icon {
  679. width: 50upx;
  680. top: 0;
  681. }
  682. .jz_myfit .loadbox {
  683. border-top-left-radius: 20upx;
  684. border-top-right-radius: 20upx;
  685. }
  686. .tab-search {
  687. position: fixed;
  688. width: 100%;
  689. z-index: 8888;
  690. }
  691. .jz_myfit.jz_lists scroll-view.uni-swiper-tab {
  692. margin-bottom: 0;
  693. }
  694. .jz_agent .agent-product {
  695. margin-top: 320upx;
  696. }
  697. .fixed {
  698. width: 100%;
  699. position: fixed;
  700. left: 0;
  701. top: 0;
  702. /* #ifdef H5 */
  703. /* top: 84upx; */
  704. top: 44px;
  705. /* #endif */
  706. background: #ffffff;
  707. margin: 0 !import;
  708. z-index: 999;
  709. box-sizing: border-box;
  710. border-bottom: 2upx solid #eeeeee;
  711. transform: translateZ(0);
  712. -webkit-transform: translateZ(0);
  713. }
  714. .activeLine {
  715. border-bottom: 2upx solid #ff273c;
  716. }
  717. .jz_lists {
  718. position: relative;
  719. }
  720. .jz_lists scroll-view.uni-swiper-tab {
  721. border-bottom: 0;
  722. height: auto;
  723. line-height: auto;
  724. padding-top: 20upx;
  725. }
  726. .jz_lists .productTitle-item {
  727. justify-content: center;
  728. align-items: center;
  729. }
  730. .jz_lists .productTitle-item .picname {
  731. line-height: 60upx;
  732. }
  733. .jz_lists .productTitle-item image {
  734. width: 50upx;
  735. height: 50upx;
  736. }
  737. .lists .sortNav .Nav:first-child {
  738. /* border-left: none; */
  739. }
  740. .list .tab-bar-wrap {
  741. width: 200upx;
  742. }
  743. ::-webkit-scrollbar {
  744. display: none;
  745. }
  746. .lists .nav-left {
  747. width: 218upx;
  748. border-right: solid 1upx #e0e0e0;
  749. padding-top: 20upx;
  750. box-sizing: border-box;
  751. }
  752. .lists .nav-left .nav-left-title {
  753. height: 80upx;
  754. font-weight: 600;
  755. margin: 0 auto;
  756. margin-left: 10upx;
  757. }
  758. .lists .nav-left-item {
  759. height: 110upx;
  760. font-size: 30upx;
  761. display: flex;
  762. align-items: center;
  763. justify-content: center;
  764. }
  765. .lists .nav-left-item image {
  766. width: 40upx;
  767. height: 40upx;
  768. margin-right: 18upx;
  769. }
  770. .lists .nav-right {
  771. width: 100%;
  772. box-sizing: border-box;
  773. }
  774. .uni-tab-bar-loading {
  775. width: 100%;
  776. }
  777. .uni-tab-bar-loading .loading-text {
  778. margin-top: 50upx;
  779. font-size: 28upx;
  780. text-align: center;
  781. }
  782. .lists .list {
  783. width: 100%;
  784. height: 92%;
  785. }
  786. #tab-bar {
  787. background-color: #ffffff;
  788. padding-bottom: 60upx;
  789. overflow: hidden;
  790. }
  791. .uni-tab-bar .active {
  792. color: #ffe200;
  793. /* border-left: 10upx solid #ffe200; */
  794. }
  795. .prices .prices-cart image {
  796. width: 52upx;
  797. height: 50upx;
  798. margin-right: 10upx;
  799. }
  800. .prices .prices-salePrice {
  801. font-size: 22upx;
  802. color: #f00000;
  803. }
  804. .image {
  805. position: absolute;
  806. width: 100%;
  807. height: 100%;
  808. }
  809. .placeholder {
  810. background: #e2e2e2 url(../../../static/load.gif) center center no-repeat;
  811. opacity: 1;
  812. transition: opacity 0.4s linear;
  813. }
  814. .placeholder.loaded {
  815. opacity: 0;
  816. }
  817. .list-collapse {
  818. padding-left: 36upx;
  819. box-sizing: border-box;
  820. }
  821. .lists .sortNav .navActive {
  822. color: #d80000;
  823. }
  824. .uni-filter {
  825. margin-top: 8upx;
  826. background-color: #ffffff;
  827. padding: 16upx 24upx;
  828. font-size: 28upx;
  829. justify-content: space-between;
  830. position: relative;
  831. }
  832. .uni-filter .uni-filter-item {
  833. background-color: #f1f1f1;
  834. padding: 8upx 0;
  835. border-radius: 4upx;
  836. width: 24%;
  837. height: 32upx;
  838. justify-content: center;
  839. align-items: center;
  840. position: relative;
  841. }
  842. .uni-filter .uni-filter-sel {
  843. background-color: #c50200;
  844. color: #ffffff;
  845. }
  846. /* .uni-filter .uni-filter-line {
  847. position: absolute;
  848. height: 4upx;
  849. background: #f1f1f1;
  850. top: 50%;
  851. left: 0;
  852. margin-top: -2upx;
  853. width: 100%;
  854. } */
  855. .jz_agent .search {
  856. margin-top: 8upx;
  857. }
  858. </style>