Browse Source

content keyWords

lyn7568 6 years ago
parent
commit
7172adf459

+ 1 - 1
src/libs/axios.js

@ -43,7 +43,7 @@ axiosUtil.interceptors.response.use(function (response) {
43 43
    return Promise.resolve(response)
44 44
  }
45 45
}, error => {
46
  Message.error('请求错误2,请重试')
46
  Message.error('服务器请求错误,请重试')
47 47
  return Promise.reject(error)
48 48
})
49 49

+ 1 - 1
src/libs/axiosk.js

@ -40,7 +40,7 @@ axiosUtil.interceptors.response.use(function (response) {
40 40
      return Promise.resolve(response)
41 41
    }
42 42
}, error => {
43
    Message.error('请求错误2,请重试')
43
    Message.error('服务器请求错误,请重试')
44 44
    return Promise.reject(error)
45 45
})
46 46

+ 11 - 1
src/pages/content/show.vue

@ -21,6 +21,13 @@
21 21
              <div class="content-uditor" v-html="contentInfo.cnt"></div>
22 22
            </div>
23 23
          </div>
24
          <div class="inner-wrapper">
25
            <div class="content">
26
              <el-row class="tag-item" v-if="contentInfo.keyWords && contentInfo.keyWords.length">
27
                <el-tag v-for="sub in contentInfo.keyWords" :key="sub.index">{{sub}}</el-tag>
28
              </el-row>
29
            </div>
30
          </div>
24 31
          <div class="inner-wrapper" v-if="platExperts && platExperts.length">
25 32
            <div class="content-title">
26 33
              <span>相关专家</span>
@ -62,7 +69,7 @@
62 69
</template>
63 70
64 71
<script>
65
  import { urlParse, commenTime } from '@/libs/util';
72
  import { urlParse, commenTime, strToArr } from '@/libs/util';
66 73
67 74
  import queryBase from '@/libs/queryBase';
68 75
  import baseExpert from '@/components/subTemplate/BaseExpert';
@ -102,6 +109,9 @@
102 109
        }, (res) => {
103 110
          if (res.success) {
104 111
            var $info = res.data;
112
            if ($info.keyWords) {
113
              $info.keyWords = strToArr($info.keyWords);
114
            }
105 115
            if ($info.modifyTime) {
106 116
              $info.modifyTime = commenTime($info.modifyTime, true)
107 117
            }

+ 1 - 1
src/pages/h5/views/Result/result.vue

@ -43,7 +43,7 @@
43 43
                </el-col>
44 44
                <el-col :span="24" v-if="patentInfo.keywords && patentInfo.keywords.length">
45 45
                  <el-row class="tag-item">
46
                    <el-tag v-for="sub in patentInfo.keywords" :key="sub.index">{{sub}}</el-tag>
46
                    <el-tag v-for="sub in patentInfo.keywords" :key="sub.index"><a :href="'h5.html#/search?n=5&k='+ sub">{{sub}}</a></el-tag>
47 47
                  </el-row>
48 48
                </el-col>
49 49
              </el-row>

+ 11 - 1
src/pages/h5/views/content/content.vue

@ -25,6 +25,13 @@
25 25
              <div class="content-uditor" v-html="contentInfo.cnt"></div>
26 26
            </div>
27 27
          </div>
28
          <div class="inner-wrapper">
29
            <div class="content">
30
              <el-row class="tag-item" v-if="contentInfo.keyWords && contentInfo.keyWords.length">
31
                <el-tag v-for="sub in contentInfo.keyWords" :key="sub.index"><a :href="'h5.html#/search?n=1&k='+ sub + '&c=' + contentInfo.catalog">{{sub}}</a></el-tag>
32
              </el-row>
33
            </div>
34
          </div>
28 35
          <div class="inner-wrapper" v-if="platExperts && platExperts.length">
29 36
            <div class="content-title">
30 37
              <span>相关专家</span>
@ -74,7 +81,7 @@
74 81
</template>
75 82
76 83
<script>
77
  import { urlParse, commenTime } from '@/libs/util';
84
  import { urlParse, commenTime, strToArr } from '@/libs/util';
78 85
  import queryBase from '@/libs/queryBase';
79 86
  import baseExpert from '@/components/subTemplate/BaseExpert';
80 87
  import baseOrg from '@/components/subTemplate/BaseOrg';
@ -139,6 +146,9 @@
139 146
        }, (res) => {
140 147
          if (res.success) {
141 148
            var $info = res.data;
149
            if ($info.keyWords) {
150
              $info.keyWords = strToArr($info.keyWords);
151
            }
142 152
            if ($info.modifyTime) {
143 153
              $info.modifyTime = commenTime($info.modifyTime, true)
144 154
            }

+ 1 - 1
src/pages/h5/views/resource/resource.vue

@ -41,7 +41,7 @@
41 41
              </el-col>
42 42
              <el-col class="rel-item" :span="24" v-if="resourceInfo.subject && resourceInfo.subject.length">
43 43
                <el-row class="tag-item">
44
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index">{{sub}}</el-tag>
44
                  <el-tag v-for="sub in resourceInfo.subject" :key="sub.index"><a :href="'h5.html#/search?n=4&k='+ sub">{{sub}}</a></el-tag>
45 45
                </el-row>
46 46
              </el-col>
47 47
            </el-row>

+ 84 - 17
src/pages/h5/views/search/scrollMore.vue

@ -1,20 +1,32 @@
1 1
<template lang="html">
2
 
3
    <div class="yo-scroll" @touchstart="touchStart($event)" ref="scrollBox"
4
         @touchmove="touchMove($event)" @touchend="touchEnd($event)" :style="{top: topVal+'px'}" v-loading="dataList.loading">
5
      <section class="inner" ref="contentBox">
6
        <!-- 使用时外面的标签会填在里面 -->
2
  <!-- <div class="swiper-container" ref="swiperContainer" :style="{top: topVal+'px;-webkit-overflow-scrolling: touch;'}" v-loading="dataList.loading">
3
    <div class="swiper-wrapper">
4
      <div class="swiper-slide" :style="'height:'+ slideH" ref="slideScroll">
7 5
        <slot>
8 6
        </slot>
9
        <!-- 保持加载更多条在最下面 -->
10
        <footer class="load-more">
11
          <slot name="load-more">
12
            <span>{{loadMoreText}}</span>
13
          </slot>
14
        </footer>
15
        <div class="nullData" v-show="dataList.noFlag">暂无更多数据</div>
16
      </section>
7
      </div>
17 8
    </div>
9
    <div class="load-more">
10
      <slot name="load-more">
11
        <span>{{loadMoreText}}</span>
12
      </slot>
13
    </div>
14
    <div class="nullData" v-show="dataList.noFlag">暂无更多数据</div>
15
    <div class="swiper-scrollbar" ref="scrollSwiper"></div>
16
  </div> -->
17
  <div class="yo-scroll" @touchstart="touchStart($event)" ref="scrollBox"
18
        @touchmove="touchMove($event)" @touchend="touchEnd($event)" :style="{top: topVal+'px'}" v-loading="dataList.loading">
19
    <section class="inner" ref="contentBox">
20
      <slot>
21
      </slot>
22
      <footer class="load-more">
23
        <slot name="load-more">
24
          <span>{{loadMoreText}}</span>
25
        </slot>
26
      </footer>
27
      <div class="nullData" v-show="dataList.noFlag">暂无更多数据</div>
28
    </section>
29
  </div>
18 30
</template>
19 31
<script>
20 32
export default {
@ -52,7 +64,64 @@ export default {
52 64
  mounted() {
53 65
    this.scrollBottomTest()
54 66
  },
67
  // mounted() {
68
  //   var that = this
69
  //   this.$nextTick(() => {
70
  //      that.setSlideHeight()
71
  //   });
72
  //   this.mySwiperScroll = new Swiper(that.$refs.swiperContainer, {
73
  //     direction: 'vertical',
74
  //     scrollbar: that.$refs.scrollSwiper,
75
  //     autoplay : 500,
76
  //     mode : 'vertical',
77
  //     slidesPerView: 'auto',
78
  //     mousewheelControl: true,
79
  //     freeMode: true,
80
  //     allowTouchMove: true,
81
  //     preventInteractionOnTransition: true,
82
  //     observer: true,
83
  //     on: {
84
  //       touchMove(e) {
85
  //         if (!that.enableLoadMore || that.dataList.noFlag || !that.touching) {
86
  //           return;
87
  //         }
88
  //         if (that.mySwiperScroll.translate === 0) {
89
  //           e.preventDefault();
90
  //         }
91
  //         that.loadMoreText = '上拉加载更多';
92
  //         that.$el.querySelector('.load-more').style.display = 'block';
93
  //       },
94
  //       touchEnd(swiper) {
95
  //         var _viewHeight = that.$refs.swiperContainer.offsetHeight;
96
  //         var _contentHeight = that.$refs.slideScroll.offsetHeight;
97
  //         // 上拉加载
98
  //         if(that.mySwiperScroll.translate <= _viewHeight - _contentHeight + that.topVal - 50
99
  //           && that.mySwiperScroll.translate < 0
100
  //           && !that.dataList.noFlag && !that.isLoading) {
101
  //           setTimeout(function() {
102
  //             that.doLoadMore()
103
  //             that.mySwiperScroll.update()
104
  //           }, 300);
105
  //         } else {
106
  //           let more = that.$el.querySelector('.load-more');
107
  //           more.style.display = 'none'; //隐藏加载条
108
  //         }
109
  //         if(that.mySwiperScroll.translate >= 50) {
110
  //           setTimeout(function() {
111
  //             //刷新操作
112
  //             that.mySwiperScroll.update(); // 重新计算高度;
113
  //           }, 1000);
114
  //         }else if(that.mySwiperScroll.translate >= 0 && that.mySwiperScroll.translate < 50){
115
116
  //         }
117
  //       }
118
  //     }
119
  //   });
120
  // },
55 121
  methods: {
122
    setSlideHeight() {
123
      this.slideH = window.innerHeight + 'px'
124
    },
56 125
    touchStart(e) {
57 126
      this.startY = e.targetTouches[0].pageY;
58 127
      this.startX = e.targetTouches[0].pageX;
@ -87,7 +156,6 @@ export default {
87 156
88 157
      //如果滑动距离太短
89 158
      if (Math.abs(dx) < 2 && Math.abs(dy) < 2) {
90
        // console.log("滑动距离太短")
91 159
        let more = this.$el.querySelector('.load-more');
92 160
        more.style.display = 'none'; //隐藏加载条
93 161
        return;
@ -103,7 +171,7 @@ export default {
103 171
        innerHeight = this.$el.querySelector('.inner').clientHeight,
104 172
        scrollTop = this.$el.scrollTop,
105 173
        bottom = innerHeight - outerHeight - scrollTop - 50;
106
      if (bottom <= this.offset && !this.dataList.noFlag) {
174
      if (bottom <= this.offset && !this.dataList.noFlag && !this.isLoading ) {
107 175
        //内容太少
108 176
        this.doLoadMore();
109 177
      } else {
@ -129,8 +197,7 @@ export default {
129 197
        var viewH = elbody.clientHeight, // 可视高度
130 198
          contentH = conbody.scrollHeight, // 内容高度
131 199
          scrollTop = elbody.scrollTop; // 滚动高度
132
        //if(contentH - viewH - scrollTop <= 100) { //到达底部100px时,加载新内容
133
        if (scrollTop / (contentH -viewH) >= 0.95 && !that.dataList.noFlag ) { //到达底部100px时,加载新内容
200
        if (scrollTop / (contentH -viewH) >= 1 && !that.dataList.noFlag && !that.dataList.loading && !that.isLoading ) { //到达底部时,加载新内容
134 201
          that.doLoadMore();
135 202
        }
136 203
      })

+ 27 - 14
src/pages/h5/views/search/search.vue

@ -29,7 +29,7 @@
29 29
        </div>
30 30
      </div>
31 31
    </div>
32
    <div class="swiper-container" :style="'height:'+ slideH" ref="scrollSwiper">
32
    <div class="swiper-container" ref="swiperMainCon" :style="'height:'+ slideH">
33 33
      <div class="swiper-wrapper" :style="'height:'+ slideH">
34 34
        <div class="swiper-slide swiper-Main-con" :style="'height:'+ slideH" v-for="tab in navList" :key="tab.tab">
35 35
          <v-scroll :onLoadMore="onLoadMore" :dataList="scrollData" :topVal="activeTab==='1'? '122' : '84'">
@ -200,11 +200,6 @@ export default {
200 200
      this.mySwiperTab.slideTo(num, 500, false)
201 201
      this.mySwiperMain.slideTo(parseInt(val) - 1, 500, false)
202 202
      this.clearToFun()
203
    },
204
    activeColumn(val) {
205
      this.contentList = []
206
      this.pageNo = 1
207
      this.contentListFun()
208 203
    }
209 204
  },
210 205
  created() {
@ -214,7 +209,10 @@ export default {
214 209
    if (urlParse('k')) {
215 210
      this.searchText = urlParse('k');
216 211
    }
217
    this.tabTofun()
212
    if (urlParse('c')) {
213
      this.activeColumn = urlParse('c');
214
    }
215
    this.clearToFun()
218 216
  },
219 217
  mounted() {
220 218
    var that = this
@ -231,7 +229,7 @@ export default {
231 229
      slidesPerView: 'auto',
232 230
      freeModeSticky: true
233 231
    });
234
    this.mySwiperMain = new Swiper(that.$refs.scrollSwiper,{
232
    this.mySwiperMain = new Swiper(that.$refs.swiperMainCon,{
235 233
      allowTouchMove: true,
236 234
      preventInteractionOnTransition: true,
237 235
      observer: true,
@ -252,6 +250,9 @@ export default {
252 250
    },
253 251
    slideChangedColumn(val) {
254 252
      this.activeColumn = val
253
      this.contentList = []
254
      this.pageNo = 1
255
      this.contentListFun()
255 256
    },
256 257
    clearToFun() {
257 258
      this.contentList = []
@ -273,6 +274,10 @@ export default {
273 274
        patId: ''
274 275
      }
275 276
      this.pageNo = 1
277
      this.scrollData = {
278
        noFlag: false,
279
        loading: false
280
      }
276 281
      this.tabTofun()
277 282
    },
278 283
    tabTofun() {
@ -295,18 +300,26 @@ export default {
295 300
    },
296 301
    onLoadMore(done) {
297 302
      var that = this
298
      this.pageNo++;
299
      setTimeout(() => {
300
        that.tabTofun()
301
        done();
302
      }, 300);
303
      console.log(111)
304
      console.log(that.scrollData.noFlag)
305
      console.log(that.scrollData.loading)
306
      if (!that.scrollData.noFlag) {
307
        console.log(222)
308
        setTimeout(() => {
309
          console.log(that.pageNo)
310
          that.pageNo++;
311
          console.log(that.pageNo)
312
          that.tabTofun()
313
          done();
314
        }, 10);
315
      }
303 316
    },
304 317
    contentListFun() {
305 318
      var that = this
306 319
      that.scrollData.loading = true
307 320
      that.scrollData.noFlag = false
308 321
      this.$axios.get('/ajax/article/pq', {
309
        title: that.searchText,
322
        key: that.searchText,
310 323
        catalog: that.activeColumn,
311 324
        published: 1,
312 325
        pageSize: that.rows,

+ 2 - 2
src/pages/h5/views/service/service.vue

@ -26,7 +26,7 @@
26 26
            </el-col>
27 27
            <el-col class="rel-item" :span="24" v-if="serveInfo.keywords && serveInfo.keywords.length">
28 28
              <el-row class="tag-item">
29
                <el-tag v-for="sub in serveInfo.keywords" :key="sub.index">{{sub}}</el-tag>
29
                <el-tag v-for="sub in serveInfo.keywords" :key="sub.index"><a :href="'h5.html#/search?n=3&k='+ sub">{{sub}}</a></el-tag>
30 30
              </el-row>
31 31
            </el-col>
32 32
          </el-row>
@ -39,7 +39,7 @@
39 39
            <div class="content content-nf">
40 40
              <baseService v-for="item in likeserves" :key="item.index" :itemSingle="item" :noBlank="true"></baseService>
41 41
            </div>
42
          </div>>
42
          </div>
43 43
        </div>
44 44
        <div class="content-wrapper" v-if="hotserves && hotserves.length">
45 45
          <div class="inner-wrapper">