detail.vue 26 KB

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