newkeycode.vue 46 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239
  1. <template>
  2. <div class="search-wrapper">
  3. <!-- 头部搜索 -->
  4. <div class="main-search-header">
  5. <input type="text" id="search-box" v-model="keyword" @keyup.13="onClickSearchHander()" :placeholder="placeholder" @input="changeKeyWord()">
  6. <span @click="onClickSearchHander()">搜索</span>
  7. <a @click="cancelSearchHander()">取消</a>
  8. <div class="main-search-header-controll clearfix">
  9. <div style="display: flex;align-items: center;justify-content: space-between;width:100%;">
  10. <div :class="ChooseTop === 'component' ? 'active' : ''" @click="setChangelistHander('component')"><a>型号</a></div>
  11. <div :class="ChooseTop === 'kind' ? 'active' : ''" @click="setChangelistHander('kind')"><a>物料名称</a></div>
  12. <div :class="ChooseTop === 'store' ? 'active' : ''" @click="setChangelistHander('store')"><a>卖家</a></div>
  13. <div :class="ChooseTop === 'brand' ? 'active' : ''" @click="setChangelistHander('brand')"><a>品牌</a></div>
  14. </div>
  15. </div>
  16. </div>
  17. <ul class="associate-list" v-show="associate.show" @click="associate.show = false">
  18. <li @click.stop="onAssociateClick(similar)" v-for="similar in similarKeywords.result">
  19. <i class="icon-sousuo iconfont"></i>
  20. <span>{{Getsimilar(similar)}}</span>
  21. <!--<span v-if="ChooseTop === 'component'">{{similar.code}}</span>-->
  22. <!--<span v-else-if="ChooseTop === 'product'">{{similar}}</span>-->
  23. <!--<span v-else-if="ChooseTop === 'store'">{{similar}}</span>-->
  24. <!--<span v-else-if="ChooseTop === 'brand'">{{similar.nameEn}}</span>-->
  25. </li>
  26. <li @click.stop="onClickTosearch(keyword)">查找“{{baseUtils.filterStringEllipsis(keyword, 30)}}”</li>
  27. </ul>
  28. <!-- 主体内容 -->
  29. <div class="main-search-wrapper">
  30. <div class="search-title">搜索“<span>{{displayKeyword}}</span>”暂无此{{getNowChooseType}}{{allTotal === 0 ? '' : `,为您找到${allTotal}条相关信息`}}</div>
  31. <template v-if="allTotal > 0">
  32. <!-- 品牌精确查找 -->
  33. <template v-if="ChooseTop === 'brand' && brandIsAccurate">
  34. <div class="search-content" style="margin-bottom: 0.2rem;height: auto">
  35. <div class="middle">
  36. <div class="list clearfix" style="border-bottom: 1px solid #dcdcdc;padding-bottom: 0.1rem;line-height: 0.8rem;">
  37. <img :src="'' || '/images/component/default.png'" class="pull-left">
  38. <div class="name pull-left overHidden" style="max-width: 5rem;">{{resourceList.brand && resourceList.brand.nameEn}}</div>
  39. </div>
  40. <div class="list">
  41. <div class="name">主打产品:</div>
  42. <div class="text">
  43. {{resourceList.brand && resourceList.brand.series}}
  44. </div>
  45. </div>
  46. <div class="list">
  47. <div class="name">应用领域:</div>
  48. <div class="text">
  49. {{resourceList.brand && resourceList.brand.application}}
  50. </div>
  51. </div>
  52. <div class="list">
  53. <div class="name">品牌介绍:</div>
  54. <div class="text">
  55. {{resourceList.brand && resourceList.brand.brief}}
  56. </div>
  57. </div>
  58. <div class="list">
  59. <div class="name" style="color:#4290f7">官网地址:</div>
  60. <div class="text" style="width: 4.5rem">
  61. <a :href="resourceList.brand && resourceList.brand.url" target="_blank">{{resourceList.brand && resourceList.brand.url}}</a>
  62. </div>
  63. <div class="pull-right lookMoreBtn" @click="showBrandDetails = true" style="color:#4290f7">
  64. 查看更多
  65. </div>
  66. </div>
  67. </div>
  68. </div>
  69. </template>
  70. <div class="search-nav clearfix" v-if="brandIsAccurate || (!brandIsAccurate && ChooseTop !== 'brand')">
  71. <span class="pull-left" :class="navType === 'hasStore' ? 'active' : ''" @click="getReloadList('hasStore')">
  72. {{ChooseTop === 'component' ? '现货': '现货卖家'}}({{stockallTotal}})条
  73. </span>
  74. <span class="pull-left" :class="navType === 'noHasStore' ? 'active' : ''" @click="getReloadList('noHasStore')">
  75. {{ChooseTop === 'component' ? '期货': '期货卖家'}}({{futuresallTotal}})条</span>
  76. </div>
  77. <div class="search-content" id="main-search-wrapper" :class="{'searchContent2' : ChooseTop === 'brand' && brandIsAccurate, 'searchContent3': ChooseTop === 'brand' && !brandIsAccurate}">
  78. <!-- 品牌模糊查询 -->
  79. <template v-if="!brandIsAccurate && ChooseTop === 'brand'">
  80. <div class="middle" v-for="item in resourceList.content">
  81. <div class="list clearfix" style="border-bottom: 1px solid #dcdcdc;padding-bottom: 0.1rem;line-height: 0.8rem;" @click="goToBrandAccurate(item)">
  82. <img :src="item.logoUrl || '/images/component/default.png'" class="pull-left">
  83. <div class="name pull-left overHidden" style="max-width: 5rem;">{{item.nameEn}}</div>
  84. <div class="more_icon pull-right"><i class="iconfont icon-swiper-right"></i></div>
  85. </div>
  86. <div class="list">
  87. <div class="name">主打产品:</div>
  88. <div class="text">
  89. {{item.series}}
  90. </div>
  91. </div>
  92. <div class="list">
  93. <div class="name">应用领域:</div>
  94. <div class="text">
  95. {{item.application}}
  96. </div>
  97. </div>
  98. <div class="list">
  99. <div class="name">品牌介绍:</div>
  100. <div class="text">
  101. {{item.brief}}
  102. </div>
  103. </div>
  104. <div class="list">
  105. <div class="name">官网地址:</div>
  106. <div class="text">
  107. <a :href="item.url" target="_blank">{{item.url}}</a>
  108. </div>
  109. </div>
  110. </div>
  111. </template>
  112. <!-- /end 品牌模糊查询 -->
  113. <template v-if="brandIsAccurate || (!brandIsAccurate && ChooseTop !== 'brand')">
  114. <!-- 现货 -->
  115. <template v-if="navType === 'hasStore'">
  116. <!-- 型号结果 -->
  117. <template v-if="ChooseTop === 'component'">
  118. <div v-if="resourceList&&resourceList.stock&&resourceList.stock.content.length > 0">
  119. <div v-for="(item, index) in resourceList.stock.content">
  120. <!--@click="goProductDetail(item)"-->
  121. <div class="middle">
  122. <div class="list">
  123. <div class="name">品牌:</div>
  124. <div class="text overHidden">{{item.brand && item.brand.nameEn || '-'}}</div>
  125. </div>
  126. <div class="list">
  127. <div class="name">物料名称(类目):</div>
  128. <div class="text overHidden">{{item.kindNameCn || '-'}}</div>
  129. </div>
  130. <div class="list">
  131. <div class="name">型号:</div>
  132. <div class="text overHidden">{{item.code || '-'}}</div>
  133. </div>
  134. <div class="list">
  135. <div class="name">规格:</div>
  136. <div class="text overHidden">{{item.spec || '-'}}</div>
  137. </div>
  138. <div class="list">
  139. <div class="fl">
  140. <div class="name">包装:</div>
  141. <div class="text overHidden" style="width: 2.3rem">{{item.packaging || '无包装信息'}}</div>
  142. </div>
  143. <div class="fl">
  144. <div class="name">交期(天):</div>
  145. <div class="text overHidden" style="width: 1.8rem" v-if="item.b2cMaxDelivery && (item.b2cMaxDelivery != item.b2cMinDelivery)" v-text="item.b2cMinDelivery + '-'+ item.b2cMaxDelivery"></div>
  146. <div class="text overHidden" style="width: 1.8rem" v-if="item.b2cMaxDelivery && (item.b2cMaxDelivery == item.b2cMinDelivery)" v-text="item.b2cMinDelivery"></div>
  147. </div>
  148. </div>
  149. <div class="list">
  150. <div class="fl">
  151. <div class="name">生产日期:</div>
  152. <div class="text overHidden" style="width: 1.75rem" :title="item.produceDate">{{item.produceDate || '-'}}</div>
  153. </div>
  154. <div class="fl">
  155. <div class="name">库存:</div>
  156. <div class="text overHidden" style="width: 2.3rem">{{item.reserve || '-'}}</div>
  157. </div>
  158. </div>
  159. <div class="list">
  160. <div class="fl" @click.stop="goAttach(item.attach)">
  161. <div class="name">规格书:</div>
  162. <div class="text">
  163. <i class="iconfont icon-pdf" :class="{'active': item.attach && item.attach !== '' && item.attach !== '1'}"></i>
  164. </div>
  165. </div>
  166. <div class="fl">
  167. <div class="name">起拍:</div>
  168. <div class="text overHidden" style="width: 2.3rem">{{item.minBuyQty || '-'}}</div>
  169. </div>
  170. </div>
  171. <div class="list">
  172. <div class="name">卖家名称:</div>
  173. <div class="text overHidden">{{item.storeName}}</div>
  174. </div>
  175. <div class="list">
  176. <div class="name left">价格梯度<p>(pcs):</p></div>
  177. <div class="table left">
  178. <ul>
  179. <li class="title">
  180. <div>分段数量/PCS</div>
  181. <div>分段单价</div>
  182. </li>
  183. <li v-for="price in item.prices">
  184. <div>{{price.start}}+</div>
  185. <div v-if="item.currencyName == 'RMB'">¥{{price.rMBPrice}}</div>
  186. <div v-else>${{price.uSDPrice}}</div>
  187. </li>
  188. </ul>
  189. </div>
  190. </div>
  191. <div class="list clearfix">
  192. <div class="pull-left cancat" @click.stop="cancatSeller(item)">
  193. <i class="iconfont icon-kefu1"></i>联系卖家
  194. </div>
  195. <div class="pull-right clearfix">
  196. <div class="pull-left" @click="buy(item, false, $event)">加入购物车</div>
  197. <div class="pull-left" @click="buy(item, true, $event)">立即购买</div>
  198. </div>
  199. </div>
  200. </div>
  201. </div>
  202. </div>
  203. </template>
  204. <!-- 卖家 物料名称 品牌-->
  205. <template v-else-if="ChooseTop === 'kind' || ChooseTop === 'store' || ChooseTop === 'brand'">
  206. <div v-if="resourceList&&resourceList.stock&&resourceList.stock.content.length > 0">
  207. <div class="middle" v-for="(item, index) in resourceList.stock.content">
  208. <nuxt-link :to="`/mobile/shop/${item.storeUuid}`" tag="div" class="list clearfix" style="border-bottom: 1px solid #dcdcdc;padding-bottom: 0.1rem">
  209. <div class="name pull-left">{{item.enName}}</div>
  210. <div class="more_icon pull-right"><i class="iconfont icon-swiper-right"></i></div>
  211. </nuxt-link>
  212. <div class="middle_bottom clearfix">
  213. <div class="middle_bottom-left">
  214. <img :src="item.storeLogoUrl || '/images/component/default.png'">
  215. </div>
  216. <div class="middle_bottom-left">
  217. <div class="middle_bottom-leftitem clearfix">
  218. <div class="bottom-title">电话</div><label style="float: left">:</label>
  219. <div class="overHidden" style="width: 3.9rem">
  220. <a :href="'tel:' + AlertstoreInfo.enterprise.enTel" target="_blank" class="content-line" style="color: #2d8cf0">{{item.enTel}}</a>
  221. </div>
  222. </div>
  223. <div class="middle_bottom-leftitem clearfix">
  224. <div class="bottom-title">邮箱</div><label style="float: left">:</label><div class="overHidden" style="width: 3.9rem">{{item.enEmail}}</div>
  225. </div>
  226. <div class="middle_bottom-leftitem clearfix">
  227. <div class="bottom-title">执照号</div><label style="float: left">:</label><div class="overHidden" style="width: 3.9rem">{{item.enBusinesscode}}</div>
  228. </div>
  229. <div class="middle_bottom-leftitem clearfix">
  230. <div class="bottom-title">地址</div><label style="float: left">:</label><div style="width: 3.9rem;">{{item.enAddress}}</div>
  231. </div>
  232. </div>
  233. </div>
  234. </div>
  235. </div>
  236. </template>
  237. </template>
  238. <!-- 期货 -->
  239. <template v-else>
  240. <!-- 型号结果 -->
  241. <template v-if="ChooseTop === 'component'">
  242. <div v-if="resourceList && resourceList.futures && resourceList.futures.content.length > 0">
  243. <div class="middle" v-for="(item, index) in resourceList.futures.content">
  244. <div class="list">
  245. <div class="name">品牌:</div>
  246. <div class="text overHidden">{{item.brandNameEn || '—'}}</div>
  247. </div>
  248. <div class="list">
  249. <div class="name">物料名称(类目):</div>
  250. <div class="text overHidden">{{item.kindNameCn || '-'}}</div>
  251. </div>
  252. <div class="list">
  253. <div class="name">型号:</div>
  254. <div class="text overHidden">{{item.code || '-'}}</div>
  255. </div>
  256. <div class="list">
  257. <div class="name">规格:</div>
  258. <div class="text overHidden">{{item.spec || '-'}}</div>
  259. </div>
  260. <div class="list">
  261. <div class="name">单位:</div>
  262. <div class="text overHidden">{{item.unit || 'PCS'}}</div>
  263. </div>
  264. <div class="list clearfix" style="overflow: inherit;">
  265. <div class="fl">
  266. <div class="name">卖家:</div>
  267. <div class="text overHidden" style="width: 4rem">{{item.storeName || '卖家名称'}}</div>
  268. </div>
  269. <div class="pull-right sayPriBtn" @click="publish(item)">立即询价</div>
  270. </div>
  271. </div>
  272. </div>
  273. </template>
  274. <!-- 卖家 物料名称 品牌-->
  275. <template v-else-if="ChooseTop === 'kind' || ChooseTop === 'store' || ChooseTop === 'brand'">
  276. <div v-if="resourceList&&resourceList.futures &&resourceList.futures.content.length > 0">
  277. <div class="middle" v-for="(item, index) in resourceList.futures.content" @click="goSupplierDetail(item)">
  278. <div class="list clearfix" style="border-bottom: 1px solid #dcdcdc;padding-bottom: 0.1rem">
  279. <div class="name pull-left">{{item.enName}}</div>
  280. <div class="more_icon pull-right"><i class="iconfont icon-swiper-right"></i></div>
  281. </div>
  282. <div class="middle_bottom clearfix">
  283. <div class="middle_bottom-left">
  284. <img :src="item.storeLogoUrl || '/images/component/default.png'">
  285. </div>
  286. <div class="middle_bottom-left">
  287. <div class="middle_bottom-leftitem clearfix">
  288. <div class="bottom-title">电话</div><label style="float: left">:</label>
  289. <div class="overHidden" style="width: 3.9rem">
  290. <a :href="'tel:' + AlertstoreInfo.enterprise.enTel" target="_blank" class="content-line" style="color: #2d8cf0">{{item.enTel}}</a>
  291. </div>
  292. </div>
  293. <div class="middle_bottom-leftitem clearfix">
  294. <div class="bottom-title">邮箱</div><label style="float: left">:</label><div class="overHidden" style="width: 3.9rem">{{item.enEmail}}</div>
  295. </div>
  296. <div class="middle_bottom-leftitem clearfix">
  297. <div class="bottom-title">执照号</div><label style="float: left">:</label><div class="overHidden" style="width: 3.9rem">{{item.enBusinesscode}}</div>
  298. </div>
  299. <div class="middle_bottom-leftitem clearfix">
  300. <div class="bottom-title">地址</div><label style="float: left">:</label><div style="width: 3.9rem;">{{item.enAddress}}</div>
  301. </div>
  302. </div>
  303. </div>
  304. </div>
  305. </div>
  306. </template>
  307. </template>
  308. </template>
  309. </div>
  310. </template>
  311. <template v-if="allTotal === 0">
  312. <div class="none-state">
  313. <img src="/images/mobile/@2x/search-empty.png">
  314. <p>暂无数据</p>
  315. <nuxt-link to="/">返回首页</nuxt-link>
  316. </div>
  317. </template>
  318. </div>
  319. <!-- 联系卖买家 -->
  320. <div class="mobile-modal" v-if="showStoreInfo" @touchmove="preventTouchMove($event)">
  321. <div class="mobile-modal-box mobile-link-en">
  322. <div class="mobile-modal-header">联系方式<i @click="showStoreInfo = false" class="icon-guanbi iconfont"></i></div>
  323. <div class="mobile-modal-content">
  324. <div v-if="AlertstoreInfo.enterprise.enTel"><span >电话:</span><a :href="'tel:' + AlertstoreInfo.enterprise.enTel" target="_blank" class="content-line link-url">{{AlertstoreInfo.enterprise.enTel}}</a></div>
  325. <div v-if="AlertstoreInfo.enterprise.enPhone"><span >手机:</span><a :href="'tel:' + AlertstoreInfo.enterprise.enPhone" target="_blank" class="content-line link-url">{{AlertstoreInfo.enterprise.enPhone}}</a></div>
  326. <div v-if="AlertstoreInfo.enterprise.enWeixin"><span >微信:</span><span class="content-line">{{AlertstoreInfo.enterprise.enWeixin}}</span></div>
  327. <div v-if="AlertstoreInfo.enterprise.enQQ"><span >Q&nbsp;Q:</span><span class="content-line">{{AlertstoreInfo.enterprise.enQQ}}</span></div>
  328. <div v-if="!empty">暂无联系方式</div>
  329. </div>
  330. </div>
  331. </div>
  332. <!-- 询价 -->
  333. <publish-supplier-seek :product="currentProduct" :showPublishBox="showPublishBox" @cancelAction="showPublishBox = false" @remindAction="setRemindText"></publish-supplier-seek>
  334. <!-- 查看品牌更多信息 -->
  335. <modal-wrapper :showModal="showBrandDetails" :title="currentBrandItem.nameEn" @closeAction="showBrandDetails=false">
  336. <div class="store-info" >
  337. <div class="store-description">
  338. <h4>主营产品</h4>
  339. <p class="content" v-if="currentBrandItem.series">
  340. {{currentBrandItem.series}}
  341. </p>
  342. <div class="com-none-state" v-else>
  343. <p>抱歉,暂无主营产品信息</p>
  344. </div>
  345. </div>
  346. <div class="store-description">
  347. <h4>应用领域</h4>
  348. <p class="content" v-if="currentBrandItem.application">
  349. {{currentBrandItem.application}}
  350. </p>
  351. <div class="com-none-state" v-else>
  352. <p>抱歉,暂无应用领域信息</p>
  353. </div>
  354. </div>
  355. <div class="store-description">
  356. <h4>品牌介绍</h4>
  357. <p class="content" v-if="currentBrandItem.brief">
  358. {{currentBrandItem.brief}}
  359. </p>
  360. <div class="com-none-state" v-else>
  361. <p>抱歉,暂无企业介绍</p>
  362. </div>
  363. </div>
  364. <div class="contact-info">
  365. <h4>联系我们</h4>
  366. <ul class="list-unstyled clearfix">
  367. <li>
  368. <div>电&nbsp;&nbsp;话:</div>
  369. <div v-if="currentBrandItem.userDefine.userTel"><a :href="'tel:' + currentBrandItem.userDefine.userTel" >{{currentBrandItem.userDefine.userTel}}</a></div>
  370. <div v-else><span>-</span></div>
  371. </li>
  372. <!-- <li>
  373. <div>店铺地址:</div>
  374. <div v-if="store.enterprise.address">{{store.enterprise.address}}</div>
  375. <div v-else><span>-</span></div>
  376. </li>-->
  377. </ul>
  378. </div>
  379. </div>
  380. </modal-wrapper>
  381. <remind-box :title="collectResult" :timeoutCount="timeoutCount"></remind-box>
  382. <!--<loading v-if="isSearchSearchingMore"></loading>-->
  383. <login-box @onLoginBoxClose="showLoginBox = false" v-if="showLoginBox" :url="url"></login-box>
  384. <pull-up :fixId="'main-search-wrapper'" :searchMore="isSearchSearchingMore" :allPage="allPage" :page="page" @pullUpAction="onPullUp" :FixedEl="true"></pull-up>
  385. </div>
  386. </template>
  387. <script>
  388. import { PublishSupplierSeek } from '~components/mobile/applyPurchase'
  389. import { RemindBox, Loading, LoginBox, PullUp } from '~components/mobile/common'
  390. import { ModalWrapper } from '~components/mobile/base'
  391. import axios from '~plugins/axios'
  392. export default {
  393. layout: 'mobile',
  394. data() {
  395. return {
  396. collectResult: '', // 提示性文字
  397. timeoutCount: 0, // 弹出框计时数
  398. isSearchSearchingMore: false, // 是否正在请求数据
  399. showLoginBox: false, // 是否显示登录弹窗
  400. url: '', // 登录后跳转回来的地址
  401. keyword: '', // 关键字搜索
  402. showStoreInfo: false, // 联系买卖家弹窗
  403. AlertstoreInfo: { // 买卖家弹窗信息
  404. enterprise: {}
  405. },
  406. navType: 'hasStore', // 现货 期货
  407. ChooseTop: 'component', // 型号, 物料名称, 卖家, 品牌
  408. page: 1,
  409. currentProduct: {},
  410. currentBrandItem: { // 查看品牌详情信息
  411. userDefine: {}
  412. }, // 存放当前点击的品牌内容
  413. showBrandDetails: false, // 是否展示品牌详情
  414. brandIsAccurate: false, // 品牌是否处于精确查找
  415. showPublishBox: false, // 询价弹窗
  416. resourceList: [],
  417. futuresallTotal: 0,
  418. stockallTotal: 0,
  419. allPage: 0, // 总页数
  420. allTotal: 0, // 总条数
  421. associate: {
  422. show: false
  423. },
  424. displayKeyword: ''
  425. }
  426. },
  427. computed: {
  428. getNowChooseType() {
  429. if (this.ChooseTop === 'component') {
  430. return '型号'
  431. } else if (this.ChooseTop === 'kind') {
  432. return '物料'
  433. } else if (this.ChooseTop === 'store') {
  434. return '卖家'
  435. } else if (this.ChooseTop === 'brand') {
  436. return '品牌'
  437. }
  438. },
  439. empty () {
  440. return this.checkInfo(this.AlertstoreInfo.enterprise.enTel) || this.checkInfo(this.AlertstoreInfo.enterprise.enPhone) || this.checkInfo(this.AlertstoreInfo.enterprise.enWeixin) || this.checkInfo(this.AlertstoreInfo.enterprise.enQQ)
  441. },
  442. placeholder() {
  443. if (this.ChooseTop === 'component') {
  444. return '请输入您要搜索的型号'
  445. } else if (this.ChooseTop === 'kind') {
  446. return '请输入您要搜索的物料名称'
  447. } else if (this.ChooseTop === 'store') {
  448. return '请输入您要搜索的卖家名称'
  449. } else if (this.ChooseTop === 'brand') {
  450. return '请输入您要搜索的品牌'
  451. }
  452. },
  453. similarKeywords () {
  454. return this.$store.state.search.keywords.data
  455. }
  456. },
  457. async asyncData({store, route}) {
  458. let ChooseTop = route.query.choosetype || 'component'
  459. let keyword = route.query.keyword || ''
  460. let brandIsAccurate = false
  461. let { data } = await axios.get(`/search/201819`, {params: {count: 10, page: 1, keyword: keyword, type: ChooseTop}})
  462. let allTotal = 0
  463. let futuresallTotal = data.futures ? data.futures.total : 0
  464. let stockallTotal = data.stock ? data.stock.total : 0
  465. let allPage = 0
  466. let currentBrandItem = {
  467. userDefine: {}
  468. }
  469. if (ChooseTop === 'brand') {
  470. if (data.futures && data.stock) {
  471. // 品牌查询 精准查找
  472. brandIsAccurate = true
  473. currentBrandItem = data.brand
  474. // 则总条数等于 现货 + 期货
  475. allTotal = stockallTotal + futuresallTotal
  476. allPage = Math.ceil(data.stock.total / 10)
  477. } else {
  478. allTotal = data.total || 0
  479. allPage = Math.ceil(data.total / 10)
  480. }
  481. } else {
  482. // 其他情况
  483. allTotal = stockallTotal + futuresallTotal
  484. allPage = Math.ceil(data.stock.total / 10)
  485. }
  486. return {
  487. ChooseTop: ChooseTop,
  488. keyword: keyword,
  489. resourceList: data,
  490. allPage: allPage,
  491. stockallTotal: stockallTotal,
  492. futuresallTotal: futuresallTotal,
  493. allTotal: allTotal,
  494. brandIsAccurate: brandIsAccurate,
  495. currentBrandItem: currentBrandItem,
  496. displayKeyword: keyword
  497. }
  498. },
  499. methods: {
  500. onPullUp() {
  501. this.page++
  502. this.ReloadList()
  503. },
  504. // 搜索点击事件
  505. onClickSearchHander() {
  506. if (!this.keyword) return
  507. this.$router.push(`/mobile/search/newkeycode?choosetype=${this.ChooseTop}&keyword=${this.keyword}`)
  508. // this.setChangelistHander(this.ChooseTop)
  509. // window.location.href =
  510. },
  511. // 现货 期货切换
  512. getReloadList(_tp) {
  513. this.navType = _tp
  514. this.page = 1
  515. this.resourceList.futures.content = []
  516. this.resourceList.stock.content = []
  517. this.ReloadList()
  518. },
  519. // 刷新数据
  520. ReloadList(param) {
  521. // 如果有值,则代表 是品牌 模糊到精确
  522. // 这里发送数据请求
  523. this.isSearchSearchingMore = true
  524. this.$http.get(`/search/201819`, {params: {count: 10, page: this.page, keyword: this.keyword, type: this.ChooseTop}}).then(res => {
  525. this.isSearchSearchingMore = false
  526. if (!this.brandIsAccurate && this.ChooseTop === 'brand') {
  527. this.resourceList.content = [...this.resourceList.content, ...res.data.content]
  528. return
  529. }
  530. if (this.navType === 'hasStore') {
  531. this.resourceList.stock.content = [...this.resourceList.stock.content, ...res.data.stock.content]
  532. } else {
  533. this.resourceList.futures.content = [...this.resourceList.futures.content, ...res.data.futures.content]
  534. }
  535. }, err => {
  536. this.isSearchSearchingMore = false
  537. })
  538. },
  539. // 模糊品牌查询结果点击
  540. goToBrandAccurate(item) {
  541. this.currentBrandItem = item
  542. this.keyword = item.nameEn
  543. this.setChangelistHander(this.ChooseTop)
  544. },
  545. // 取消返回事件
  546. cancelSearchHander() {
  547. this.$router.replace('/')
  548. },
  549. // 购买 加入购物车
  550. buy: function (item, flag, e) {
  551. this.baseUtils.buyOrCar(flag, e, this, item, '/mobile/center/user/pay/')
  552. },
  553. // 联系买卖家
  554. cancatSeller(item) {
  555. this.$http.get(`/api/store-service/stores?uuid=${item.storeid}`).then(res => {
  556. this.AlertstoreInfo = res.data
  557. this.showStoreInfo = true
  558. })
  559. },
  560. // 切换顶部一级标题
  561. setChangelistHander(str) {
  562. if (document.querySelector('#main-search-wrapper')) document.querySelector('#main-search-wrapper').scrollTop = 0
  563. this.ChooseTop = str
  564. this.page = 1
  565. if (!this.keyword) return
  566. this.displayKeyword = this.keyword
  567. this.brandIsAccurate = false
  568. this.isSearchSearchingMore = true
  569. this.$http.get(`/search/201819`, {params: {count: 10, page: 1, keyword: this.keyword, type: this.ChooseTop}}).then(data => {
  570. data = data.data
  571. this.resourceList = data
  572. this.futuresallTotal = data.futures ? data.futures.total : 0
  573. this.stockallTotal = data.stock ? data.stock.total : 0
  574. let allTotal = 0 // 总条数
  575. if (this.ChooseTop === 'brand') {
  576. if (data.futures && data.stock) {
  577. // 品牌查询 精准查找
  578. this.brandIsAccurate = true
  579. // 则总条数等于 现货 + 期货
  580. allTotal = this.stockallTotal + this.futuresallTotal
  581. this.currentBrandItem = data.brand
  582. } else {
  583. allTotal = data.total || 0
  584. }
  585. } else {
  586. // 其他情况
  587. allTotal = this.stockallTotal + this.futuresallTotal
  588. }
  589. this.allTotal = allTotal
  590. this.isSearchSearchingMore = false
  591. if (!this.brandIsAccurate && this.ChooseTop === 'brand') {
  592. // 品牌 模糊查找
  593. this.allPage = Math.ceil(this.resourceList.total / 10) || 0
  594. } else {
  595. if (this.navType === 'hasStore') {
  596. this.allPage = this.resourceList.stock && Math.ceil(this.resourceList.stock.total / 10) || 0
  597. } else {
  598. this.allPage = this.resourceList.futures && Math.ceil(this.resourceList.futures.total / 10) || 0
  599. }
  600. }
  601. this.associate.show = false
  602. })
  603. },
  604. // 供应商详情
  605. goSupplierDetail: function (item) {
  606. this.$http.get('/vendor/introduction/product/count', {params: {vendUU: item.enUU}})
  607. .then(response => {
  608. if (response.data.success && response.data.count > 0) {
  609. this.$router.push(`/mobile/supplier/detail/${item.enUU}?isStore=${item.isStore}`)
  610. } else {
  611. this.setRemindText('供应商正在完善产品信息,暂时不能查看更多。')
  612. }
  613. })
  614. },
  615. checkInfo: function (str) {
  616. return str && str.trim() !== ''
  617. },
  618. publish: function (product) {
  619. if (this.user.logged) {
  620. let item = {
  621. cmpCode: product.code,
  622. pbranden: product.brandNameEn,
  623. brand: product.brandNameEn,
  624. spec: product.spec,
  625. kind: product.kindNameCn
  626. }
  627. this.currentProduct = item
  628. this.showPublishBox = true
  629. } else {
  630. this.url = this.$route.fullPath
  631. this.showLoginBox = true
  632. }
  633. },
  634. setRemindText(str) {
  635. this.timeoutCount++
  636. this.collectResult = str
  637. },
  638. onAssociateClick (word) {
  639. if (this.ChooseTop === 'component') {
  640. this.keyword = word.code
  641. } else if (this.ChooseTop === 'kind') {
  642. this.keyword = word.nameCn
  643. } else if (this.ChooseTop === 'store') {
  644. this.keyword = word.name
  645. } else if (this.ChooseTop === 'brand') {
  646. this.keyword = word.nameEn
  647. }
  648. this.associate.show = false
  649. this.setChangelistHander(this.ChooseTop)
  650. },
  651. Getsimilar(word) {
  652. if (this.ChooseTop === 'component') {
  653. return word.code
  654. } else if (this.ChooseTop === 'kind') {
  655. return word.nameCn
  656. } else if (this.ChooseTop === 'store') {
  657. return word.name
  658. } else if (this.ChooseTop === 'brand') {
  659. return word.nameEn
  660. }
  661. },
  662. onChange () {
  663. if (!this.keyword) {
  664. this.associate.show = false
  665. this.$store.dispatch('resetSearchKeywords')
  666. } else {
  667. this.searchKeywords()
  668. }
  669. },
  670. changeKeyWord() {
  671. this.associate.show = true
  672. this.onChange()
  673. },
  674. searchKeywords () {
  675. this.$store.dispatch('searchKeywords', {keyword: this.keyword, type: this.ChooseTop})
  676. },
  677. onClickTosearch(str) {
  678. this.keyword = str
  679. this.setChangelistHander(this.ChooseTop)
  680. }
  681. },
  682. components: {
  683. RemindBox,
  684. Loading,
  685. LoginBox,
  686. PublishSupplierSeek,
  687. ModalWrapper,
  688. PullUp
  689. },
  690. watch: {
  691. '$route' (to, from) {
  692. this.keyword = to.query.keyword
  693. this.displayKeyword = to.query.keyword
  694. this.setChangelistHander(to.query.choosetype)
  695. }
  696. }
  697. }
  698. </script>
  699. <style lang="scss" scoped>
  700. @mixin overFlowHidden {
  701. overflow: hidden;
  702. text-overflow: ellipsis;
  703. white-space: nowrap;
  704. }
  705. @mixin lineHeight($value) {
  706. height: $value;
  707. line-height: $value;
  708. }
  709. .search-wrapper {
  710. background: #f1f3f6;
  711. width: 100%;
  712. position: fixed;
  713. z-index: 1000;
  714. top: 0;
  715. bottom: 0;
  716. .main-search-header {
  717. position: absolute;
  718. background: #3e82f5;
  719. line-height: .88rem;
  720. margin-top: 0;
  721. z-index: 1;
  722. width: 100%;
  723. input {
  724. width: 4.88rem;
  725. height: .62rem;
  726. line-height: .62rem;
  727. font-size: .26rem;
  728. color: #333;
  729. margin-left: 0.3rem;
  730. /*padding-left: 1.26rem;*/
  731. border: .04rem solid #fff;
  732. background: #fff;
  733. outline: none;
  734. border-radius: 0;
  735. float: left;
  736. margin-top: .12rem;
  737. -webkit-appearance: none;
  738. border-top-left-radius: .14rem;
  739. border-bottom-left-radius: .14rem;
  740. }
  741. span {
  742. display: inline-block;
  743. width: 1.02rem;
  744. text-align: center;
  745. height: .62rem;
  746. line-height: .62rem;
  747. color: #366df3;
  748. font-size: .28rem;
  749. margin-left: .02rem;
  750. border-top-right-radius: .14rem;
  751. border-bottom-right-radius: .14rem;
  752. background: #fff;
  753. float: left;
  754. margin-top: .12rem;
  755. }
  756. a {
  757. font-size: .28rem;
  758. color: #fff;
  759. margin-left: .2rem;
  760. }
  761. .main-search-header-controll {
  762. background: #3e82f5;
  763. width: 5.9rem;
  764. margin-left: 0.3rem;
  765. div {
  766. @include lineHeight(0.66rem);
  767. font-size: 0.28rem;
  768. color: #fff;
  769. margin: 0;
  770. background: rgba(0,0,0,0);
  771. border-radius: 0;
  772. &.active a {
  773. color: #fff;
  774. border-bottom: 0.02rem solid #fff;
  775. }
  776. a {
  777. margin-left: 0 !important;
  778. }
  779. }
  780. }
  781. }
  782. .main-search-wrapper {
  783. margin-top: 1.7rem;
  784. }
  785. .search-title {
  786. font-size: 0.26rem;
  787. text-align: center;
  788. color: #999;
  789. margin: 0 auto 0.2rem;
  790. span {
  791. color: #4290f7
  792. }
  793. }
  794. .search-nav {
  795. background: #fff;
  796. @include lineHeight(1rem);
  797. padding: 0 0.2rem;
  798. span {
  799. width: 50%;
  800. color: #666;
  801. font-size: 0.28rem;
  802. text-align: center;
  803. border-bottom: 0.04rem solid #dcdcdc;
  804. @include lineHeight(0.7rem);
  805. margin-top: 0.15rem;
  806. &.active {
  807. border-bottom: 0.04rem solid #4290f7;
  808. color: #4290f7
  809. }
  810. }
  811. }
  812. .search-content {
  813. padding-top: 0;
  814. margin-top: 0.2rem;
  815. height: calc(100vh - 3.43rem);
  816. overflow-y: auto;
  817. .middle {
  818. background: #fff;
  819. padding: 0.2rem;
  820. .lookMoreBtn {
  821. font-size: 0.28rem;
  822. color: #2d8cf0
  823. }
  824. .more_icon {
  825. font-size: 0.34rem;
  826. color: #999;
  827. }
  828. .order-tag {
  829. display: inline-block;
  830. font-size: .18rem;
  831. color: #fff;
  832. font-weight: bold;
  833. background: #ee1717;
  834. height: .27rem;
  835. width: .27rem;
  836. line-height: .27rem;
  837. text-align: center;
  838. border-radius: .05rem;
  839. position: relative;
  840. top: -.05rem;
  841. margin-right: .05rem;
  842. &.reserve-tag {
  843. background: #07bb1c;
  844. }
  845. }
  846. text-align: left;
  847. background: #fff;
  848. /*border-radius: 5px;*/
  849. margin-bottom: 0.2rem;
  850. .overHidden {
  851. @include overFlowHidden()
  852. }
  853. .pms {
  854. color: #f57710;
  855. border: 1px solid #f57710;
  856. border-radius: 0.4rem;
  857. background: #fff;
  858. font-size: 0.24rem;
  859. height: 0.4rem;
  860. line-height: 0.4rem;
  861. width: 0.8rem;
  862. text-align: center;
  863. }
  864. .list {
  865. @include overFlowHidden();
  866. width: 100%;
  867. .left {
  868. float: left;
  869. overflow: hidden;
  870. text-overflow: ellipsis;
  871. white-space: nowrap;
  872. }
  873. .textinfo {
  874. font-size: 0.18rem;
  875. margin-left: 0.1rem;
  876. display: inline-block;
  877. background: #3f84f6;
  878. color: #fff;
  879. font-weight: bold;
  880. border-radius: 3px;
  881. width: 0.8rem;
  882. height: 0.32rem;
  883. line-height: 0.32rem;
  884. text-align: center
  885. }
  886. .button {
  887. font-size: 0.3rem;
  888. color: #1a58dd;
  889. width: 0.92rem;
  890. height: 0.43rem;
  891. line-height: 0.43rem;
  892. text-align: center;
  893. border-radius: 5px;
  894. border:1px solid #1a58dd;
  895. display: inline-block;
  896. margin-right: 0.2rem;
  897. }
  898. margin-bottom: 0.18rem;
  899. &::after{
  900. clear: both;
  901. display: block;
  902. content: ' ';
  903. visibility: hidden;
  904. zoom: 1;
  905. }
  906. .fl {
  907. width: 3.5rem;
  908. float: left;
  909. }
  910. .fr {
  911. text-align: left;
  912. width: 2.6rem;
  913. overflow: hidden;
  914. text-overflow: ellipsis;
  915. white-space: nowrap;
  916. }
  917. &.list-long {
  918. .fl {
  919. width: 100% !important;
  920. }
  921. }
  922. .name {
  923. color: #666;
  924. font-size: 0.28rem;
  925. display: inline-block;
  926. }
  927. .text {
  928. display: inline-block;
  929. color: #333;
  930. font-size: 0.28rem;
  931. vertical-align: top;
  932. width: 5.5rem;
  933. @include overFlowHidden();
  934. }
  935. .table {
  936. width: 5.85rem;
  937. margin-bottom: 0;
  938. margin-top: 0;
  939. margin-left: 0.1rem;
  940. li {
  941. height: 0.43rem;
  942. line-height: 0.43rem;
  943. border-left: .01rem solid #c5c5c5;
  944. font-size: .28rem;
  945. &::after {
  946. clear: both;
  947. display: block;
  948. content: ' ';
  949. visibility: hidden;
  950. zoom: 1;
  951. }
  952. div {
  953. text-align: center;
  954. width: 50%;
  955. float: left;
  956. border-right: .01rem solid #c5c5c5;
  957. border-bottom: .01rem solid #c5c5c5;
  958. }
  959. &:nth-child(odd) {
  960. background: #ddd;
  961. color: #333;
  962. font-size: 0.28rem;
  963. }
  964. &:nth-child(even) {
  965. background: #fcfcfc;
  966. color: #333;
  967. font-size: 0.28rem;
  968. }
  969. &:nth-last-of-type(1){
  970. color: #f31919;
  971. }
  972. &.title {
  973. font-size: 0.28rem;
  974. color: #333;
  975. }
  976. }
  977. }
  978. .pull-right {
  979. div {
  980. color: #3f84f6;
  981. font-size: 0.28rem;
  982. border-radius: 0.07rem;
  983. border: 1px solid #3f84f6;
  984. background: #fff;
  985. width: 2rem;
  986. line-height: 0.56rem;
  987. height: 0.56rem;
  988. text-align: center;
  989. }
  990. div:last-child {
  991. margin-left: 0.2rem;
  992. color: #fff;
  993. background: #3f84f6;
  994. }
  995. }
  996. i {
  997. &.icon-pdf {
  998. color: #929292;
  999. font-size: 0.4rem;
  1000. }
  1001. &.active {
  1002. color: #eb062b;
  1003. }
  1004. }
  1005. .cancat {
  1006. height: 0.56rem;
  1007. line-height: 0.56rem;
  1008. border: 1px solid #3f84f6;
  1009. color: #3f84f6;
  1010. font-size: 0.26rem;
  1011. text-align: center;
  1012. border-radius: 3px;
  1013. padding: 0 0.1rem;
  1014. overflow: hidden;
  1015. width: auto;
  1016. }
  1017. img.pull-left {
  1018. width: 1.21rem;
  1019. height: 0.8rem;
  1020. border: 1px solid #dcdcdc;
  1021. border-radius: 0.07rem;
  1022. margin-top: 0;
  1023. }
  1024. }
  1025. .sayPriBtn {
  1026. width: 2rem;
  1027. @include lineHeight(0.54rem);
  1028. color: #fff;
  1029. font-size: 0.28rem;
  1030. background: #3f84f6;
  1031. border-radius: 3px;
  1032. text-align: center;
  1033. margin-top: -0.1rem;
  1034. }
  1035. .middle_bottom {
  1036. .middle_bottom-left {
  1037. float: left;
  1038. img {
  1039. width: 1.21rem;
  1040. height: 1.21rem;
  1041. border: 1px solid #4290f7;
  1042. border-radius: 0.07rem;
  1043. overflow: hidden;
  1044. }
  1045. div.middle_bottom-leftitem {
  1046. line-height: 0.5rem;
  1047. font-size: 0.28rem;
  1048. div {
  1049. display: inline-block;
  1050. color: #666;
  1051. height: 100%;
  1052. float: left;
  1053. &.bottom-title {
  1054. display: inline-block;
  1055. text-align: justify;
  1056. vertical-align: top;
  1057. width: 1.5rem;
  1058. height: 0.5rem;
  1059. &::after {
  1060. content: "";
  1061. display: inline-block;
  1062. width: 100%;
  1063. overflow: hidden;
  1064. height: 0;
  1065. }
  1066. }
  1067. }
  1068. }
  1069. }
  1070. }
  1071. }
  1072. }
  1073. .searchContent2 {
  1074. height: calc(100vh - 7.3rem);
  1075. }
  1076. .searchContent3 {
  1077. height: calc(100vh - 2.25rem);
  1078. }
  1079. .store-info {
  1080. background: #f7f7f7;
  1081. h4{
  1082. width: 100%;
  1083. text-align: left;
  1084. font-size: 0.3rem;
  1085. line-height: 0.6rem;
  1086. height: 0.6rem;
  1087. letter-spacing: 0px;
  1088. color: #333;
  1089. font-weight: normal;
  1090. border-bottom: 1px solid #efeded;
  1091. padding-left: 0.11rem;
  1092. &:before{
  1093. content: '';
  1094. display: inline-block;
  1095. width: 0.08rem;
  1096. height: 0.26rem;
  1097. background-color: #145dee;
  1098. margin-right: 0.13rem;
  1099. position: relative;
  1100. top: 0.02rem;
  1101. }
  1102. }
  1103. .contact-info{
  1104. background: #fff;
  1105. margin: .2rem auto;
  1106. border-radius: .1rem;
  1107. ul{
  1108. padding: 0.22rem 0rem;
  1109. li{
  1110. div{
  1111. float: left;
  1112. font-size: .28rem;
  1113. color: #666;
  1114. line-height: .53rem;
  1115. width:80%;
  1116. text-align: left;
  1117. &:first-child{
  1118. width: 20%;
  1119. padding-left: 0.36rem;
  1120. text-align: justify;
  1121. }
  1122. a{
  1123. color: #145dee;
  1124. }
  1125. .click-tel, .click-phone{
  1126. color: #f44336;
  1127. }
  1128. }
  1129. /* &:last-child{
  1130. div{
  1131. width: 74%;
  1132. padding-right:.34rem;
  1133. word-wrap: break-word;
  1134. &:first-child{
  1135. text-align: left;
  1136. padding: 0rem 0rem 0rem .36rem;
  1137. width: 26%;
  1138. }
  1139. }
  1140. }*/
  1141. }
  1142. }
  1143. }
  1144. .store-description{
  1145. background: #fff;
  1146. /*width: 6.96rem;*/
  1147. margin: 0 auto .2rem;
  1148. border-radius: .1rem;
  1149. .content {
  1150. text-indent:2em;
  1151. background: #fff;
  1152. margin: .2rem auto 0;
  1153. padding: .04rem .34rem .4rem .34rem;
  1154. width: 100%;
  1155. font-size: .28rem;
  1156. color: #666;
  1157. text-align: left;
  1158. height: 95%;
  1159. /*box-shadow: 0 .03rem .01rem 0 #cdcbcb96;*/
  1160. line-height: .5rem;
  1161. word-break: break-all;
  1162. }
  1163. }
  1164. }
  1165. .none-state{
  1166. text-align: center;
  1167. padding:1.5rem 0;
  1168. background: #fff;
  1169. margin-top:.1rem;
  1170. width:100%;
  1171. img{
  1172. margin:0 auto;
  1173. width: 4.08rem;
  1174. height: 2.62rem;
  1175. }
  1176. p {
  1177. font-size: .32rem;
  1178. color: #999;
  1179. margin: 1.19rem 0 0 0;
  1180. }
  1181. a {
  1182. display: block;
  1183. font-size: .28rem;
  1184. color: #fff;
  1185. width: 1.88rem;
  1186. height: .54rem;
  1187. line-height: .54rem;
  1188. background: #418bf6;
  1189. margin: .7rem auto 0;
  1190. border-radius: .05rem;
  1191. }
  1192. }
  1193. .associate-list {
  1194. position: absolute;
  1195. width: 100%;
  1196. background: #fff;
  1197. top: 0.8rem;
  1198. border: 1px solid #dcdcdc;
  1199. z-index: 100;
  1200. height: 100%;
  1201. left: 0;
  1202. bottom: 0;
  1203. right: 0;
  1204. li {
  1205. height: 0.7rem;
  1206. line-height: .9rem;
  1207. margin: 0 .45rem;
  1208. border-bottom: .04rem solid #f1f0f0;
  1209. @include overFlowHidden();
  1210. i {
  1211. font-size: .36rem;
  1212. margin-right: .24rem;
  1213. color: #ddd;
  1214. }
  1215. span {
  1216. color: #999;
  1217. font-size: .28rem;
  1218. line-height: .58rem;
  1219. height: .58rem;
  1220. display: inline-block;
  1221. }
  1222. &:active, &:hover {
  1223. background: #eee;
  1224. }
  1225. &:last-child {
  1226. text-align: center;
  1227. font-size: .3rem;
  1228. color: #3976f4;
  1229. border-bottom: none;
  1230. &:active, &:hover {
  1231. background: #fff;
  1232. }
  1233. }
  1234. }
  1235. }
  1236. }
  1237. </style>