Vue中使用mescroll.js实现下拉刷新

第一步:引入js和css文件

1 <link rel="stylesheet" href="static/mescroll/mescroll.min.css">
2 <script src="static/mescroll/mescroll.m.js"></script>

 

第二步:编写布局

 1 <template>
 2     <div id="homeWrapper">
 3         <div id="mescroll" class="mescroll">
 4             <div class="content">
 5                 <Index-home ref="indexhome"></Index-home>
 6                 <Water-forecast ref="waterforecast"></Water-forecast>
 7                 <Rainfall-forecast ref="rainfallforecast"></Rainfall-forecast>
 8                 <Rainfall-live ref="rainfalllive"></Rainfall-live>
 9                 <Station-details ref="stationdetails"></Station-details>
10             </div>
11         </div>
12 
13         <keep-alive>
14             <router-view></router-view>
15         </keep-alive>
16     </div>
17 </template>

 

第三步: 初始化Mescroll

 1 methods: {
 2                 _initMescroll() {
 3                         this.mescroll = new MeScroll("mescroll", { 
 4                         up: {
 5                             use: false 
 6                         },
 7                         down: {
 8                             auto: false,
 9                             callback: this.downCallback 
10                         }
11                     });
12                 },
13                 downCallback() {
14                     this.$refs.indexhome._getStation();
15                     this.$refs.indexhome._getRainRemind();
16                     this.$refs.indexhome._getWarningMsg();
17                     this.$refs.indexhome._hydroLiveWeatherData();
18                     this.$refs.indexhome._WeatherTo7dayData();
19                     this.$refs.indexhome.getwarningNumber();
20                     this.$refs.indexhome._newspaperTime();
21                     this.$refs.waterforecast.getpredictMore();
22                     this.$refs.rainfallforecast.ForecastAddupAreaRain();
23                     this.$refs.rainfallforecast.rainTo72HBy3Hdata();
24                     this.$refs.rainfallforecast.rainTo7DayBy6H();
25                     this.$refs.rainfalllive.get3DayRealrain();
26                     this.$refs.stationdetails.getStationData();    
27                     if(this.mescroll.endSuccess) {
28                         setTimeout(() => {
29                             this.mescroll.endSuccess();
30                         }, 1000)
31                         
32                     }else {
33                         setTimeout(() => {
34                             this.mescroll.endErr();
35                         }, 1000)
36                     }
37                 }
38         },

样式:外层用固定定位,内层用绝对定位

 1 <style lang="stylus" rel="stylesheet/stylus" scoped>
 2     #homeWrapper
 3         position: fixed
 4         top: 0;
 5         bottom: 0
 6         left: 0
 7         width: 100%
 8         background: url("bg_55.png");
 9         .mescroll
10             position: absolute
11             top: 0
12             left: 0
13             bottom: 2rem
14             height: auto          
15 </style>

 

第四步:遇到的问题:修改滚动条样式,可以在mescroll.min.css 中修改,

隐藏下拉出现的滚动条:

在reset.css中,

::-webkit-scrollbar {/*隐藏滚轮*/
  display: none;
}

 

posted @ 2018-04-05 19:50  Various  阅读(4841)  评论(0编辑  收藏  举报