-
Notifications
You must be signed in to change notification settings - Fork 27.5k
ng-model is not updated immediately in Chrome WebView or Browser #5308
Comments
Do you think this is related to #5298 @davgothic? It doesn't look like it should be as it's not preventing default, but even so it's something to look at I guess (it's possible the browser compositionstarts regardless of IME) --- Yeah, it shouldn't matter WRT the other issue, but it's still interesting. |
Yeah, they are separate issues certainly (which is too bad, it would be easier to fix just one!) Do you have any idea how we can get around this for languages/IMEs that don’t really “need” composition events? It seems like not a good idea Caitlin Potter On Dec 6, 2013, at 10:17 AM, David Hancock [email protected] wrote:
|
So, I'm not sure there is anything we can do about this :( Based on https://code.google.com/p/chromium/issues/detail?id=118639, it looks like we're pretty much at the mercy of what a given IME decides to tell us, and have no ability to detect a specific IME and change our behaviour in response. I'm not sure what the right approach is, is an app usable at all on Android with this issue? Like, do you see the model updated just late? It might be the most sensible approach to just hope that IME vendors fix their bugs, rather than choosing to break apps which make use of them totally. |
Quick update: I tried to reproduce this with Android Emulator and Chrome Shell, but it worked well. Sorry, but this won't make it into the release today, but hopefully into the release next week. |
I confirm the same problem (Samsung S4 / Chrome / Android 4.2.2): Angular 1.2.3 has the problem |
We know the cause, it's because we're not updating the model until we get Like, that's kind of a hard call to make, it seems like this should probably be dealt with elsewhere (eg in Android / 3rd party IMEs). I'm not totally convinced it makes sense to roll back. What else can we do.. Set a timeout after the If you have any ideas of how to deal with this from within angular in a fair and balanced way, I'd love to hear it. But I'm not so sure such a way exists |
Hi caipt... I think it's very important find a way to fix it because now it's impossible update stuff while using an Android mobile keyboard and it'is unacceptable :( If you don't want to remove the feature might you give us a little patch that we can include in our projects? Thanks in advance |
I've personally been experiencing this behaviour on web apps (which aren't angular-based, such as github) on my android phone for ages now, and this is actually the closest I've come to really explaining why it happens! kind of funny. I don't know, I don't like the idea of hurting people with CJK requirements or anything, but I agree that it's not really a good thing. It's just that there probably isn't much we can do about it from within Angular while still supporting complex IMEs |
Hi @clkao, |
@caitp Thanks for the PR and it seems to work fine!
The problem that #4684 solved when adapted to this procedure is: after pressing the left/right key to select an accent, the scope value changed and e.g. a bound filter for a repeater got updated before the right accent was chosen with the enter key. However, the model value should not change until the correct accent was chosen. Your PR does not break the fixed behavior of #4684, so I will merge it. |
Cool --- yeah it's working well for me with Swype on Nexus too, so just hopefully it doesn't break any internationalization features, since I think it's only really been tested with latin IMEs Sounds good |
Just got my Nexus 5 and tested on the device. I see the problem now: Chrome does auto correction of things that are typed. It fires a So even with the PR from @caitp the scope value is not updated until the end of the word! So if we want to have updates on every key press we need something else... Need to think a bit more about this... |
hmm, I'm actually not seeing that on my device with swype, the model seems to update as soon as the gesture is complete, whether it's a single tap or a short thing like "js". But that's a bit bothersome We could try and update the model on compositionupdate, but that seems like a bad idea. On the other hand, is waiting for a complete word really that bad? Since it's mobile, fewer digests might be for the best |
@tbosch I am all for the more customizable #2129, but sadly that is a more complicated change and is scheduled for 1.3.x The issue here is: mobile input correction being compositions but immediate updates are desired. However it's probably still unwanted intermediate changes for CJK IME. I think a good compromise is that we still send out updates for ascii characters even during composition (on keypress event), so it works as desired for all cases without configuration. This should be a relatively small change, what do people think? |
But there may be auto completion for Chinese in Chrome for Android as Sent from my iPhone On Dec 17, 2013, at 9:24 PM, Chia-liang Kao [email protected] @tbosch https://github.com/tbosch I am all for the more customizable The issue here is: mobile input correction being compositions but immediate This should be a relatively small change, what do people think? — |
It seems the mobile browsers and individual IME vary quite a lot. On my android 4.1 mobilesafari does no composition event at all for cjk input and english auto-correction, and chrome for android sends out compositionend whenever autocomplete results are chosen for CJK. Another way until #2129 is is to completely disable this on android (just need to make $sniffer export the android var) |
Workaround for chrome for android until angular#2129 is ready. Closes angular#5308, angular#5323
I'm not sure I like the idea of requiring ng-model-update-on="comma-separated-list-of-events" for this, because you'd need this for generally every input if you wanted to support some particular phone, and that just seems awful. I think @clkao's sniffer approach is better (although, it should probably also sniff the version of Webkit/Blink, as I've said before this bug was not reproducible at all for me on 534), and just hope that future IMEs do a better job of reporting compositionend appropriately. Or alternatively, it could be decided that model updates on autocomplete are not that bad, as this means fewer digest cycles on low-powered devices. |
Just a side note: checking the characters does not help in this case. When using a Chinese locale on a US keyboard we only get normal us characters until the |
@tbosch actually, in real browsers during composition you get keycode 229 on keydown and then the ascii keycode on keyup, which is what you referred to. Sadly both events send out keycode 0 on N5 chrome for (tested by @walkingice earlier today) So this really comes down to what @caitp said about autocomplete (or auto-correction) and model updates. And in this case, based on the use of the API, the new builtin text service on android or chrome for android seem to decide that incomplete english texts aren't intended values. |
Ok, thought about it a lot and I agree with @clkao that we should just disable this for Android. I double checked for iOS and it does not fire composition events for word completion suggestions. To summarize:
Any vetos? |
Not necessarily a veto, BUT @clkao was saying on IRC earlier that there would be unintended data in the buffer/model value prior to #4684, so I'm not sure it's necessarily a good call to ignore this on Android (unless @clkao can confirm that this actually doesn't have this effect in the case of Android + Chrome) |
Ok, let's do it. I took the PR from @clkao and added a missing test. Will merge when ci is green... |
Workaround for chrome for android until angular#2129 is ready. Closes angular#5308, angular#5323
Workaround for chrome for android until angular#2129 is ready. Closes angular#5308, angular#5323
Hi @rodrigozrusso, could you create a new issue? |
@rodrigozrusso It'd be great if you can also bisect the commit causing the regression and put it in the new issue. |
I had the same issue that the title of this issue & description says:
I was a little confused after reading this thread on how introducing Failed experiment using ng-model-optionsI tried using <!-- someInput.html -->
<!-- Before -->
<input ng-model="someInput" />
<!-- After -->
<input ng-model="someInput" ng-model-options="{updateOn: 'keyup'}" /> My logic was maybe ng-model is not relying on the SolutionI ended up adding an extra <!-- someInput.html -->
<!-- Before -->
<input ng-model="someInput" />
<!-- After -->
<input ng-model="someInput" ng-keyup="updateSomeInput($event)" /> /*
SomeInputController.js
Note: don't pass the angular's form element to this function, as it won't have the updated value
*/
$scope.updateSomeInput = function(event) {
// manually updating the model here
$scope.someInput = event.target.value;
}; Hope it helps for people looking for the similar issue, Please let me know if there is a better solution. |
On Android 4.4 (KitKat) using both the Chrome WebView (v30) and the Chrome Browser (v31.0.1650.59) an input with an
ng-model
is not updating the variable value until the focus leaves the input.The following commit for version 1.2.2 is responsible for this bug:
If I revert that commit in angular 1.2.3 or revert to angular 1.2.1 the problem goes away.
Here is a demo of the problem:
http://plnkr.co/edit/ZcksakM9icREgxe38Pnf?p=preview
The text was updated successfully, but these errors were encountered: