_id.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <template>
  2. <div class="client-details-page">
  3. <!-- 详情页 -->
  4. <div class="client-details-box">
  5. <!--行业资讯详情-->
  6. <div class="client-details-wrap" :class="{'isRiZhi': infoData.newsClassifyId == 3}">
  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" v-if="infoData.newsClassifyId != 3">
  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 lang="scss">
  89. .client-details-page .client-details-wrap.isRiZhi {
  90. width: 100% !important;
  91. border-right: none;
  92. h1 {
  93. text-align: center;
  94. }
  95. .details-visits-box {
  96. text-align: center;
  97. }
  98. }
  99. </style>