首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在每次更改文本时强制UITextView滚动到顶部?

如何在每次更改文本时强制UITextView滚动到顶部?
EN

Stack Overflow用户
提问于 2009-08-05 16:12:03
回答 34查看 73.1K关注 0票数 103

好吧,我的UITextView出了点问题。这是问题所在:

我向UITextView中添加了一些文本。然后,用户双击以选择某些内容。然后,我更改了UITextView中的文本(编程方式同上),UITextView滚动到页面底部有光标的位置。

然而,这并不是用户点击的地方。无论用户在哪里单击,它都会滚动到UITextView的底部。

所以我的问题是:如何在每次更改文本时强制UITextView滚动到顶部?我试过contentOffsetscrollRangeToVisible。两者都不起作用。

如有任何建议,我们将不胜感激。

EN

回答 34

Stack Overflow用户

发布于 2010-04-01 11:02:02

代码语言:javascript
复制
UITextView*note;
[note setContentOffset:CGPointZero animated:YES];

这对我来说就够了。

Swift版本(在Xcode9.3上使用iOS 11的Swift 4.1 ):

代码语言:javascript
复制
note.setContentOffset(.zero, animated: true)
票数 153
EN

Stack Overflow用户

发布于 2015-03-02 09:19:59

如果有人在iOS 8中遇到这个问题,我发现只需设置UITextView's text属性,然后使用带有location:0length:0NSRange调用scrollRangeToVisible就可以了。我的文本视图是不可编辑的,并且我测试了可选择和不可选择(这两个设置都不会影响结果)。下面是一个Swift的例子:

代码语言:javascript
复制
myTextView.text = "Text that is long enough to scroll"
myTextView.scrollRangeToVisible(NSRange(location:0, length:0))
票数 70
EN

Stack Overflow用户

发布于 2015-07-24 05:13:07

这是我的解决方案。

代码语言:javascript
复制
    override func viewDidLoad() {
        textView.scrollEnabled = false
        textView.text = "your text"
    }

    override func viewDidAppear(animated: Bool) {
        textView.scrollEnabled = true
    }
票数 46
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1234242

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档