Can be used on Applications in order to execute some code while the end user is entering input data. Its aim is giving constant feedback to the user (e.g. UI effects).
Any variable or attribute control that is on a layout as an editable field (see Scope section). The value of this control will be the value before the change.
A variable with the same type as VarOrAtt. Its value will be the next value that will have the VarOrAtt once it has been changed.
The code that will be executed when the event triggers (it is like any other User Event in Smart Devices).
Suppose a chat scenario where we have a button for recording while a text field is empty. If the end user starts writing on the field, the button will change for sending the message. This effect can be done very simply by adding the ControlValueChanging event in the following way.
First, we design the chat panel properly.
Then, we write the following event associated with the text-field.
&MessageLen = &vMessageNew.Length()
SendButton.Visible = &MessageLen > 0
RecButton.Visible = &MessageLen = 0
Note that there is no need for checking the value of &vMessage (which in this context is a control, not a variable), we only check the &vMessageNew variable value.
There are a lot of scenarios that can be resolved by using this event. For example, making an automatic validation of a field once a complete sequence of tokens is inserted (and if it is ok, for example, setting the focus in the next field).
The event not only detects when the user is typing in the text field but also detects when the user pastes some content from the clipboard or deletes some selected text. In the example exposed, use Length method or IsEmpty method will have the same behavior. But, if the developer wants to operate depending on the difference of at least one character, the first option is better. A simple usage example is for updating how many characters left to fulfill a message. In such case, will only we to add a single line to the above code as follows and take some actions with that value.
&HowManyLeft = 256 - &MessageLen
- Remember that VarOrAtt refers to a control, consequently, its value won't be accessible until the user ends editing (and the ControlValueChanged event will be triggered).
- If the field value is changed programmatically (i.e. by coding), the ControlValueChanging event is not going to be executed (e.g. multiple assignations of the same variable on another User event).
- Android does not differentiate the values of VarOrAtt and &newVarOrAtt, both will be the same.
- in Web, parameter &newVarOrAtt is ignored.
||Attribute control, Variable control
||Numeric, Character, VarChar, LongVarChar
||Smart Devices, Web
This feature is available as of GeneXus 15 Upgrade 5 in iOS and Android, and as of GeneXus 15 Upgrade 6 in Web too.