_id.vue 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <template>
  2. <div class="client-details-page">
  3. <!-- 详情页 -->
  4. <div class="client-details-box">
  5. <!--行业资讯详情-->
  6. <div class="client-details-wrap">
  7. <h1>{{infoData.title}}</h1>
  8. <p class="details-visits-box"><i></i><span>{{infoData.startTime}}</span><i type="visits"></i><span>{{infoData.visits}}</span>
  9. </p>
  10. <div class="client-content-box" v-html="infoData.content"></div>
  11. <div class="client-details-pagination">
  12. <a v-show="infoData.lastId" :href="`${baseUrl}/news/${infoData.lastId}`">
  13. <span class="mta-hidden-xs" @click.prevent="changeNews(infoData.lastId)" :title="'上一篇:'+infoData.lastName">上一篇:{{infoData.lastName}}</span>
  14. <span class="mta-hidden-sm details-phone-btn" @click.prevent="changeNews(infoData.lastId)">上一篇</span>
  15. </a>
  16. <a v-show="infoData.nextId" :href="`${baseUrl}/news/${infoData.nextId}`">
  17. <span class="mta-hidden-xs" @click.prevent="changeNews(infoData.nextId)" :title="'下一篇:'+infoData.nextName">下一篇:{{infoData.nextName}}</span>
  18. <span class="mta-hidden-sm details-phone-btn" @click.prevent="changeNews(infoData.lastId)">下一篇</span>
  19. </a>
  20. </div>
  21. </div>
  22. <!-- 最新新闻 -->
  23. <div class="latest-news-box mta-hidden-xs">
  24. <h4>最新新闻</h4>
  25. <ul class="latest-news-list">
  26. <li v-for="(item, index) in newestData" :key="index">
  27. <a :href="`${baseUrl}/news/${item.code}`">
  28. <span @click.prevent="changeNews(item.code)" :title="item.title">{{item.title}}</span>
  29. </a>
  30. <p class="details-visits-box"><i></i><span>{{item.startTime}}</span><i type="visits"></i><span style="margin-right: 0">{{item.visits}}</span>
  31. </p>
  32. </li>
  33. </ul>
  34. </div>
  35. </div>
  36. </div>
  37. </template>
  38. <script>
  39. import { mapGetters } from 'vuex';
  40. export default {
  41. name: 'news_id',
  42. layout: 'templateB',
  43. async asyncData({ params, $axios, store }) {
  44. // 设置选中菜单
  45. store.commit('setActiveNav', '/news');
  46. try {
  47. const url = '/home/news/info';
  48. const opt = {
  49. code: params.id,
  50. };
  51. const res = await $axios.post(url, opt);
  52. const url2 = '/home/news/newest';
  53. const res2 = await $axios.post(url2);
  54. console.log(res);
  55. return {
  56. infoData: res.data.data,
  57. newestData: res2.data.data.data,
  58. };
  59. } catch (e) {
  60. return {};
  61. }
  62. },
  63. head(){
  64. return {
  65. title: this.infoData.title,
  66. meta: [
  67. {
  68. hid: this.infoData.keyword,
  69. name: 'description',
  70. content: this.infoData.intro
  71. }
  72. ],
  73. }
  74. },
  75. computed: {
  76. baseUrl() {
  77. return this.getBaseUrl;
  78. },
  79. ...mapGetters(['getBaseUrl']),
  80. },
  81. methods: {
  82. changeNews(id) {
  83. this.$router.push({ name: 'news-id', params: { id } });
  84. },
  85. },
  86. };
  87. </script>
  88. <style>
  89. </style>