index.vue 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <template>
  2. <div class="purchase-layout">
  3. <div class="plate01">
  4. <div class="main-detail">
  5. <browse
  6. :idata='browdata'
  7. :iactive='browactive'
  8. :floder="'zhijiabrowse'"
  9. class="product-img"
  10. :style="{marginLeft:(split - 350)+ 'px'}"
  11. />
  12. <!-- <video class="product-img" :style="{marginLeft:(split - 500)+ 'px'}" :src="`${$cdn}video/zhijia-video.mp4`" autoplay muted loop></video> -->
  13. <div class="layout">
  14. <img class="pro-logo" :src="this.language==='en'?`${$cdn}images/zhijia-logo-en.png`:`${$cdn}images/zhijia-logo-black.png`" alt="">
  15. <p class="sub b-label" v-html="langPurchase.dec"></p>
  16. <p class="price">
  17. {{langPurchase.price}}
  18. <!-- <span>{{langPurchase.yushou}}</span> -->
  19. </p>
  20. <template>
  21. <p class="title first-title">{{langPurchase.color.key}}</p>
  22. <div class="detail-box">
  23. <i class="iconfont icon-yuandian">{{langPurchase.color.val}}</i>
  24. </div>
  25. <p class="title">{{langPurchase.service.key}}</p>
  26. <div class="detail-box sceond-box">
  27. <ul>
  28. <li v-for="(item, i) in langPurchase.service.val" :key="i">{{item}}</li>
  29. </ul>
  30. </div>
  31. </template>
  32. <template v-if="language!=='en'">
  33. <p class="title" style="margin-top:20px;">{{langPurchase.count.key}}</p>
  34. <spinner class="spinner" @count="handleSpinner"/>
  35. </template>
  36. <div>
  37. <div class="btns">
  38. <div v-if="language!=='en'" class="button add-cart" @click="addcart">
  39. <vcenter>
  40. <span>{{langPurchase.cart}}</span>
  41. </vcenter>
  42. </div>
  43. <div class="button" @click="pay">
  44. <vcenter>
  45. <span>{{langPurchase.buy}}</span>
  46. </vcenter>
  47. </div>
  48. </div>
  49. <div class="btn-dec">{{langPurchase.tiaokuan}}</div>
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. <div class="plate02">
  55. <div class="b-title">{{langPurchase.zhijia.name}}</div>
  56. <div class="b-label">{{langPurchase.zhijia.sub}}</div>
  57. <div class="p2-con">
  58. <img class="p2c-img" :src="`${$cdn}images/zhijia-left.png`" alt="">
  59. <div class="b-info">
  60. <div class="right-title">{{langPurchase.zhijia.detail}}</div>
  61. <div class="right-line"></div>
  62. <div class="right-con">
  63. <div v-for="(item,i) in langPurchase.zhijia.detailArr" :key="i">
  64. <img :src="item.img" alt="">
  65. <div class="low-title">{{item.name}}</div>
  66. </div>
  67. </div>
  68. </div>
  69. </div>
  70. </div>
  71. <div class="plate03" >
  72. <div class="b-title">{{langPurchase.guige.name}}</div>
  73. <div class="params-con">
  74. <div class="params-item" :style="{width: getWidth(index)}" v-for="(item,index) in langPurchase.guige.arr" :key="index">
  75. <div class="p-l" :style="{width:language==='en'?'300px':'100px'}">{{item.name}}</div>
  76. <div class="p-r" :style="{width:getRWidth(index)}">
  77. <div v-html="sub" v-for="(sub,i) in item.val" :key="i"></div>
  78. </div>
  79. </div>
  80. </div>
  81. <div class="sub">
  82. <p v-for="(ites,i) in langPurchase.guige.dec" :key="i">{{ites}}</p>
  83. </div>
  84. </div>
  85. <div class="plate04">
  86. <div class="b-title">{{langPurchase.hualun.name}}</div>
  87. <div class="b-label">{{langPurchase.hualun.sub}}</div>
  88. <div class="p4-img">
  89. <img :src=" language==='en'?`${$cdn}images/p4zhijia-len.png`:`${$cdn}images/p4zhijia-l.png`" alt="">
  90. <img :src=" language==='en'?`${$cdn}images/p4zhijia-ren.png`:`${$cdn}images/p4zhijia-r.png`" alt="">
  91. </div>
  92. </div>
  93. <div class="plate03" >
  94. <div class="b-title">{{langPurchase.lunguige.name}}</div>
  95. <div class="params-con">
  96. <div class="params-item" :style="{width: language==='en'? '100%': index%2===0?'calc(100% - 42%)':'42%'}" v-for="(item,index) in langPurchase.lunguige.arr" :key="index">
  97. <div class="p-l" :style="{width:language==='en'?'60%':'100px'}">{{item.name}}</div>
  98. <div class="p-r" :style="{width:language==='en'?'220px':'200px'}">
  99. <div v-html="sub" v-for="(sub,i) in item.val" :key="i"></div>
  100. </div>
  101. </div>
  102. </div>
  103. <div class="sub">
  104. <p>{{langPurchase.lunguige.dec}}</p>
  105. </div>
  106. </div>
  107. </div>
  108. </template>
  109. <script>
  110. import { mapState } from 'vuex'
  111. import spinner from '@/components/spinner'
  112. import vcenter from '@/components/vcenter'
  113. import browse from '@/components/browse'
  114. import priceTable from '@/components/priceTable'
  115. export default {
  116. components: {
  117. spinner,
  118. vcenter,
  119. browse,
  120. priceTable
  121. },
  122. computed: {
  123. ...mapState({
  124. split: state => state.ui.navDivision,
  125. isLogin: state => state.user.name,
  126. langPurchase: state => state.language.home.purchasezhijia,
  127. langToast: state => state.language.home.toast,
  128. language: state => state.language.current,
  129. token: state => state.user.token,
  130. cart: state => JSON.parse(state.user.cart)
  131. })
  132. },
  133. data () {
  134. let zhijiadetail = [
  135. {
  136. name: '专业球形云台',
  137. img: `${this.$cdn}images/zhijia-detail01.png`
  138. },
  139. {
  140. name: '脚管三段角度调节按钮',
  141. img: `${this.$cdn}images/zhijia-detail02.png`
  142. },
  143. {
  144. name: '安全的中轴升降锁紧按钮',
  145. img: `${this.$cdn}images/zhijia-detail03.png`
  146. },
  147. {
  148. name: '防滑保暖致密海绵护手',
  149. img: `${this.$cdn}images/zhijia-detail04.png`
  150. },
  151. {
  152. name: '可伸缩中轴挂钩稳定脚架',
  153. img: `${this.$cdn}images/zhijia-detail05.png`
  154. },
  155. {
  156. name: '方便快捷的版扣脚管',
  157. img: `${this.$cdn}images/zhijia-detail06.png`
  158. }
  159. ]
  160. let detail = {
  161. left: [
  162. '数据永久存储',
  163. '高速上传计算队列',
  164. '场景分享、热点编辑、隐私加密'
  165. ],
  166. right: ['多种个性化功能', '附送30G终身容量']
  167. }
  168. let guige = [
  169. {
  170. name: '容量和内存',
  171. val: ['LPDDR4X双通道', '6G内存', 'UFS 2.1', '64GB 机身存储']
  172. },
  173. {
  174. name: '机身尺寸和重量',
  175. val: ['高度 = 153.3m', '宽度 = 74.5mm', '厚度 = 7.9mm', '重量 = 170g']
  176. },
  177. {
  178. name: '处理器平台',
  179. val: [
  180. 'Qualcomm® 骁龙™ 845 处理器',
  181. '10nm 先进制程',
  182. '单核主频可达 2.8GHz',
  183. 'Adreno™ 630 图形处理器,主频可达 700MHz',
  184. '配备人工智能引擎(AI Engine)'
  185. ]
  186. },
  187. {
  188. name: '网络',
  189. val: ['支持 VoLTE 高质量宽带', '支持三载波聚', '支持 LTE B41 4x4 MIMO']
  190. },
  191. {
  192. name: '屏幕',
  193. val: [
  194. '6.17 英寸 In-Cell 全高清显示屏',
  195. '2242 x 1080 分辨率,403 ppi',
  196. '康宁®第三代大猩猩®玻璃'
  197. ]
  198. }
  199. ]
  200. let browdata = [
  201. {
  202. small: 'small-0',
  203. big: 'big-0',
  204. video: true
  205. }, {
  206. small: 'small-1',
  207. big: 'big-1'
  208. },
  209. {
  210. small: 'small-2',
  211. big: 'big-2'
  212. },
  213. {
  214. small: 'small-3',
  215. big: 'big-3'
  216. },
  217. {
  218. small: 'small-4',
  219. big: 'big-4'
  220. }]
  221. let browactive = browdata[0]
  222. return {
  223. detail,
  224. zhijiadetail,
  225. guige,
  226. browactive,
  227. browdata,
  228. count: 1,
  229. selectParts: true
  230. }
  231. },
  232. methods: {
  233. getWidth (index) {
  234. let zhW = index > this.langPurchase.lunguige.arr.length - 5 ? '100%' : index % 2 === 0 ? 'calc(100% - 36.1%)' : '36.1%'
  235. return this.language === 'en' ? '100%' : zhW
  236. },
  237. getRWidth (index) {
  238. let zhW = index > this.langPurchase.lunguige.arr.length - 5 ? 'calc(100% - 110px)' : '200px'
  239. return this.language === 'en' ? 'calc(100% - 320px)' : zhW
  240. },
  241. handleSpinner (data) {
  242. this.count = data
  243. },
  244. gobuy () {
  245. },
  246. async addcart () {
  247. if (!this.token) {
  248. return this.$bus.$emit('showAside')
  249. }
  250. let params = {
  251. goodsId: 7,
  252. goodsCount: this.count,
  253. skuSn: 'U15604134406280073'
  254. }
  255. await this.$store.dispatch('addCart', params)
  256. this.$toast.show('success', this.langToast['39'])
  257. },
  258. pay () {
  259. if (this.language === 'en') {
  260. return window.open('https://www.alibaba.com/product-detail/4DKanKan-Pro-Tripod-Set_62431649408.html?spm=a2700.icbuShop.41413.11.339877f3TUXWiN')
  261. }
  262. let params = {
  263. type: 'detail',
  264. sku: [{
  265. goodsId: 7,
  266. goodsCount: this.count,
  267. price: 899,
  268. skuSn: 'U15604134406280073'
  269. }],
  270. fromList: false
  271. }
  272. this.$bus.$emit('showAside', params)
  273. }
  274. },
  275. beforeDestroy () {
  276. clearInterval(this.interval)
  277. }
  278. }
  279. </script>
  280. <style lang="scss" scoped>
  281. @import "./style.scss";
  282. </style>