添加如下service:
angular.module('YourApp').service('utilities', function() {this.triggerScrollViewPullToRefresh = function (scrollView) {
scrollView.__publish(
scrollView.__scrollLeft, -scrollView.__refreshHeight,
scrollView.__zoomLevel, true) var d = new Date()
scrollView.refreshStartTime = d.getTime()
scrollView.__refreshActive = true
scrollView.__refreshHidden = false if (scrollView.__refreshShow) {
scrollView.__refreshShow()
}if (scrollView.__refreshActivate) {
scrollView.__refreshActivate()
}if (scrollView.__refreshStart) {
scrollView.__refreshStart()
}
}
})
然后在你的controller里添加方法:
angular.module('YourApp').controller('YourController', function($scope, $ionicScrollDelegate, utilities) {
$scope.someFunc = function() { // scrollerHandle should be the delegate-handle set on the scrollview
$scope.scrollDelegate = $ionicScrollDelegate.$getByHandle('scrollerHandle')
utilities.triggerScrollViewPullToRefresh($scope.scrollDelegate.getScrollView())
}
})
只要在你想触发的地方调用$scope.someFunc 就可以触发下拉刷新
html通过iframe把2.html加载进来,然后通过iframe.contentWindow.A()就可以; 1、必须两个页面在同一个域。 2、将两个页面的js拿出来,保存为a.js。 3、在两个页面里都引用这个a.js,那么里面的函数在两个页面里都能使用了。注意事项:1、XListView因为添加了Header,会导致存储的数据+1,所以赋值时需要position-1。补充:当去掉HeaderView时,position不用-1。2、提个建议:上拉加载,最好在onCreate()中就执行setAdapter,然后不论是空数据、还是有数据,只用更新适配器就行了。一、XListView1、下载gitHub的地址。或者从这儿下。2、用法导入图中的me.maxwin.view包提供了两个接口:IXListViewListener:触发下拉刷新,上拉加载。实现此接口时,onLoadMore()用来上拉加载,onRefresh()用来下拉刷新。OnXScrollListener:和原生的OnScrollListener一样,但是在header/footer回滚时也会触发。几个常用方法:setPullRefreshEnable(booleanenable):是否允许下拉刷新setPullLoadEnable(booleanenable):是否允许上拉加载stopRefresh():停止刷新,重置headerviewstopLoadMore():停止加载,重置footerview请求到数据后停止刷新停止加载。setRefreshTime(Stringtime):设置上次刷新的时间onLoadMore():加载时调用的方法。注意第一次进入时不会调用此方法。onRefresh():下拉刷新时调用的方法。3、代码中怎么体现1)实现IXListViewListener接口->2)实现上拉刷新和下拉加载的数据变更->3)更新headerview和footerview,并设置更新时间。[java]viewplaincopy//1、实现IXListViewListener接口mListView.setXListViewListener(this)//2.1onRefresh中实现下拉刷新的数据加载@OverridepublicvoidonRefresh(){//请求数据//更新界面显示[java]viewplaincopyonLoad()}//2.2onLoadMore中实现上拉加载的数据加载[java]viewplaincopy@OverridepublicvoidonLoadMore(){//请求数据//更新界面显示[java]viewplaincopyonLoad()}//3、加载完数据后,复位headerview和footerview,并设置更新的时间。[java]viewplaincopyprivatevoidonLoad(){mListView.stopRefresh()mListView.stopLoadMore()mListView.setRefreshTime("刚刚")}4、xml注意事项当将XListView嵌入到LinearLayout中时,XListView占满全屏时不能再加载。上错误代码:[java]viewplaincopy5、去ScrollView共用这种情况,重写XListView会导致上拉加载时频繁的报错:适配器未更新,不知道咋解决。二、PullToRefresh大部分内容转自鸿洋的博客:这里写上拉加载的任务newGetDataTask().execute()}})3、属性介绍1)ptr:ptrMode="both"支持上拉加载和下拉刷新。disabled禁用下拉刷新和上拉加载。pullFromEnd仅支持上拉加载。manualOnly只允许手动触发。当然通过代码也可设置:lv.setMode(Mode.BOTH)2)ptr:trAnimationStyle="flip"flip:翻转动画;rotate:旋转动画。3)ptr:ptrDrawable="@drawable/ic_launcher"设置图标4)ptrScrollingWhileRefreshingEnabled刷新的时候,是否允许ListView或GridView滚动。觉得为true比较好。5)ptrListViewExtrasEnabled决定了Header,Footer以何种方式加入mPullRefreshListView,true为headView方式加入,就是滚动时刷新头部会一起滚动。4、自定义下拉指示器文本内容等效果:在初始化完成PullToRefreshListView后,通过lv.getLoadingLayoutProxy()可得到一个ILoadingLayout对象,这个对象可设置各种指示器中的样式、文本等。[java]viewplaincopyILoadingLayoutstartLabels=mPullRefreshListView.getLoadingLayoutProxy()startLabels.setPullLabel("你可劲拉,拉")//刚下拉时,显示的提示startLabels.setRefreshingLabel("好嘞,正在刷新")//刷新时startLabels.setReleaseLabel("你敢放,我就敢刷新")//下来达到一定距离时,显示的提示默认是上拉和下拉的字同时改变的,如果希望单独改变呢:[java]viewplaincopyprivatevoidinitIndicator(){ILoadingLayoutstartLabels=mPullRefreshListView.getLoadingLayoutProxy(true,false)startLabels.setPullLabel("你可劲拉,拉")//刚下拉时,显示的提示startLabels.setRefreshingLabel("好嘞,正在刷新")//刷新时startLabels.setReleaseLabel("你敢放,我就敢刷新")//下来达到一定距离时,显示的提示ILoadingLayoutendLabels=mPullRefreshListView.getLoadingLayoutProxy(false,true)endLabels.setPullLabel("你可劲拉,拉2")//刚下拉时,显示的提示endLabels.setRefreshingLabel("好嘞,正在刷新2")//刷新时endLabels.setReleaseLabel("你敢放,我就敢刷新2")//下来达到一定距离时,显示的提示}欢迎分享,转载请注明来源:内存溢出
评论列表(0条)