Skip to content Skip to sidebar Skip to footer

Change Input Value Based On Another Input's Value

hope that title makes sense. I'm a noob at javascript. What I want to do is have a form which will have a couple of inputs like, name and url for example. When the user enters the

Solution 1:

You'd probably want to do this in JavaScript and not in PHP. Even though you may be more familiar with the latter, the user experience would be better with the former and the overall design simpler (since the page wouldn't need to refresh).

You essentially need to do two things:

  1. Set the value of an input in response to an event on another input.
  2. Replace space characters with underscore characters.

For the second part, take a look at JavaScript's replace function. It's pretty robust and lets you do a lot of string manipulation. Definitely worth trying it out yourself.

For the first part, here's an example with jQuery:

$('#inputName').change(function() {
  $('#inputURL').val($('#inputName').val());
});

This would set the value of inputURL to the value of inputName any time the value of inputName changes. For the string replacement, you'd modify it similar to this:

$('#inputName').change(function() {
  $('#inputURL').val($('#inputName').val().replace(' ', '_'));
});

Note that the change event will be fired when the control loses focus. If you want to to happen as-you-type then try the keyup event. There are other events as well.

Solution 2:

Add a keyup event to the name field that will update the url field:

<form>
    <input type="text"id="name" />
    <input type="text"id="url" />
</form>

...and the js:

addEvent(document.getElementById('name'), 'keyup', function () {
   document.getElementById('url').value = this.value.replace(' ', '_');
});


functionaddEvent(ele, evnt, funct) {
  if (ele.addEventListener) // W3Creturn ele.addEventListener(evnt,funct,false);
  elseif (ele.attachEvent)  // IEreturn ele.attachEvent("on"+evnt,funct);
}

http://jsfiddle.net/XKEh5/

If you're only going to do some trivial stuff like this, then you'll be fine with plain old javascript. If you're going to be doing a lot of this sort of thing, plus any effects like fading out elements or whatnot, I suggest you look in to mootools or jQuery.

Solution 3:

Here is an edited version of the above answer. There was an issue with the "value.replace(' ', '_');" where it would only take the space out between the first two words typed in. This code snippet below does it for all.

<scriptlanguage="javascript"type="text/javascript">addEvent(document.getElementById('name'), 'keyup', function () {    
   document.getElementById('url').value = this.value.split(' ').join('');    
});    

functionaddEvent(ele, evnt, funct) {

  if (ele.addEventListener) // W3C    return ele.addEventListener(evnt,funct,false);

  elseif (ele.attachEvent)  // IE    return ele.attachEvent("on"+evnt,funct);

}

</script>

Post a Comment for "Change Input Value Based On Another Input's Value"