Разница между BeanFactory и ApplicationContext:
Интерфейсы org.springframework.beans.factory.BeanFactory и org.springframework.context.ApplicationContext действуют как контейнер IoC. Интерфейс ApplicationContext построен поверх интерфейса BeanFactory. Он добавляет некоторые дополнительные функции, чем BeanFactory, такие как простая интеграция с AOP Spring, обработка ресурсов сообщений (для I18N), распространение событий, контекст специфического уровня приложения (например, WebApplicationContext) для веб-приложения. Поэтому лучше использовать ApplicationContext, чем BeanFactory.
textView.editable = YES;
textView.selectedRange = NSMakeRange(2, 0);
Установите selectedRange в местоположение с длиной 0, и вы, вероятно, также хотите, чтобы textView был редактируемым, поэтому также установите его в YES.
Я знаю, что это ОЧЕНЬ поздно, но я думал, что смогу помочь людям, застрявшим в этом (как я).
performSelector:withObject:afterDelay
, кажется, работает нормально (другие ответы просто не будут работать по какой-то странной причине):
- (void)textViewDidBeginEditing:(UITextView *)inView
{
[self performSelector:@selector(setCursorToBeginning:) withObject:inView afterDelay:0.01];
}
- (void)setCursorToBeginning:(UITextView *)inView
{
//you can change first parameter in NSMakeRange to wherever you want the cursor to move
inView.selectedRange = NSMakeRange(3, 0);
}
источник: http://puppenspieler.tumblr.com/ запись / 757819650 / компл-selectedrange-в-UITextView
Если вы хотите, чтобы Textview был обязательным или необязательным, как я. Смотрите мой хак
func textViewDidBeginEditing(textView: UITextView) {
if textView.text.isEmpty {
if self.text == "Required" || self.text == "Optional" {
dispatch_async(dispatch_get_main_queue(), {
textView.selectedRange = NSMakeRange(0, 0)
});
}
}
}
func textViewDidEndEditing(textView: UITextView) {
if CommonUtils.isEmptyString(textView.text) {
if required {
textView.text = "Required"
} else {
textView.text = "Optional"
}
textView.textColor = grayColor//
}
}
func textViewDidChange(textView: UITextView) {
if textView.text.isEmpty {
if required {
textView.text = "Required"
} else {
textView.text = "Optional"
}
textView.textColor = grayColor
textView.selectedRange = NSMakeRange(0, 0)
} else {
if required {
if textView.text.length > "Required".length {
textView.text = self.text.replace("Required", withString: "")
}
} else {
if textView.text.length > "Optional".length {
textView.text = self.text.replace("Optional", withString: "")
}
}
textView.textColor = blackColor//
}
}
Не забудьте зарегистрировать делегата: UITextViewDelegate
Я использую следующее, чтобы перейти к началу textView, используя Swift 4 :
DispatchQueue.main.async {
self.selectedTextRange = self.textRange(from: self.beginningOfDocument, to: self.beginningOfDocument)
}
Попробуйте что-то вроде этого:
dispatch_async(dispatch_get_main_queue(), ^{
inView.selectedRange = NSMakeRange(3, 0);
});
Это приведет к выполнению selectedRange в главном потоке в начале следующего цикла выполнения.
изменить selectedRange
вашего textView. например, чтобы поместить курсор в положение 3:
[textView setSelectedRange:NSMakeRange(3, 0)];
В вашем случае добавление некоторых пробелов в текстовое содержимое может помочь. и наблюдатель textview
's textDidChanged event
для предотвращения этих мест будет удален пользователем.