productInfo.vue 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882
  1. <template>
  2. <view class="">
  3. <u-loading-page :loading="isLoading" ></u-loading-page>
  4. <view class="" v-if="!isLoading">
  5. <u-swiper @change='swiperChange' @click="swiperClick" :list="info.images_arr" indicator indicatorMode="dot" circular height="338" imgMode="scaleToFill"></u-swiper>
  6. <view class="baseInfo">
  7. <view class="titleBox">
  8. <view class="wechat">
  9. 客服微信:{{kefu}}
  10. </view>
  11. <view class="takeImg" @click="takephotos" >
  12. 生成斑马简图
  13. </view>
  14. </view>
  15. <view class="attributeBox">
  16. <view class="attributeItem">
  17. <view class="labelItem">
  18. 编号:<text class="fontWeight">{{info.code}}</text>
  19. </view>
  20. <view class="labelItem">
  21. 区服:<text class="fontWeight">{{info.server}}</text>
  22. </view>
  23. </view>
  24. <view class="attributeItem">
  25. <view class="labelItem">
  26. 金伙伴:<text class="fontWeight">{{info.partner}}</text>
  27. </view>
  28. <view class="labelItem">
  29. vip:<text class="fontWeight">{{info.level}}</text>
  30. </view>
  31. </view>
  32. <view class="attributeItem">
  33. <view class="labelItem">
  34. 战力:<text class="fontWeight">{{info.force}}亿</text>
  35. </view>
  36. <view class="labelItem">
  37. 速度:<text class="fontWeight">{{info.speed}}万</text>
  38. </view>
  39. </view>
  40. <view class="attributeItem">
  41. <view class="labelItem">
  42. 法伤:<text class="fontWeight">{{info.atk}}万</text>
  43. </view>
  44. <view class="labelItem">
  45. 冰冻:<text class="fontWeight">{{info.property}}万</text>
  46. </view>
  47. </view>
  48. <view class="attributeItem">
  49. <view class="labelItem">
  50. 渡劫:<text class="fontWeight">{{info.dj_level}}</text>
  51. </view>
  52. <view class="labelItem">
  53. 小号数量:<text class="fontWeight">{{info.children}}</text>
  54. </view>
  55. </view>
  56. <view class="attributeItem">
  57. <view class="labelItem">
  58. 是否榜一:<text class="fontWeight">{{info.top_one==1?'是':'否'}}</text>
  59. </view>
  60. <view class="labelItem">
  61. 账号类型:<text class="fontWeight">{{info.account_type_text}}</text>
  62. </view>
  63. </view>
  64. </view>
  65. </view>
  66. <view class="labelBox" >
  67. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.top_bg.value+')'}" v-if="info.is_top==1">
  68. 置顶
  69. </view>
  70. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.discount_bg.value+')'}" v-if="info.discount==1">
  71. 特价
  72. </view>
  73. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.recommend_bg.value+')'}" v-if="info.recommend==1">
  74. 斑马推荐
  75. </view>
  76. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.stage_bg.value+')'}" v-if="info.stage==1">
  77. 可分期
  78. </view>
  79. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.recommend_bg.value+')'}" v-if="info.is_hot==1">
  80. 热门
  81. </view>
  82. <!-- <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.level_bg.value+')'}" v-if="info.level>=1">
  83. VIP
  84. </view> -->
  85. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.new_bg.value+')'}" v-if="info.is_new==1">
  86. 新品
  87. </view>
  88. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby1_bg.value+')'}" v-if="info.standby1==1">
  89. {{info.standby1_title}}
  90. </view>
  91. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby2_bg.value+')'}" v-if="info.standby2==1">
  92. {{info.standby2_title}}
  93. </view>
  94. <view class="labelItem" :style="{ backgroundImage:'url('+BASE_URL+bg_list.standby3_bg.value+')'}" v-if="info.standby3==1">
  95. {{info.standby3_title}}
  96. </view>
  97. <!-- <u-tag v-if="item.discount==1" text="特价" type="error" shape="circle" size="mini"></u-tag>
  98. <u-tag v-if="item.recommend==1" text="斑马推荐" shape="circle" size="mini"></u-tag>
  99. <u-tag v-if="item.stage==1" text="可分期" type="success" shape="circle" size="mini"></u-tag> -->
  100. </view>
  101. <view class="productInfo">
  102. <view class="infoTitle">
  103. 商品详情
  104. </view>
  105. <view class="">
  106. <u-parse :content="info.detail"></u-parse>
  107. </view>
  108. <view class="" v-if="info.content_switch==1">
  109. <u-parse :content="info.detail2"></u-parse>
  110. </view>
  111. </view>
  112. <view class="productInfo">
  113. <view class="infoTitle">
  114. 免责声明
  115. </view>
  116. <view class="statement">
  117. <u-parse :content="disclaimer"></u-parse>
  118. </view>
  119. </view>
  120. <view class="tabbar">
  121. <view class="back" @click="goBack">
  122. <u-icon name="home-fill" color="#fff"></u-icon>
  123. <span style="font-size: 16px;">返回</span>
  124. </view>
  125. <view class="price">
  126. jià格:<text class="bold">{{info.money}}</text><text>米</text>
  127. </view>
  128. <view class="back purchase" @click="showPopup=true">
  129. 流程规则
  130. </view>
  131. </view>
  132. <view class="swiper-item swiper-itemcopy" id="copyswiperItem">
  133. <view class="titleBox" :style="{background: 'url('+BASE_URL+jt_bg1+')'}">
  134. <!-- <image :src="BASE_URL+item.qrimage" mode=""></image> -->
  135. <limeQrcodeVue ref="qrcodeRef" :value="BASE_URL1+'/h5/#/pages/deal/productInfo?id='+id" size="112rpx" ></limeQrcodeVue>
  136. <view class="title">
  137. <p>{{item.title1}}</p>
  138. <p>{{item.title2}}</p>
  139. <p class="warn">{{item.title3}}</p>
  140. </view>
  141. </view>
  142. <view class="content" :style="{background: 'url('+BASE_URL+jt_bg2+')'}">
  143. <view class="" id="copycontent">
  144. </view>
  145. <view class="watermark" v-if="item.watermark_info&&item.watermark_info.type==1||item.watermark_info&&item.watermark_info.type==3">
  146. <view v-for="it in 100" class="" :style="{transform: 'rotate('+item.watermark_info.angle+'deg)',opacity:(100-item.watermark_info.opacity*1)*0.01,color:item.watermark_info.color,marginTop:item.watermark_info.hh+'px',marginBottom:item.watermark_info.hh+'px',marginLeft:item.watermark_info.ww+'px',marginRight:item.watermark_info.ww+'px',fontSize:item.watermark_info.text_font+'px',fontWeight:item.watermark_info.bold==1?'bold':'',fontFamily:item.watermark_info.typeface==1?'typeface1':item.watermark_info.typeface==2?'typeface2':item.watermark_info.typeface==3?'typeface3':item.watermark_info.typeface==4?'typeface4':item.watermark_info.typeface==5?'typeface5':item.watermark_info.typeface==6?'typeface6':''}">
  147. <image :src="BASE_URL+item.watermark_info.image" mode="" v-if="item.watermark_info.image&&item.watermark_info.type==1"></image>
  148. <text v-if="item.watermark_info.water_text&&item.watermark_info.type==3">{{item.watermark_info.water_text}}</text>
  149. </view>
  150. </view>
  151. <view class="watermark1"
  152. :style="{left:item.watermark_info.waterPos==0?0+item.watermark_info.xx+'px':item.watermark_info.waterPos==1?0+item.watermark_info.xx+'px':item.watermark_info.waterPos==4?0+item.watermark_info.voffset+'px':item.watermark_info.waterPos==7?0+item.watermark_info.xx+'px':item.watermark_info.waterPos==2?'calc( 40%'+' + '+item.watermark_info.xx+'px )':item.watermark_info.waterPos==5?'calc( 40%'+' + '+item.watermark_info.voffset+'px )':item.watermark_info.waterPos==8?'calc( 40%'+' + '+item.watermark_info.xx+'px )':'',top:item.watermark_info.waterPos==0?0+item.watermark_info.yy+'px':item.watermark_info.waterPos==1?0+item.watermark_info.yy+'px':item.watermark_info.waterPos==2?0+item.watermark_info.yy+'px':item.watermark_info.waterPos==3?0+item.watermark_info.yy+'px':item.watermark_info.waterPos==4?'40%':item.watermark_info.waterPos==5?'40%':item.watermark_info.waterPos==6?'40%':'',right:item.watermark_info.waterPos==3?0+item.watermark_info.xx+'px':item.watermark_info.waterPos==6?0+item.watermark_info.waterPos+'px':item.watermark_info.waterPos==9?0+item.watermark_info.xx+'px':'',bottom:item.watermark_info.waterPos==7?0+item.watermark_info.xx+'px':item.watermark_info.waterPos==8?0+item.watermark_info.ww+'px':item.watermark_info.waterPos==9?0+item.watermark_info.xx+'px':'',fontWeight:item.watermark_info.bold==1?'bold':'',fontFamily:item.watermark_info.typeface==1?'typeface1':item.watermark_info.typeface==2?'typeface2':item.watermark_info.typeface==3?'typeface3':item.watermark_info.typeface==4?'typeface4':item.watermark_info.typeface==5?'typeface5':item.watermark_info.typeface==6?'typeface6':''}"
  153. v-if="item.watermark_info&&item.watermark_info.type==2||item.watermark_info&&item.watermark_info.type==4">
  154. <view class="" :style="{transform: 'rotate('+item.watermark_info.angle+'deg)',opacity:(100-item.watermark_info.opacity*1)*0.01,color:item.watermark_info.color,fontSize:item.watermark_info.text_font+'px'}">
  155. <image :src="BASE_URL+item.watermark_info.image" mode="" v-if="item.watermark_info.image&&item.watermark_info.type==2"></image>
  156. <text v-if="item.watermark_info.water_text&&item.watermark_info.type==4">{{item.watermark_info.water_text}}</text>
  157. </view>
  158. </view>
  159. </view>
  160. </view>
  161. <view class="swiper-item" id="swiperItem">
  162. <view class="titleBox" :style="{background: 'url('+BASE_URL+jt_bg1+')'}">
  163. <limeQrcodeVue v-if="item.id" ref="qrcodeRef" :value="BASE_URL1+'/h5/#/pages/deal/productInfo?id='+id" size="112rpx" ></limeQrcodeVue>
  164. <!-- <image :src="BASE_URL+item.qrimage" mode=""></image> -->
  165. <view class="title">
  166. <p>{{item.title1}}</p>
  167. <p>{{item.title2}}</p>
  168. <p class="warn">{{item.title3}}</p>
  169. </view>
  170. </view>
  171. <view class="content" v-if="item.detail" :style="{background: 'url('+BASE_URL+jt_bg2+')'}">
  172. <view class="" id="content1">
  173. <u-parse :content="item.detail"></u-parse>
  174. </view>
  175. <view class="watermark" v-if="item.watermark_info&&item.watermark_info.type==1||item.watermark_info&&item.watermark_info.type==3">
  176. <view v-for="it in 100" class="" :style="{transform: 'rotate('+item.watermark_info.angle+'deg)',opacity:(100-item.watermark_info.opacity*1)*0.01,color:item.watermark_info.color,marginTop:item.watermark_info.hh+'px',marginBottom:item.watermark_info.hh+'px',marginLeft:item.watermark_info.ww+'px',marginRight:item.watermark_info.ww+'px',fontSize:item.watermark_info.text_font+'px',fontWeight:item.watermark_info.bold==1?'bold':'',fontFamily:item.watermark_info.typeface==1?'typeface1':item.watermark_info.typeface==2?'typeface2':item.watermark_info.typeface==3?'typeface3':item.watermark_info.typeface==4?'typeface4':item.watermark_info.typeface==5?'typeface5':item.watermark_info.typeface==6?'typeface6':''}">
  177. <image :src="BASE_URL+item.watermark_info.image" mode="" v-if="item.watermark_info.image&&item.watermark_info.type==1"></image>
  178. <text v-if="item.watermark_info.water_text&&item.watermark_info.type==3">{{item.watermark_info.water_text}}</text>
  179. </view>
  180. </view>
  181. <view class="watermark1" :style="{left:item.watermark_info.waterPos==0?0:item.watermark_info.waterPos==1?0:item.watermark_info.waterPos==4?0:item.watermark_info.waterPos==7?0:item.watermark_info.waterPos==2?'40%':item.watermark_info.waterPos==5?'40%':item.watermark_info.waterPos==8?'40%':'',top:item.watermark_info.waterPos==0?0:item.watermark_info.waterPos==1?0:item.watermark_info.waterPos==2?0:item.watermark_info.waterPos==3?0:item.watermark_info.waterPos==4?'40%':item.watermark_info.waterPos==5?'40%':item.watermark_info.waterPos==6?'40%':'',right:item.watermark_info.waterPos==3?0:item.watermark_info.waterPos==6?0:item.watermark_info.waterPos==9?0:'',bottom:item.watermark_info.waterPos==7?0:item.watermark_info.waterPos==8?0:item.watermark_info.waterPos==9?0:'',fontWeight:item.watermark_info.bold==1?'bold':'',fontFamily:item.watermark_info.typeface==1?'typeface1':item.watermark_info.typeface==2?'typeface2':item.watermark_info.typeface==3?'typeface3':item.watermark_info.typeface==4?'typeface4':item.watermark_info.typeface==5?'typeface5':item.watermark_info.typeface==6?'typeface6':''}" v-if="item.watermark_info&&item.watermark_info.type==2||item.watermark_info&&item.watermark_info.type==4">
  182. <view class="" :style="{transform: 'rotate('+item.watermark_info.angle+'deg)',opacity:(100-item.watermark_info.opacity*1)*0.01,color:item.watermark_info.color,fontSize:item.watermark_info.text_font+'px'}">
  183. <image :src="BASE_URL+item.watermark_info.image" mode="" v-if="item.watermark_info.image&&item.watermark_info.type==2"></image>
  184. <text v-if="item.watermark_info.water_text&&item.watermark_info.type==4">{{item.watermark_info.water_text}}</text>
  185. </view>
  186. </view>
  187. </view>
  188. </view>
  189. <u-overlay :show="show" @click="show = false">
  190. <view class="warp">
  191. <view class="rect" @tap.stop>
  192. <image :src="url" mode="widthFix"></image>
  193. <p>长按保存到本地</p>
  194. </view>
  195. </view>
  196. </u-overlay>
  197. <u-popup :show="showPopup" :round="10" mode="bottom" @close="showPopup=false">
  198. <view class="popup">
  199. <view class="popupTop">
  200. <view class="contactInfo">
  201. <p>{{notice_text}}</p>
  202. </view>
  203. <image :src="BASE_URL+noticeimage" mode=""></image>
  204. </view>
  205. <view class="notice">
  206. <!-- <view class="noticeTitle">
  207. 购买须知
  208. </view> -->
  209. <view class="noticeInfo">
  210. <u-parse :content="buy_notes"></u-parse>
  211. </view>
  212. <view class="popupBottom">
  213. <view class="back" @click="showPopup=false">
  214. <u-icon name="home-fill" color="#fff"></u-icon>
  215. 返回
  216. </view>
  217. </view>
  218. </view>
  219. </view>
  220. </u-popup>
  221. <u-overlay :show="show10" @click="show10 = false">
  222. <view class="warp">
  223. <view class="rect1" @tap.stop>
  224. <image src="../../static/tishi.png" mode=""></image>
  225. <p>该商品已出售或下架</p>
  226. <u-button color="#A5CF49" type="success" shape="circle" size="large" text="看看其他斑马账号" @click="goBack"></u-button>
  227. </view>
  228. </view>
  229. </u-overlay>
  230. </view>
  231. </view>
  232. </template>
  233. <script setup>
  234. import limeQrcodeVue from '../../uni_modules/lime-qrcode/components/l-qrcode/l-qrcode.vue';
  235. import html2canvas from 'html2canvas';
  236. import {BASE_URL,BASE_URL1} from '../../utils/http.js'
  237. import {
  238. onLoad,
  239. onShow,
  240. onPullDownRefresh,onReady
  241. } from "@dcloudio/uni-app";
  242. import {
  243. ref
  244. } from "vue"
  245. import {getGoodsDetail,getsimpleimages,getplatformeditor,getsimpleimagesdetail,getplatformmeun} from '@/utils/api.js'
  246. let show10=ref(false)
  247. let disclaimer=ref()
  248. let buy_notes=ref()
  249. let notice_text=ref()
  250. let kefu=ref()
  251. let title=ref()
  252. let bg_list=ref({})
  253. let current=ref(0)
  254. let noticeimage=ref()
  255. let jt_bg1=ref('')
  256. let jt_bg2=ref('')
  257. onReady(()=>{
  258. getplatformmeun().then(res=>{
  259. uni.setNavigationBarTitle({
  260. title: res.data.name
  261. });
  262. jt_bg1.value=res.data.jt_bg1
  263. jt_bg2.value=res.data.jt_bg2
  264. })
  265. })
  266. let swiperChange=(e)=>{
  267. current.value=e.current
  268. }
  269. let swiperClick=(e)=>{
  270. uni.previewImage({
  271. // 预览时,默认显示图片的索引
  272. current:current.value,
  273. // 所有图片 url 地址的数组
  274. urls:info.value.images_arr
  275. })
  276. }
  277. let isLoading=ref(true)
  278. onLoad((option) => {
  279. getplatformeditor().then(res=>{
  280. disclaimer.value=res.data.disclaimer
  281. notice_text.value=res.data.notice_text
  282. noticeimage.value=res.data.noticeimage
  283. buy_notes.value=res.data.buy_notes
  284. kefu.value=res.data.kfwx
  285. kefu.value=res.data.kfwx
  286. })
  287. id.value=option.id
  288. let images_arr=[]
  289. let index = new Date().getTime()
  290. getGoodsDetail(id.value).then(res=>{
  291. if(res.code==1){
  292. bg_list.value=res.data.bg_list
  293. if(res.data.detail.status==0){
  294. show10.value=true
  295. // return
  296. }
  297. }else{
  298. show10.value=true
  299. isLoading.value=false
  300. }
  301. res.data.detail.images_arr.forEach(item=>{
  302. // images_arr.push(BASE_URL+item+"?res="+index)
  303. images_arr.push(BASE_URL+item)
  304. })
  305. info.value=res.data.detail
  306. info.value.images_arr=images_arr
  307. getsimpleimagesdetail({goods_id:info.value.id}).then(res=>{
  308. isLoading.value=false
  309. item.value=res.data
  310. // item.value.detail=getspan(item.value.detail)
  311. })
  312. // getsimpleimages().then(res=>{
  313. // let arr=res.data
  314. // arr.forEach(it=>{
  315. // if(info.value.simple_id==it.id){
  316. // item.value=it
  317. // }
  318. // })
  319. // })
  320. })
  321. })
  322. function getspan(str) {
  323. var list1 = str.split('</span>')
  324. var list2 = []
  325. list1.forEach(val => {
  326. if (val.indexOf("<span") > -1) {
  327. list2.push({
  328. isspan: true,
  329. arr: val.split("<span")
  330. })
  331. } else {
  332. list2.push({
  333. isspan: false,
  334. arr: val
  335. })
  336. }
  337. })
  338. var list3 = []
  339. list2.forEach(val => {
  340. if (val.isspan) {
  341. list3.push({
  342. ...val,
  343. style: val.arr[1].split('>')[0],
  344. span: val.arr[1].split('>')[1]
  345. })
  346. } else {
  347. list3.push({
  348. ...val
  349. })
  350. }
  351. })
  352. var html = ''
  353. list3.forEach(val => {
  354. if (val.isspan) {
  355. html = html + val.arr[0]
  356. var span = ''
  357. for (var a = 0; a < val.span.length; a++) {
  358. span = span + `<span${val.style}>${val.span[a]}</span>`
  359. }
  360. html = html + span
  361. } else {
  362. html = html + val.arr
  363. }
  364. })
  365. return html
  366. }
  367. onShow(() => {
  368. })
  369. let item=ref({})
  370. let info=ref({})
  371. let id=ref('')
  372. let showPopup = ref(false)
  373. let swiperHeight =ref(67)
  374. let goBack = () => {
  375. let page=getCurrentPages()
  376. if(page.length==1){
  377. uni.switchTab({
  378. url:'/pages/deal/deal'
  379. })
  380. }else{
  381. uni.navigateBack()
  382. }
  383. // console.log('page',page)
  384. }
  385. let show = ref(false)
  386. let takephotos = () => {
  387. // var dom = document.getElementById('swiperItem'); // 获取dom元素
  388. // if(dom&&dom.children[1]){
  389. // swiperHeight.value=67+dom.children[1].clientHeight
  390. // }else{
  391. // swiperHeight.value=67
  392. // }
  393. // html2canvas(dom).then((canvas) => {
  394. // url.value = canvas.toDataURL("image/png");
  395. // show.value = true
  396. // });
  397. var swiper = document.getElementById('copyswiperItem'); // 获取dom元素
  398. var dom = document.getElementById('content1'); // 获取dom元素
  399. var dom1 = document.getElementById('copycontent'); // 获取dom元素
  400. dom1.innerHTML=dom.innerHTML
  401. let res = domTrans(dom1)
  402. // console.log(1223,res)
  403. let html = forFn(res)
  404. dom1.innerHTML=html
  405. html2canvas(swiper,{
  406. allowTaint: true,
  407. useCORS: true
  408. }).then((canvas) => {
  409. url.value = canvas.toDataURL("image/png").replace('image/png', 'image/octet-stream');
  410. show.value=true
  411. });
  412. }
  413. let url = ref()
  414. let content = `
  415. <p>露从今夜白,月是故乡明</p>
  416. <img src="https://cdn.uviewui.com/uview/swiper/2.jpg" />
  417. `
  418. let list3 = ref([
  419. 'https://cdn.uviewui.com/uview/swiper/swiper3.png',
  420. 'https://cdn.uviewui.com/uview/swiper/swiper2.png',
  421. 'https://cdn.uviewui.com/uview/swiper/swiper1.png',
  422. ])
  423. onPullDownRefresh(() => {
  424. setTimeout(function() {
  425. uni.stopPullDownRefresh();
  426. }, 1000);
  427. })
  428. function domTrans(dom) {
  429. // 总dom树
  430. let tree = [];
  431. // 递归, node = 当前的节点,dataNode = 数据插入的节点
  432. const loop = (node, dataNode) => {
  433. // 当前节点的模板
  434. let temp = {
  435. type: node.nodeType,
  436. };
  437. // 如果是文本节点 或 单标签节点
  438. if (temp.type == 3 && node.nodeValue.match(/\S/)) {
  439. temp["content"] = node.nodeValue;
  440. temp["tag"] = node.nodeName;
  441. dataNode.push(temp);
  442. }
  443. // 元素节点
  444. if (temp.type == 1) {
  445. let attributes = getAttribute(node);
  446. // 如果没有属性,不添加 attributes
  447. if (attributes) temp["attributes"] = attributes;
  448. var newNode = node.childNodes
  449. var newNode2
  450. if (newNode[0] && newNode.length <= 1) {
  451. newNode2 = newNode[0].childNodes.length
  452. }
  453. // 当前节点下还有子节点
  454. if (node.childNodes.length > 1 || newNode2 > 0) {
  455. temp["children"] = [];
  456. temp["tag"] = node.nodeName.toLowerCase();
  457. for (let i = 0; i < node.childNodes.length; i++) {
  458. loop(node.childNodes[i], temp.children);
  459. }
  460. }
  461. // 当前节点下只有文本 或 单标签节点
  462. if (node.childNodes.length <= 1 && newNode2 == 0) {
  463. temp["content"] = node.innerHTML;
  464. temp["tag"] = node.nodeName.toLowerCase();
  465. }
  466. dataNode.push(temp);
  467. }
  468. };
  469. loop(dom, tree);
  470. return tree[0].children;
  471. }
  472. function forFn(arr) {
  473. let html = ``
  474. for (let i = 0; i < arr.length; i++) {
  475. let tArr = []
  476. if (arr[i].content) {
  477. tArr = arr[i].content.split("")
  478. }
  479. if (arr[i].type === 1) {
  480. if (arr[i].attributes) {
  481. if (arr[i].attributes.src) {
  482. html +=
  483. `<img class="${arr[i].attributes.class}" src="${arr[i].attributes.src}" style="${arr[i].attributes.style}">`
  484. } else {
  485. html += `<${arr[i].tag} class="${arr[i].attributes.class}" style="${arr[i].attributes.style}">`
  486. }
  487. } else {
  488. if (arr[i].tag == "img") {
  489. html += `<${arr[i].tag} style="${arr[i].attributes.style}">`
  490. } else {
  491. html += `<${arr[i].tag}>`
  492. }
  493. }
  494. if (arr[i].children) {
  495. html += forFn(arr[i].children)
  496. }
  497. html += `</${arr[i].tag}>`
  498. }
  499. tArr.forEach(el => {
  500. if (arr[i].tag === "#text") {
  501. html += `${el}`
  502. } else {
  503. if (arr[i].attributes) {
  504. if (arr[i].tag == "img") {
  505. html +=
  506. `<${arr[i].tag} class="${arr[i].attributes.class}" src="${arr[i].attributes.src}" style="${arr[i].attributes.style}">${el}</${arr[i].tag}>`
  507. } else {
  508. html +=
  509. `<${arr[i].tag} class="${arr[i].attributes.class}" style="${arr[i].attributes.style}">${el}</${arr[i].tag}>`
  510. }
  511. } else {
  512. if (arr[i].tag == "img") {
  513. html += `<${arr[i].tag} src="${arr[i].attributes.src}">${el}</${arr[i].tag}>`
  514. } else {
  515. html += `<${arr[i].tag}>${el}</${arr[i].tag}>`
  516. }
  517. }
  518. }
  519. });
  520. }
  521. // console.log(html,'====')
  522. return html
  523. }
  524. // 提取元素属性
  525. function getAttribute(dom) {
  526. let attributes = {};
  527. // let empty = true;
  528. Array.from(dom.attributes).map((item) => {
  529. attributes[item.nodeName] = item.nodeValue;
  530. // empty = false;
  531. });
  532. return attributes;
  533. }
  534. </script>
  535. <style lang="scss">
  536. .fontWeight{
  537. font-weight: bold;
  538. color: #000;
  539. font-size: 30rpx;
  540. }
  541. .warp {
  542. padding: 0 28rpx;
  543. display: flex;
  544. align-items: center;
  545. justify-content: center;
  546. height: 100%;
  547. }
  548. .rect1 {
  549. padding: 60rpx 120rpx;
  550. display: flex;
  551. flex-direction: column;
  552. align-items: center;
  553. width: 558rpx;
  554. height: 438rpx;
  555. background: #FFFFFF;
  556. border-radius: 20rpx;
  557. image {
  558. width: 96rpx;
  559. height: 96rpx;
  560. }
  561. p {
  562. font-size: 30rpx;
  563. margin: 62rpx 0 40rpx;
  564. }
  565. // background-color: #fff;
  566. }
  567. .labelBox{
  568. padding: 0 15px;
  569. margin: 10rpx 0;
  570. display: flex;
  571. flex-wrap: wrap;
  572. .labelItem{
  573. margin-right: 20rpx;
  574. margin-bottom: 5rpx;
  575. font-size: 20rpx;
  576. color: #fff;
  577. border-radius: 30rpx;
  578. padding: 7rpx 16rpx;
  579. background-position: center center;
  580. background-repeat: no-repeat;
  581. background-size: cover;
  582. // background-color: #A5CF49;
  583. }
  584. }
  585. .content{
  586. padding-left: 10rpx;
  587. padding-right: 10rpx;
  588. overflow: hidden;
  589. position: relative;
  590. word-break: break-all;
  591. word-wrap: break-word;
  592. overflow: hidden;
  593. position: relative;
  594. .watermark{
  595. display: flex;
  596. flex-wrap: wrap;
  597. position: absolute;
  598. top: 0;
  599. left: 0;
  600. right: 0;
  601. // bottom: 0;
  602. image{
  603. width: 100rpx;
  604. height: 100rpx;
  605. }
  606. }
  607. .watermark1{
  608. position: absolute;
  609. image{
  610. width: 100rpx;
  611. height: 100rpx;
  612. }
  613. }
  614. }
  615. .popup {
  616. overflow: hidden;
  617. .notice{
  618. padding: 24rpx 28rpx;
  619. font-size: 28rpx;
  620. .noticeTitle{
  621. font-weight: bold;
  622. text-align: center;
  623. }
  624. .noticeInfo{
  625. height:500rpx;
  626. overflow: scroll;
  627. }
  628. }
  629. .popupBottom{
  630. display: flex;
  631. justify-content: right;
  632. padding: 20rpx 28rpx;
  633. height: 160rpx;
  634. .back{
  635. display: flex;
  636. justify-content: center;
  637. text-align: center;
  638. font-size: 28rpx;
  639. color: #fff;
  640. width: 162rpx;
  641. height: 80rpx;
  642. line-height: 80rpx;
  643. background: #A5CF49;
  644. border-radius: 40rpx;
  645. }
  646. }
  647. .popupTop {
  648. border-radius: 20rpx 20rpx 0rpx 0rpx;
  649. display: flex;
  650. justify-content: space-between;
  651. align-items: center;
  652. padding: 26rpx;
  653. background: linear-gradient(135deg, #F9FFE9 0%, #DDFFDA 100%);
  654. .contactInfo {
  655. flex: 1;
  656. font-size: 36rpx;
  657. }
  658. image{
  659. width: 160rpx;
  660. height: 160rpx;
  661. }
  662. }
  663. }
  664. .warp {
  665. padding: 0 28rpx;
  666. display: flex;
  667. align-items: center;
  668. justify-content: center;
  669. height: 100%;
  670. }
  671. .rect {
  672. display: flex;
  673. flex-direction: column;
  674. align-items: center;
  675. width: 694px;
  676. height: auto;
  677. image {
  678. width: 100%;
  679. }
  680. p {
  681. font-size: 48rpx;
  682. color: #fff;
  683. margin-top: 12rpx;
  684. }
  685. // background-color: #fff;
  686. }
  687. .swiper-item {
  688. position: fixed;
  689. top: 9999px;
  690. .titleBox {
  691. font-size: 28rpx;
  692. color: #666666;
  693. padding: 6rpx;
  694. background: #FFF5E5;
  695. display: flex;
  696. align-items: flex-end;
  697. image {
  698. margin-right: 4rpx;
  699. width: 112rpx;
  700. height: 112rpx;
  701. }
  702. .warn {
  703. font-size: 32rpx;
  704. color: #FF2828;
  705. }
  706. .title{
  707. margin-left: 4rpx;
  708. }
  709. }
  710. }
  711. .tabbar {
  712. bottom: 0;
  713. padding: 20rpx 28rpx;
  714. position: fixed;
  715. width: 750rpx;
  716. height: 160rpx;
  717. background: #FFFFFF;
  718. display: flex;
  719. justify-content: space-between;
  720. .back {
  721. display: flex;
  722. justify-content: center;
  723. font-size: 28rpx;
  724. color: #Fff;
  725. width: 162rpx;
  726. height: 80rpx;
  727. text-align: center;
  728. line-height: 80rpx;
  729. background: #A5CF49;
  730. border-radius: 40rpx;
  731. }
  732. .price {
  733. line-height: 80rpx;
  734. font-size: 24rpx;
  735. color: #333333;
  736. text {
  737. color: #FF2828;
  738. }
  739. .bold {
  740. font-weight: bold;
  741. font-size: 40rpx;
  742. }
  743. }
  744. }
  745. .productInfo {
  746. margin-bottom: 10rpx;
  747. background-color: #fff;
  748. padding: 20rpx 32rpx;
  749. .infoTitle {
  750. margin-bottom: 10rpx;
  751. font-size: 28rpx;
  752. font-weight: bold;
  753. }
  754. .statement {
  755. font-size: 24rpx;
  756. }
  757. }
  758. .label {
  759. padding: 24rpx 32rpx;
  760. background-color: #fff;
  761. margin: 10rpx 0;
  762. .u-fade-enter-active {
  763. margin-right: 20rpx;
  764. }
  765. }
  766. page {
  767. padding-bottom: 170rpx;
  768. .attributeBox {
  769. font-size: 28rpx;
  770. color: #666666;
  771. .attributeItem {
  772. margin-top: 20rpx;
  773. display: flex;
  774. .labelItem {
  775. flex: 1;
  776. }
  777. }
  778. }
  779. .baseInfo {
  780. background-color: #fff;
  781. padding: 22rpx 30rpx;
  782. .titleBox {
  783. display: flex;
  784. justify-content: space-between;
  785. .wechat {
  786. font-size: 40rpx;
  787. color: #1677FF;
  788. font-weight: bold;
  789. }
  790. .takeImg {
  791. width: 206rpx;
  792. height: 52rpx;
  793. line-height: 52rpx;
  794. background: #A5CF49;
  795. border-radius: 40rpx;
  796. font-size: 28rpx;
  797. color: #ffff;
  798. font-weight: bold;
  799. text-align: center;
  800. }
  801. }
  802. }
  803. }
  804. </style>