deal.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866
  1. <template>
  2. <view class="">
  3. <view class="sort">
  4. <view class="sortItem" :style="{color:current==1?'#A5CF49':'#333333'}" @click="sort(1)">
  5. <text>{{sortCurrent==null?'时间排序':sortList[sortCurrent].name}}</text>
  6. <u-icon name="arrow-down-fill" :color="{color:current==1?'#A5CF49':'#333333'}"
  7. :class="{'select':current==1}" size="8"></u-icon>
  8. </view>
  9. <view class="sortItem" @click="sort(2)" :style="{color:current==2?'#A5CF49':'#333333'}">
  10. <view class="">
  11. <text>账号筛选</text>
  12. <view class="tips">
  13. {{mark_notice}}
  14. </view>
  15. <u-badge showZero absolute='true' :offset='[10,30]' bgColor='red' type="warning " max="99" :value="total_num"></u-badge>
  16. </view>
  17. <u-icon name="arrow-down-fill" :color="{color:current==2?'#A5CF49':'#333333'}"
  18. :class="{'select':current==2}" size="8"></u-icon>
  19. <zpTooltip content="点击快速筛选" :visible="visible" placement="bottom"></zpTooltip>
  20. </view>
  21. </view>
  22. <view class="notice">
  23. <u-notice-bar :text="text1" color="#fff" bgColor="#A5CF49" fontSize='16'></u-notice-bar>
  24. </view>
  25. <view class="" v-if="swiperList.length!=0">
  26. <u-swiper
  27. :list="swiperList"
  28. @change="change"
  29. keyName="image"
  30. @click="click"
  31. ></u-swiper>
  32. </view>
  33. <view class="accountList">
  34. <view class="accountItem" v-for="(item,index) in goodsList" :key="index" @click="toInfo(item)">
  35. <view class="imgBox">
  36. <image :src="BASE_URL+item.coverimage" mode=""></image>
  37. <view class="bar" :class="{'bule':item.bar_type==0}">
  38. {{item.color_bar}}
  39. </view>
  40. </view>
  41. <view class="introduction">
  42. <view class="title">
  43. {{item.show_title}}
  44. </view>
  45. <view class="labelBox">
  46. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.top_bg.value+')'}" v-if="item.is_top==1">
  47. 置顶
  48. </view>
  49. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.discount_bg.value+')'}" v-if="item.discount==1">
  50. 特价
  51. </view>
  52. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.recommend_bg.value+')'}" v-if="item.recommend==1">
  53. 斑马推荐
  54. </view>
  55. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.stage_bg.value+')'}" v-if="item.stage==1">
  56. 可分期
  57. </view>
  58. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.recommend_bg.value+')'}" v-if="item.is_hot==1">
  59. 热门
  60. </view>
  61. <!-- <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.level_bg.value+')'}" v-if="item.level>=1">
  62. VIP
  63. </view> -->
  64. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.new_bg.value+')'}" v-if="item.is_new==1">
  65. 新品
  66. </view>
  67. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby1_bg.value+')'}" v-if="item.standby1==1">
  68. {{item.standby1_title}}
  69. </view>
  70. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby2_bg.value+')'}" v-if="item.standby2==1">
  71. {{item.standby2_title}}
  72. </view>
  73. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby3_bg.value+')'}" v-if="item.standby3==1">
  74. {{item.standby3_title}}
  75. </view>
  76. <!-- <u-tag v-if="item.discount==1" text="特价" type="error" shape="circle" size="mini"></u-tag>
  77. <u-tag v-if="item.recommend==1" text="斑马推荐" shape="circle" size="mini"></u-tag>
  78. <u-tag v-if="item.stage==1" text="可分期" type="success" shape="circle" size="mini"></u-tag> -->
  79. </view>
  80. <view class="price">
  81. <text>{{item.money}}</text>米
  82. </view>
  83. </view>
  84. </view>
  85. <u-empty
  86. v-if="goodsList.length==0"
  87. mode="list"
  88. icon="http://cdn.uviewui.com/uview/empty/list.png"
  89. >
  90. </u-empty>
  91. </view>
  92. </view>
  93. <u-popup :show="show" mode="top" @close="close">
  94. <view class="popup">
  95. <view class="item" :class="{'selectSort':sortCurrent==index}" v-for="(item,index) in sortList" :key="index" @click="sortClick(item,index)">
  96. {{item.name}}
  97. </view>
  98. </view>
  99. </u-popup>
  100. <u-popup :show="show1" mode="top" @close="close1">
  101. <scroll-view scroll-y="true" >
  102. <view class="popup popup1">
  103. <view class="labelItem">
  104. <view class="label">
  105. 编号
  106. </view>
  107. <view class="value">
  108. <input type="text" v-model="condition.search_name" class="codeInput" placeholder="请输入需要搜索的账号编号">
  109. </view>
  110. </view>
  111. <view class="" style="height: 800rpx;overflow: scroll;">
  112. <view class="labelItem">
  113. <view class="label">
  114. 标签选择
  115. </view>
  116. <view class="value">
  117. <u-checkbox-group v-model="checkboxValue1" placement="row" @change="checkboxChange">
  118. <u-checkbox :customStyle="{marginBottom: '8px'}" v-for="(item, index) in labelList"
  119. :key="index" :label="item.title" :name="item.id">
  120. </u-checkbox>
  121. </u-checkbox-group>
  122. </view>
  123. </view>
  124. <view class="labelItem">
  125. <view class="label">
  126. 价格区间
  127. </view>
  128. <view class="value1">
  129. <input type="number" v-model="condition.min_money" class="codeInput" placeholder="最低价格">
  130. <text>至</text>
  131. <input type="number" v-model="condition.max_money" class="codeInput" placeholder="最高价格">
  132. </view>
  133. </view>
  134. <view class="labelItem">
  135. <view class="label">
  136. 区服范围
  137. </view>
  138. <view class="value1">
  139. <input type="number" v-model="condition.min_server" class="codeInput" placeholder="XXX区">
  140. <text>至</text>
  141. <input type="number" v-model="condition.max_server" class="codeInput" placeholder="XXX区">
  142. </view>
  143. </view>
  144. <view class="labelItem">
  145. <view class="label">
  146. 金伙伴数量区间
  147. </view>
  148. <view class="value1">
  149. <input type="number" v-model="condition.min_partner" class="codeInput" placeholder="最少伙伴数量">
  150. <text>至</text>
  151. <input type="number" v-model="condition.max_partner" class="codeInput" placeholder="最多伙伴数量">
  152. </view>
  153. </view>
  154. <view class="labelItem">
  155. <view class="label">
  156. VIP等级区间
  157. </view>
  158. <view class="value1">
  159. <input type="number" v-model="condition.min_level" class="codeInput" placeholder="最低等级">
  160. <text>至</text>
  161. <input type="number" v-model="condition.max_level" class="codeInput" placeholder="最高等级">
  162. </view>
  163. </view>
  164. <view class="labelItem">
  165. <view class="label">
  166. 战力范围(单位:亿)
  167. </view>
  168. <view class="value1">
  169. <input type="number" v-model="condition.min_force" class="codeInput" placeholder="最低战力">
  170. <text>至</text>
  171. <input type="number" v-model="condition.max_force" class="codeInput" placeholder="最高战力">
  172. </view>
  173. </view>
  174. <view class="labelItem">
  175. <view class="label">
  176. 速度范围(单位:万)
  177. </view>
  178. <view class="value1">
  179. <input type="number" v-model="condition.min_speed" class="codeInput" placeholder="最低速度">
  180. <text>至</text>
  181. <input type="number" v-model="condition.max_speed" class="codeInput" placeholder="最高速度">
  182. </view>
  183. </view>
  184. <view class="labelItem">
  185. <view class="label">
  186. 法伤范围(单位:万)
  187. </view>
  188. <view class="value1">
  189. <input type="number" v-model="condition.min_atk" class="codeInput" placeholder="最低法伤">
  190. <text>至</text>
  191. <input type="number" v-model="condition.max_atk" class="codeInput" placeholder="最高法伤">
  192. </view>
  193. </view>
  194. <view class="labelItem">
  195. <view class="label">
  196. 冰冻范围(单位:万)
  197. </view>
  198. <view class="value1">
  199. <input type="number" v-model="condition.min_property" class="codeInput" placeholder="最低冰冻">
  200. <text>至</text>
  201. <input type="number" v-model="condition.max_property" class="codeInput" placeholder="最高冰冻">
  202. </view>
  203. </view>
  204. <view class="labelItem">
  205. <view class="label">
  206. 账号类型
  207. </view>
  208. <view class="value">
  209. <u-radio-group v-model="radiovalue1" placement="row" @change="groupChange">
  210. <u-radio :customStyle="{marginBottom: '8px'}" v-for="(item, index) in checkboxList1"
  211. :key="index" :label="item.name" :name="item.type" >
  212. </u-radio>
  213. </u-radio-group>
  214. </view>
  215. </view>
  216. <view class="labelItem">
  217. <view class="label">
  218. 是否榜一
  219. </view>
  220. <view class="value">
  221. <u-radio-group v-model="radiovalue2" placement="row" @change="groupChange1">
  222. <u-radio :customStyle="{marginBottom: '8px'}" v-for="(item, index) in checkboxList2"
  223. :key="index" :label="item.name" :name="item.type" >
  224. </u-radio>
  225. </u-radio-group>
  226. </view>
  227. </view>
  228. </view>
  229. <view class="btnBox">
  230. <button class="btn1" @click="reset">重置</button>
  231. <button class="btn2" @click="getList">确定</button>
  232. </view>
  233. </view>
  234. </scroll-view>
  235. </u-popup>
  236. <u-overlay :show="show10" @click="show10 = false">
  237. <view class="warp">
  238. <view class="rect1" @tap.stop>
  239. <image src="../../static/tishi.png" mode=""></image>
  240. <p>该商品已出售或下架</p>
  241. <u-button color="#A5CF49" type="success" shape="circle" text="看看其他斑马账号" @click="show10 = false"></u-button>
  242. </view>
  243. </view>
  244. </u-overlay>
  245. <view class="ICP"><a href="http://beian.miit.gov.cn/">ICP备案号:苏ICP备2023025782号-1</a></view>
  246. </template>
  247. <script setup>
  248. import {
  249. onLoad,
  250. onShow,
  251. onPullDownRefresh,onReachBottom
  252. } from "@dcloudio/uni-app";
  253. import zpTooltip from '../../uni_modules/zb-tooltip/components/zb-tooltip/zb-tooltip.vue'
  254. import {BASE_URL} from '../../utils/http.js'
  255. import {
  256. ref
  257. } from "vue"
  258. import {getbannerlist,getnoticelist,getSelLabel,getGoodsList,getplatformmeun,getplatformeditor} from '@/utils/api.js'
  259. let mark_notice=ref('')
  260. onLoad(() => {
  261. getplatformeditor().then(res => {
  262. mark_notice.value = res.data.mark_notice
  263. })
  264. // uni.hideTabBar()
  265. // getplatformmeun().then(res=>{
  266. // text1.value=res.data.acc_notice
  267. // let menu=res.data
  268. // getApp().globalData.config=menu
  269. // uni.setTabBarItem({
  270. // index: 0,
  271. // text: menu.simple_menu,
  272. // iconPath: BASE_URL+menu.simple_logo,
  273. // selectedIconPath: BASE_URL+menu.simple_logo2
  274. // })
  275. // uni.setTabBarItem({
  276. // index: 1,
  277. // text: menu.acc_menu,
  278. // iconPath: BASE_URL+menu.acc_logo,
  279. // selectedIconPath: BASE_URL+menu.acc_logo2
  280. // })
  281. // uni.setTabBarItem({
  282. // index: 2,
  283. // text: menu.jump_menu,
  284. // iconPath: BASE_URL+menu.jump_logo,
  285. // selectedIconPath: BASE_URL+menu.jump_logo2
  286. // })
  287. // uni.setTabBarItem({
  288. // index: 3,
  289. // text: menu.information_menu,
  290. // iconPath: BASE_URL+menu.information_logo,
  291. // selectedIconPath: BASE_URL+menu.information_logo2
  292. // })
  293. // uni.showTabBar()
  294. // uni.setNavigationBarTitle({
  295. // title: res.data.name
  296. // });
  297. // })
  298. getBanner()
  299. getSelLabel().then(res=>{
  300. labelList.value=res.data
  301. })
  302. // getnoticelist(2).then(res=>{
  303. // let data=res.data
  304. // data.forEach(item=>{
  305. // text1.value=text1.value+' '+item.content
  306. // })
  307. // })
  308. getList()
  309. })
  310. let show10=ref(false)
  311. onReachBottom(()=>{
  312. condition.value.page++
  313. getList()
  314. })
  315. let groupChange=(e)=>{
  316. condition.value.account_type=e
  317. }
  318. let groupChange1=(e)=>{
  319. condition.value.is_top=e
  320. }
  321. let sortCurrent=ref(null)
  322. let sortClick=(item,index)=>{
  323. if(sortCurrent.value!=index){
  324. sortCurrent.value=index
  325. condition.value.sort_type=item.sort_type
  326. condition.value.sort_order=item.sort_order
  327. show.value=false
  328. current.value=0
  329. condition.value.page=1
  330. getList()
  331. }
  332. }
  333. let goodsList=ref([])
  334. let bg_list=ref({})
  335. let total_num=ref(0)
  336. let getList=()=>{
  337. show1.value=false
  338. current.value=0
  339. getGoodsList(condition.value).then(res=>{
  340. getNum()
  341. bg_list.value=res.data.bg_list
  342. if(condition.value.page==1){
  343. goodsList.value=res.data.list
  344. }else{
  345. goodsList.value=[...goodsList.value,...res.data.list]
  346. }
  347. })
  348. }
  349. let labelList=ref([])
  350. onShow(() => {
  351. // setTimeout(()=>{
  352. // visible.value=false
  353. // },3000)
  354. })
  355. let getNum=()=>{
  356. let count=0
  357. if(condition.value.search_name!=''){
  358. count+=1
  359. }
  360. if(condition.value.label_ids.split(',')!=0){
  361. count+=condition.value.label_ids.split(',').length
  362. }
  363. if(condition.value.min_money!=''||condition.value.max_money!=''){
  364. count+=1
  365. }
  366. if(condition.value.min_server!=''||condition.value.max_server!=''){
  367. count+=1
  368. }
  369. if(condition.value.min_partner!=''||condition.value.max_partner!=''){
  370. count+=1
  371. }
  372. if(condition.value.min_level!=''||condition.value.max_level!=''){
  373. count+=1
  374. }
  375. if(condition.value.min_force!=''||condition.value.max_force!=''){
  376. count+=1
  377. }
  378. if(condition.value.min_speed!=''||condition.value.max_speed!=''){
  379. count+=1
  380. }
  381. // console.log(123,condition.value.min_atk,condition.value.max_atk)
  382. if(condition.value.min_atk!=''||condition.value.max_atk!=''){
  383. count+=1
  384. }
  385. if(condition.value.min_property!=''||condition.value.max_property!=''){
  386. count+=1
  387. }
  388. if(condition.value.account_type!=0){
  389. count+=1
  390. }
  391. if(condition.value.is_top!=-1){
  392. count+=1
  393. }
  394. total_num.value=count
  395. }
  396. let reset=()=>{
  397. radiovalue1.value = ref(0)
  398. radiovalue2.value = ref(-1)
  399. checkboxValue1.value=[]
  400. condition.value={
  401. page:1,
  402. page_num:10,
  403. sort_type:'',
  404. sort_order:'',
  405. min_money:'',
  406. max_money:'',
  407. min_server:'',
  408. max_server:'',
  409. min_partner:'',
  410. max_partner:'',
  411. min_level:'',
  412. max_level:'',
  413. min_force:'',
  414. max_force:'',
  415. min_speed:'',
  416. max_speed:'',
  417. min_atk:'',
  418. max_atk:'',
  419. min_property:'',
  420. max_property:'',
  421. account_type:0,
  422. is_top:-1,
  423. label_ids:'',
  424. search_name:''
  425. }
  426. }
  427. let sortList=[
  428. {name:'最近发布',sort_type:1,sort_order:1},
  429. // {name:'发布时间从远到近',sort_type:1,sort_order:2},
  430. {name:'价格从高到低',sort_type:2,sort_order:1},
  431. {name:'价格从低到高',sort_type:2,sort_order:2},
  432. {name:'战力从高到低',sort_type:3,sort_order:1},
  433. {name:'战力从低到高',sort_type:3,sort_order:2},
  434. {name:'冰冻从高到低',sort_type:4,sort_order:1},
  435. {name:'冰冻从低到高',sort_type:4,sort_order:2},
  436. {name:'速度从高到低',sort_type:5,sort_order:1},
  437. {name:'速度从低到高',sort_type:5,sort_order:2},
  438. {name:'法伤从高到低',sort_type:6,sort_order:1},
  439. {name:'法伤从低到高',sort_type:6,sort_order:2},
  440. {name:'vip等级排序',sort_type:7,sort_order:1},
  441. // {name:'vip等级从低到高',sort_type:7,sort_order:2},
  442. ]
  443. let condition=ref({
  444. page:1,
  445. page_num:10,
  446. sort_type:'',
  447. sort_order:'',
  448. min_money:'',
  449. max_money:'',
  450. min_server:'',
  451. max_server:'',
  452. min_partner:'',
  453. max_partner:'',
  454. min_level:'',
  455. max_level:'',
  456. min_force:'',
  457. max_force:'',
  458. min_speed:'',
  459. max_speed:'',
  460. min_atk:'',
  461. max_atk:'',
  462. min_property:'',
  463. max_property:'',
  464. account_type:0,
  465. is_top:-1,
  466. label_ids:'',
  467. search_name:''
  468. })
  469. let getBanner=()=>{
  470. getbannerlist().then(res=>{
  471. res.data.forEach(item=>{
  472. item.image=BASE_URL+item.image
  473. })
  474. swiperList.value=res.data
  475. })
  476. }
  477. let toInfo=(item)=>{
  478. if(item.status==0){
  479. show10.value=true
  480. return
  481. }
  482. uni.navigateTo({
  483. url:`/pages/deal/productInfo?id=${item.id}`+(item.rand_num?`&rand_num=${item.rand_num}`:'')
  484. // url:'/pages/deal/productInfo?id='+6
  485. })
  486. }
  487. let visible=ref(true)
  488. let swiperList=ref([])
  489. let radiovalue1 = ref(0)
  490. let radiovalue2 = ref(-1)
  491. let checkboxValue1 = ref([])
  492. let checkboxChange = (n) => {
  493. condition.value.label_ids=n.toString()
  494. }
  495. let text1=ref('')
  496. // 基本案列数据
  497. let checkboxList1 = [{
  498. name: '全部',
  499. type: 0
  500. },
  501. {
  502. name: '手机',
  503. type: 1
  504. },
  505. {
  506. name: '邮箱',
  507. type: 2
  508. },
  509. {
  510. name: '微信/qq',
  511. type: 3
  512. }
  513. ]
  514. let checkboxList2 = [{
  515. name: '全部',
  516. type: -1
  517. },
  518. {
  519. name: '否',
  520. type: 0
  521. },
  522. {
  523. name: '是',
  524. type: 1
  525. }
  526. ]
  527. let show = ref(false)
  528. let show1 = ref(false)
  529. let current = ref(0)
  530. let sort = (type) => {
  531. if (current.value != type) {
  532. current.value = type
  533. if (type == 1) {
  534. show.value = true
  535. show1.value = false
  536. } else {
  537. show1.value = true
  538. show.value = false
  539. }
  540. } else {
  541. current.value = 0
  542. show.value = false
  543. show1.value = false
  544. }
  545. }
  546. let close = () => {
  547. show.value = false
  548. current.value = 0
  549. }
  550. let close1 = () => {
  551. show1.value = false
  552. current.value = 0
  553. }
  554. onPullDownRefresh(() => {
  555. reset()
  556. getList()
  557. setTimeout(function() {
  558. uni.stopPullDownRefresh();
  559. }, 2000);
  560. })
  561. </script>
  562. <style>
  563. uni-button:after{
  564. border:none;
  565. }
  566. </style>
  567. <style lang="scss">
  568. .notice{
  569. height: 37px;
  570. overflow: hidden;
  571. }
  572. .warp {
  573. padding: 0 28rpx;
  574. display: flex;
  575. align-items: center;
  576. justify-content: center;
  577. height: 100%;
  578. }
  579. .rect1 {
  580. padding: 60rpx 120rpx;
  581. display: flex;
  582. flex-direction: column;
  583. align-items: center;
  584. width: 558rpx;
  585. height: 438rpx;
  586. background: #FFFFFF;
  587. border-radius: 20rpx;
  588. image {
  589. width: 96rpx;
  590. height: 96rpx;
  591. }
  592. p {
  593. font-size: 24rpx;
  594. margin: 62rpx 0 40rpx;
  595. }
  596. // background-color: #fff;
  597. }
  598. .labelBox{
  599. margin: 10rpx 0;
  600. display: flex;
  601. flex-wrap: wrap;
  602. .labelItem{
  603. margin-right: 20rpx;
  604. margin-bottom: 5rpx;
  605. font-size: 24rpx;
  606. font-weight: bold;
  607. color: #fff;
  608. border-radius: 30rpx;
  609. padding: 7rpx 16rpx;
  610. background-position: center center;
  611. background-repeat: no-repeat;
  612. background-size: cover;
  613. // background-color: #A5CF49;
  614. }
  615. }
  616. .selectSort{
  617. color: rgb(165, 207, 73);
  618. }
  619. .accountList{
  620. background-color: #FFFFFF;
  621. .accountItem{
  622. border-bottom: 20rpx solid #F5F5F5;
  623. display: flex;
  624. padding: 8rpx 24rpx;
  625. align-items: center;
  626. .imgBox{
  627. overflow: hidden;
  628. position: relative;
  629. margin-right: 26rpx;
  630. image{
  631. width: 188rpx;
  632. max-height: 188rpx;
  633. border-radius: 10rpx;
  634. }
  635. .bar{
  636. display: flex;
  637. justify-content: center;
  638. font-weight: bold;
  639. overflow: hidden;
  640. font-size: 28rpx;
  641. color: #fff;
  642. padding: 5rpx;
  643. // text-align: center;
  644. position: absolute;
  645. top: 50%;
  646. transform: translateY(-50%);
  647. width: 188rpx;
  648. background: red;
  649. }
  650. .bule{
  651. background: blue;
  652. }
  653. }
  654. .introduction{
  655. flex: 1;
  656. .title{
  657. color: #000000;
  658. font-weight: bold;
  659. font-size: 28rpx;
  660. }
  661. .u-fade-enter-active{
  662. margin-top: 0;
  663. padding: 10rpx;
  664. }
  665. .price{
  666. color: #FF2828;
  667. font-size: 24rpx;
  668. text{
  669. font-size: 40rpx;
  670. font-weight: bold;
  671. }
  672. }
  673. }
  674. }
  675. }
  676. .btnBox {
  677. margin-top: 100rpx;
  678. display: flex;
  679. justify-content: right;
  680. button {
  681. margin: 0;
  682. margin-left: 40rpx;
  683. padding: 0;
  684. width: 206rpx;
  685. height: 80rpx;
  686. line-height: 80rpx;
  687. background: #F5F5F5;
  688. border-radius: 40rpx;
  689. font-size: 24rpx;
  690. }
  691. .btn1 {
  692. background: #F5F5F5;
  693. }
  694. .btn2 {
  695. background: #A5CF49;
  696. color: #fff;
  697. }
  698. }
  699. .labelItem {
  700. .label {
  701. font-size: 24rpx;
  702. font-weight: bold;
  703. margin: 24rpx 0 10rpx;
  704. }
  705. .value {
  706. .codeInput {
  707. font-size: 24rpx;
  708. width: 562rpx;
  709. height: 68rpx;
  710. line-height: 68rpx;
  711. background: #F5F5F5;
  712. border-radius: 20rpx;
  713. padding: 0 24rpx;
  714. }
  715. }
  716. .value1 {
  717. display: flex;
  718. align-items: center;
  719. justify-content: space-between;
  720. input {
  721. font-size: 24rpx;
  722. text-align: center;
  723. width: 231rpx;
  724. height: 68rpx;
  725. line-height: 68rpx;
  726. background: #F5F5F5;
  727. border-radius: 20rpx;
  728. padding: 0 24rpx;
  729. }
  730. }
  731. }
  732. .popup {
  733. padding: 0 40rpx;
  734. font-size: 24rpx;
  735. .item {
  736. line-height: 90rpx;
  737. border-bottom: 1rpx solid #F5F5F5;
  738. }
  739. }
  740. .popup1 {
  741. padding: 0 40rpx 40rpx;
  742. }
  743. ::v-deep .u-checkbox {
  744. span {
  745. font-size: 24rpx !important;
  746. }
  747. margin-right: 20rpx;
  748. }
  749. ::v-deep .u-radio {
  750. span {
  751. font-size: 24rpx !important;
  752. }
  753. margin-right: 20rpx;
  754. }
  755. ::v-deep .u-fade-enter-active {
  756. margin-top: 89px;
  757. }
  758. ::v-deep .u-slide-down-enter-to {
  759. top: 49px !important;
  760. }
  761. .select {
  762. transform: rotate(180deg);
  763. }
  764. page {
  765. .sort {
  766. border-top: 1rpx solid #F2F2F2;
  767. width: 750rpx;
  768. height: 120rpx;
  769. line-height: 120rpx;
  770. background: #FFFFFF;
  771. box-shadow: 0rpx 4rpx 8rpx 0rpx rgba(0, 0, 0, 0.1);
  772. display: flex;
  773. position: sticky;
  774. top: 0;
  775. z-index: 99999;
  776. .sortItem {
  777. position: relative;
  778. flex: 1;
  779. display: flex;
  780. justify-content: center;
  781. align-items: center;
  782. text {
  783. margin-right: 16rpx;
  784. }
  785. .tips{
  786. width: 100%;
  787. text-align: center;
  788. position: absolute;
  789. bottom: -40rpx;
  790. left: 0;
  791. // transform: translateX(-50%);
  792. font-size: 8rpx;
  793. white-space: nowrap;
  794. color: #000;
  795. font-weight: bold;
  796. // transform: scale(0.8);
  797. }
  798. }
  799. }
  800. }
  801. .ICP{
  802. height: 40rpx;
  803. font-size: 20rpx;
  804. width: 100%;
  805. text-align: center;
  806. line-height: 30rpx;
  807. a{
  808. color: #999999;
  809. text-decoration: none;
  810. }
  811. }
  812. </style>