浏览 2061 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-07-31
最后修改:2009-10-01
大概搜索了一下,解决方案多是用取得文档最大值的方法,譬如这个 this.textarea.addEventListener(FlexEvent.VALUE_COMMIT,onValueCommit); private function onValueCommit(event:FlexEvent):void{ this.textarea.verticalScrollPosition=this.textarea.maxVerticalScrollPosition; } 方法本身没有问题,但是实际效果并不好,主要在于忽视了flex是异步的这点,取到的maxVerticalScrollPosition并非实际数据刷新后的maxVerticalScrollPosition。 稍微改动一下,就可以达到目的。 private function init():void{ a.addEventListener(FlexEvent.UPDATE_COMPLETE,handleMessage); } private function handleMessage(event:Event):void { if (a.verticalScrollPosition < a.maxVerticalScrollPosition) { a.verticalScrollPosition = a.maxVerticalScrollPosition; } } 那有没有更简单的办法呢? 事实上可以不建立监听,利用ui组件的validateNow()函数让本来异步读取数据的flex看起来像是同步刷新的,譬如这样的代码 a.validateNow(); a.verticalScrollPosition = a.maxVerticalScrollPosition; 更加简单实现效果,推荐这种做法 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |