detail_sec.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  1. <template>
  2. <!-- goods -->
  3. <div class="goods">
  4. <main class="index_main" v-if="shopType == 1">
  5. <section class="index_1 clearfix">
  6. <div class="breadcrumb">
  7. <div class="inner">
  8. <span class="location">当前位置 :</span>
  9. <el-breadcrumb :separator-icon="ArrowRight">
  10. <el-breadcrumb-item>
  11. <NuxtLink to="/">首页</NuxtLink>
  12. </el-breadcrumb-item>
  13. <el-breadcrumb-item v-if="p_parent_name != ''">
  14. <NuxtLink :to="`/${targetSegment}/index.html`"> {{ p_parent_name }}</NuxtLink>
  15. </el-breadcrumb-item>
  16. <el-breadcrumb-item v-if="parent_name != ''">
  17. <NuxtLink :to="`/${targetSegment}/${targetSegment1}/index.html`"> {{ parent_name }}
  18. </NuxtLink>
  19. </el-breadcrumb-item>
  20. <el-breadcrumb-item>
  21. {{ routeNewsTtitle }}
  22. </el-breadcrumb-item>
  23. </el-breadcrumb>
  24. </div>
  25. </div>
  26. </section>
  27. <section class="index_2 clearfix">
  28. <img class="index_2_img" :src="shopImg" :title="newsDetail.name" alt="">
  29. <div class="index_2_left">
  30. <h4 class="index_2_h4 dot1">{{ newsDetail.name }}</h4>
  31. <div class="index_2_title_box clearfix">
  32. <time class="index_2_title"> 更新日期:{{ newsDetail.updated_at }}</time>
  33. <span class="index_2_title">浏览次数:{{ newsDetail.hits }}</span>
  34. </div>
  35. <div class="index_2_ul clearfix">
  36. <div class="index_2_li clearfix">
  37. <label class="index_2_li_label">公 司 名</label>
  38. <span class="index_2_li_text "> {{ newsDetail.com }}</span>
  39. </div>
  40. <div class="index_2_li clearfix">
  41. <label class="index_2_li_label">所 在 地</label>
  42. <span class="index_2_li_text ">{{ newsDetail.address }}</span>
  43. </div>
  44. <div class="index_2_li clearfix">
  45. <label class="index_2_li_label">联 系 人</label>
  46. <span class="index_2_li_text ">{{ newsDetail.contact }}</span>
  47. </div>
  48. <div class="index_2_li clearfix">
  49. <label class="index_2_li_label">产品单价</label>
  50. <span class="index_2_li_text">
  51. {{ newsDetail.price }}
  52. 元/
  53. {{ newsDetail.unit }}
  54. </span>
  55. </div>
  56. <div class="index_2_li clearfix">
  57. <label class="index_2_li_label">最小定量</label>
  58. <span class="index_2_li_text ">{{ newsDetail.min }}</span>
  59. </div>
  60. <div class="index_2_li clearfix">
  61. <label class="index_2_li_label">供货总量</label>
  62. <span class="index_2_li_text ">{{ newsDetail.max }}</span>
  63. </div>
  64. <div class="index_2_li clearfix">
  65. <label class="index_2_li_label">有 效 期</label>
  66. <span class="index_2_li_text ">{{ getTime(newsDetail.validity, 'year', 1) }}</span>
  67. </div>
  68. </div>
  69. </div>
  70. </section>
  71. <!-- 选项卡1 -->
  72. <section class="index_3 clearfix">
  73. <div class="shop_head_1 clearfix">
  74. <div class="shop_head_1_name" :class="{ shop_head_1_name_only: supply_num == 1 }"
  75. @mouseover="supply_num = 1">详情信息</div>
  76. <div class="shop_head_1_name" :class="{ shop_head_1_name_only: supply_num == 2 }"
  77. @mouseover="supply_num = 2">联系方式</div>
  78. <div class="shop_head_1_name" :class="{ shop_head_1_name_only: supply_num == 3 }"
  79. @mouseover="supply_num = 3">图片展示</div>
  80. </div>
  81. <div class="card_out clearfix">
  82. <div class="card_1_box clearfix card_1_box_only" v-if="supply_num == 1" v-html="newsDetail.detail">
  83. </div>
  84. <div class="card_1_box clearfix card_1_box_only" v-if="supply_num == 2">
  85. <p class="supply_art_box_p">公司名称:{{ newsDetail.com }}</p>
  86. <p class="supply_art_box_p">电子邮箱:{{ newsDetail.email }}</p>
  87. <p class="supply_art_box_p">邮政编码:{{ newsDetail.postal }}</p>
  88. <p class="supply_art_box_p">联系地址:{{ newsDetail.address }}</p>
  89. </div>
  90. <div class="card_1_box clearfix card_1_box_only" v-if="supply_num == 3">
  91. <div class="supply_art_box_img">
  92. <img :src="item" v-for="item in newsDetail.imgurl">
  93. </div>
  94. </div>
  95. </div>
  96. </section>
  97. <!-- 选项卡2 -->
  98. <section class="index_4 clearfix">
  99. <div class="box_1 clearfix">
  100. <div class="box_1_head">
  101. <div class="box_1_head_name">点击排行</div>
  102. </div>
  103. <div class="img_ul_1 clearfix">
  104. <div class="img_li_1 clearfix" v-for="(item, index) in pageData1" :key="index">
  105. <NuxtLink class="img_li_1_a" :href="getLinkPathDetail(item)" :title="item.title">
  106. <div class="img_li_1_img_box clearfix">
  107. <img class="img_li_1_img" :src="item.imgurl" :title="item.title" alt="">
  108. </div>
  109. <div class="img_li_1_dot2">{{ item.name }}
  110. </div>
  111. </NuxtLink>
  112. </div>
  113. </div>
  114. </div>
  115. <div class="box_1 clearfix">
  116. <div class="box_1_head">
  117. <div class="box_1_head_name">最新商机</div>
  118. </div>
  119. <div class="img_ul_1 clearfix">
  120. <div class="img_li_1 clearfix" v-for="(item, index) in pageData2" :key="index">
  121. <NuxtLink class="img_li_1_a" :href="getLinkPathDetail(item)" :title="item.title">
  122. <div class="img_li_1_img_box clearfix">
  123. <img class="img_li_1_img" :src="item.imgurl" :title="item.title" alt="">
  124. </div>
  125. <div class="img_li_1_dot2">{{ item.name }}
  126. </div>
  127. </NuxtLink>
  128. </div>
  129. </div>
  130. </div>
  131. </section>
  132. </main>
  133. <main class="index_main" v-if="shopType == 2">
  134. <section class=" clearfix">
  135. <div class="index_out_1_left clearfix">
  136. <section class="index_1 clearfix">
  137. <div class="breadcrumb">
  138. <div class="inner">
  139. <span class="location">当前位置 :</span>
  140. <el-breadcrumb :separator-icon="ArrowRight">
  141. <el-breadcrumb-item>
  142. <NuxtLink to="/">首页</NuxtLink>
  143. </el-breadcrumb-item>
  144. <el-breadcrumb-item v-if="p_parent_name != ''">
  145. <NuxtLink :to="`/${targetSegment}/index.html`"> {{ p_parent_name }}</NuxtLink>
  146. </el-breadcrumb-item>
  147. <el-breadcrumb-item v-if="parent_name != ''">
  148. <NuxtLink :to="`/${targetSegment}/${targetSegment1}/index.html`">
  149. {{ parent_name }}
  150. </NuxtLink>
  151. </el-breadcrumb-item>
  152. <el-breadcrumb-item>
  153. {{ routeNewsTtitle }}
  154. </el-breadcrumb-item>
  155. </el-breadcrumb>
  156. </div>
  157. </div>
  158. </section>
  159. <section class="index_2 clearfix">
  160. <img class="index_2_img" :src="shopImg" :title="newsDetail.name" alt="">
  161. <div class="index_2_right">
  162. <h4 class="index_2_h4 dot1">求购:{{ newsDetail.name }}</h4>
  163. <div class="index_2_ul clearfix">
  164. <div class="index_2_li clearfix">
  165. <label class="index_2_li_label">发布日期</label>
  166. <span class="index_2_li_text">{{ getTime(newsDetail.updated_at, 'year', 1) }}</span>
  167. </div>
  168. <div class="index_2_li clearfix">
  169. <label class="index_2_li_label">截止日期</label>
  170. <span class="index_2_li_text">{{ getTime(newsDetail.validity, 'year', 1) }}</span>
  171. </div>
  172. <div class="index_2_li clearfix">
  173. <label class="index_2_li_label">浏览次数</label>
  174. <span class="index_2_li_text">{{ newsDetail.hits }}</span>
  175. </div>
  176. <div class="index_2_li clearfix">
  177. <label class="index_2_li_label">联 系 人</label>
  178. <span class="index_2_li_text">{{ newsDetail.contact }}</span>
  179. </div>
  180. <div class="index_2_li clearfix">
  181. <label class="index_2_li_label">发布地区</label>
  182. <span class="index_2_li_text">{{ newsDetail.address }}</span>
  183. </div>
  184. <div class="index_2_li clearfix">
  185. <label class="index_2_li_label">座 机</label>
  186. <span class="index_2_li_text">{{ newsDetail.landline }}</span>
  187. </div>
  188. <div class="index_2_li clearfix">
  189. <label class="index_2_li_label">联系电话</label>
  190. <span class="index_2_li_text">{{ newsDetail.phone }}</span>
  191. </div>
  192. </div>
  193. </div>
  194. </section>
  195. </div>
  196. <div class="shop_3_right clearfix">
  197. <div class="choice_1_box clearfix">
  198. <div class="choice_1_btn_box clearfix">
  199. <div class="choice_1_btn" :class="{ choice_1_btn_only: supply_buy == 1 }"
  200. @mouseover="supply_buy = 1">
  201. <span class="choice_1_btn_a" title="供应商品">供应商品</span>
  202. </div>
  203. <div class="choice_1_btn " :class="{ choice_1_btn_only: supply_buy == 2 }"
  204. @mouseover="supply_buy = 2">
  205. <a class="choice_1_btn_a" title="求购商品">求购商品</a>
  206. </div>
  207. </div>
  208. <div class="choice_1_card_box">
  209. <!-- 供应商品 -->
  210. <div class="shop_ul_img_2 choice_1_card clearfix" v-show="supply_buy == 1">
  211. <div class="shop_li_img_2" v-for="(item, index) in pageData3" :key="index">
  212. <NuxtLink class="shop_li_img_2_a" :href="getLinkPathDetail(item)"
  213. :title="item.name">
  214. <div class="shop_li_img_2_num"> {{ index + 1 }} </div>
  215. <div class="shop_li_img_2_right clearfix">
  216. <img class="shop_li_img_2_img" :src="item.imgurl" :title="item.name" alt="">
  217. <div class="shop_li_img_2_text">
  218. {{ item.name }}
  219. </div>
  220. </div>
  221. </NuxtLink>
  222. </div>
  223. </div>
  224. <!-- 供应商品 -->
  225. <!-- 求购商品 -->
  226. <div class="shop_ul_img_2 choice_1_card clearfix" v-show="supply_buy == 2">
  227. <div class="shop_li_img_2" v-for="(item, index) in pageData4" :key="index">
  228. <NuxtLink class="shop_li_img_2_a" :href="getLinkPathDetail(item)"
  229. :title="item.name">
  230. <div class="shop_li_img_2_num"> {{ index + 1 }} </div>
  231. <div class="shop_li_img_2_right clearfix">
  232. <img class="shop_li_img_2_img" :src="item.imgurl" :title="item.name" alt="">
  233. <div class="shop_li_img_2_text">
  234. {{ item.name }}
  235. </div>
  236. </div>
  237. </NuxtLink>
  238. </div>
  239. </div>
  240. <!-- 求购商品 -->
  241. </div>
  242. </div>
  243. </div>
  244. </section>
  245. <!-- 选项卡1 -->
  246. <section class="index_3 clearfix">
  247. <div class="shop_head_1 clearfix">
  248. <div class="shop_head_1_name" :class="{ shop_head_1_name_only: buy_num == 1 }"
  249. @mouseover="buy_num = 1">详情信息</div>
  250. <div class="shop_head_1_name" :class="{ shop_head_1_name_only: buy_num == 2 }"
  251. @mouseover="buy_num = 2">发布人信息</div>
  252. </div>
  253. <div class="card_out clearfix">
  254. <div class="card_1_box clearfix card_1_box_only" v-show="buy_num == 1" v-html="newsDetail.detail">
  255. </div>
  256. <div class="card_1_box clearfix card_1_box_only" v-show="buy_num == 2">
  257. <P>公司名称:{{ newsDetail.com }}</P>
  258. <P>电子邮箱:{{ newsDetail.email }}</P>
  259. <P>邮政编码:{{ newsDetail.postal }}</P>
  260. <P>联系地址:{{ newsDetail.address }}</P>
  261. </div>
  262. </div>
  263. </section>
  264. <!-- 选项卡2 -->
  265. <section class="index_4 clearfix">
  266. <div class="box_1 clearfix">
  267. <div class="box_1_head">
  268. <div class="box_1_head_name">点击排行</div>
  269. </div>
  270. <div class="img_ul_1 clearfix">
  271. <div class="img_li_1 clearfix" v-for="(item, index) in pageData1" :key="index">
  272. <NuxtLink class="img_li_1_a" :href="getLinkPathDetail(item)" :title="item.title">
  273. <div class="img_li_1_img_box clearfix">
  274. <img class="img_li_1_img" :src="item.imgurl" :title="item.title" alt="">
  275. </div>
  276. <div class="img_li_1_dot2">{{ item.name }}
  277. </div>
  278. </NuxtLink>
  279. </div>
  280. </div>
  281. </div>
  282. <div class="box_1 clearfix">
  283. <div class="box_1_head">
  284. <div class="box_1_head_name">最新商机</div>
  285. </div>
  286. <div class="img_ul_1 clearfix">
  287. <div class="img_li_1 clearfix" v-for="(item, index) in pageData2" :key="index">
  288. <NuxtLink class="img_li_1_a" :href="getLinkPathDetail(item)" :title="item.title">
  289. <div class="img_li_1_img_box clearfix">
  290. <img class="img_li_1_img" :src="item.imgurl" :title="item.title" alt="">
  291. </div>
  292. <div class="img_li_1_dot2">{{ item.name }}
  293. </div>
  294. </NuxtLink>
  295. </div>
  296. </div>
  297. </div>
  298. </section>
  299. </main>
  300. </div>
  301. </template>
  302. <script setup>
  303. //0.页面依赖 start ---------------------------------------->
  304. import { onMounted, ref } from 'vue'
  305. import { ElBreadcrumb, ElBreadcrumbItem, ElRadio, ElRadioGroup, ElCheckbox, ElCheckboxGroup, ElMessage, ElInput } from 'element-plus'
  306. import { ArrowRight } from '@element-plus/icons-vue'
  307. //0.页面依赖 end ---------------------------------------->
  308. //1.获得路由id start ---------------------------------------->
  309. const route = useRoute();
  310. const articleId = parseInt(route.params.id);
  311. const targetSegment = getRoutePath(1);
  312. const targetSegment1 = getRoutePath(2);
  313. const targetSegment2 = getRoutePath(3);
  314. const supply_num = ref(1)
  315. const buy_num = ref(1)
  316. const supply_buy = ref(1)
  317. //1.1 获得当前的路由id
  318. let routeId;
  319. let routeType;
  320. let navTitle = ref('')//二级导航标题
  321. let navCid = ref('')//二级导航id
  322. //通过导航路径反向查询导航id
  323. const getRouteId = await requestDataPromise('/web/getWebsiteRoute', {
  324. method: 'GET',
  325. query: {
  326. 'pinyin': targetSegment2,
  327. },
  328. });
  329. console.log("getRouteId", getRouteId);
  330. if (getRouteId.code == 200) {
  331. navTitle.value = getRouteId.data.alias
  332. navCid.value = getRouteId.data.category_id
  333. } else {
  334. console.log("获得路由id出错!", getRouteId.message)
  335. }
  336. //1.2 获取二级栏目
  337. let parent_name = ref('');//父级名称
  338. let parent_id = ref('');//父级id
  339. let parent_pinyin = ref('');//父级拼音
  340. const getRoutePName = await requestDataPromise('/web/getWebsiteRoute', {
  341. method: 'GET',
  342. query: {
  343. 'pinyin': targetSegment1,
  344. },
  345. });
  346. console.log("getRoutePName", getRoutePName);
  347. if (getRoutePName.code == 200) {
  348. routeId = getRoutePName.data.category_id
  349. parent_id.value = getRoutePName.data.category_id
  350. parent_name.value = getRoutePName.data.alias
  351. routeType = getRoutePName.data.type
  352. } else {
  353. console.log("获得路由id出错!", getRoutePName.message)
  354. }
  355. //1.3 获取一级栏目
  356. let p_parent_name = ref('');//父级名称
  357. let p_parent_id = ref('');//父级id
  358. let p_parent_pinyin = ref('');//父级拼音
  359. const getRoutePName_parent = await requestDataPromise('/web/getWebsiteRoute', {
  360. method: 'GET',
  361. query: {
  362. 'pinyin': targetSegment,
  363. },
  364. });
  365. console.log("getRoutePName_parent", getRoutePName_parent);
  366. if (getRoutePName_parent.code == 200) {
  367. p_parent_id.value = getRoutePName_parent.data.category_id
  368. p_parent_name.value = getRoutePName_parent.data.alias
  369. // p_parent_pinyin.value = getRoutePName_parent.data.aLIas_pinyin
  370. } else {
  371. console.log("获得路由id出错!", getRoutePName_parent.message)
  372. }
  373. //1.4 获取某个栏目
  374. const getParentId = await requestDataPromise('/web/getOneWebsiteCategory', {
  375. method: 'GET',
  376. query: {
  377. 'catid': parent_id.value,
  378. },
  379. });
  380. console.log("getParentId", getParentId);
  381. if (getParentId.code == 200) {
  382. parent_pinyin.value = getParentId.data.aLIas_pinyin
  383. } else {
  384. console.log("获得路由id出错!", getParentId.message)
  385. }
  386. //1.获得路由id end ---------------------------------------->
  387. //2.获得模块数据 start ---------------------------------------->
  388. const pageData1 = ref([])//点击排行
  389. const pageData2 = ref([])//最新商机
  390. const pageData3 = ref([])//供应商品
  391. const pageData4 = ref([])//求购商品
  392. //创建请求数据json
  393. let getJson = [
  394. { "level": "3,0,8" },//点击排行
  395. { "level": "4,0,8" },//最新商机
  396. { "level": "5,0,6" },//供应商品
  397. { "level": "6,0,6" },//求购商品
  398. ]
  399. let jsonString = JSON.stringify(getJson)
  400. //获取所有数据
  401. async function getPageAllData() {
  402. const mkdata = await requestDataPromise('/web/getWebsiteshop', {
  403. method: 'GET',
  404. query: {
  405. 'id': jsonString,
  406. 'catid': 713,
  407. },
  408. });
  409. if (mkdata.code == 200) {
  410. //点击排行
  411. pageData1.value = mkdata.data.goods[0];
  412. //最新商机
  413. pageData2.value = mkdata.data.goods[1];
  414. //供应商品
  415. pageData3.value = mkdata.data.goods[2];
  416. //求购商品
  417. pageData4.value = mkdata.data.goods[3];
  418. } else {
  419. ElMessage.error(mkdata.message)
  420. }
  421. }
  422. getPageAllData();
  423. //2.获得模块数据 end ---------------------------------------->
  424. //4.新闻详情 start ---------------------------------------->
  425. //4.1 资讯详情
  426. const newsDetail = ref({})
  427. const routeNewsTtitle = ref("");
  428. //4.2 发布日期
  429. const time = ref("");
  430. //4.3 路径
  431. const routLevelTitle = ref("");
  432. const routLevelId = ref("");
  433. //4.4 是否展示投票
  434. const articleChoice = ref(false);
  435. //4.5 获取详情
  436. let shopImg = ref('')
  437. let shopType = ref(1)
  438. async function getPageData() {
  439. const mkdata = await requestDataPromise('/web/getWebsiteshopInfo', {
  440. method: 'GET',
  441. query: {
  442. 'id': articleId
  443. },
  444. });
  445. if (mkdata.code == 200) {
  446. //判断是否显示投票
  447. if (mkdata.data.is_survey == 1) {
  448. console.log("本篇文章含有投票!")
  449. articleChoice.value = true;
  450. }
  451. //获取内容
  452. newsDetail.value = mkdata.data;
  453. shopType.value = mkdata.data.type_id
  454. //获取路径
  455. routLevelTitle.value = newsDetail.value.cat_name;
  456. routLevelId.value = newsDetail.value.category_id;
  457. shopImg.value = mkdata.data.imgurl[0]
  458. //获取发布时间
  459. time.value = newsDetail.value.updated_at.split(' ')[0];
  460. //修正标题长度
  461. if (newsDetail.value.name.length >= 20) {
  462. routeNewsTtitle.value = newsDetail.value.name.substr(0, 20) + "...";
  463. } else {
  464. routeNewsTtitle.value = newsDetail.value.name
  465. }
  466. } else {
  467. console.log("SSR waring ---------- SSR waring ---------- SSR waring ---------->")
  468. console.log("错误位置:获取详情内容")
  469. console.log("后端错误反馈:", mkdata.message)
  470. console.log("SSR waring ---------- SSR waring ---------- SSR waring ---------->")
  471. }
  472. }
  473. getPageData();
  474. //4.新闻详情 end ---------------------------------------->
  475. //6.设置seo信息 start---------------------------------------->
  476. const setData = await requestDataPromise('/web/getWebsiteCategoryHead', {
  477. method: 'GET',
  478. query: {
  479. 'catid': routeId
  480. },
  481. });
  482. if (setData.code == 200) {
  483. let seoTitle = setData.data.seo_title;
  484. let seoDescription = setData.data.seo_description;
  485. let seoKeywords = setData.data.seo_keywords;
  486. let seoSuffix = setData.data.suffix;
  487. let seoName = setData.data.website_name;
  488. useSeoMeta({
  489. title: seoTitle + "_" + seoSuffix,
  490. meta: [
  491. { name: 'keywords', content: seoKeywords + "_" + seoName + "_" + seoSuffix, tagPriority: 10 },
  492. { name: 'description', content: seoDescription + "_" + seoName + "_" + seoSuffix, tagPriority: 10 }
  493. ]
  494. });
  495. } else {
  496. console.log("设置频道页SEO出错!", setData.message)
  497. }
  498. //6.设置seo信息 end---------------------------------------->
  499. //8.页面图片放大 start---------------------------------------->
  500. const previewVisible = ref(false)
  501. const selectedImage = ref(' ')
  502. const openPreview = (event) => {
  503. if (event.target.tagName === 'IMG') {
  504. selectedImage.value = event.target.src;
  505. previewVisible.value = true;
  506. }
  507. }
  508. const closePreview = () => {
  509. previewVisible.value = false;
  510. }
  511. //8.页面图片放大 end---------------------------------------->
  512. </script>
  513. <style lang="less" scoped>
  514. @import url('@/assets/css/shop/goodsDetail.less');
  515. @import url('@/assets/css/shop/goodsDetail1.less');
  516. </style>