Kung Fu Ninja
Kung Fu Ninja

Reputation: 3752

jquery array question

I have the following :

<script>
$().ready(function() {

 $("#myVal#").blur(function() {
   var arr = jQuery.makeArray(  $("#myArr").val() )
if ( $("#myVal").val().indexOf(arr) == -1 || $("#myVal").val().indexOf(arr) ==0) {
    arr.push($("#myVal").val());
}
$("#myArr").val(arr)
});
});
</script>
<form action="" method="post" name="myF" id="myF">
 <input type="text" name="myVal" id="myVal" value="">
 <input type="text" name="myArr" id="myArr" value="">
 <br/>
<input type="submit" name="submit" id="submit" value="go">
</form>

I am trying to check and see if a particular value entered to myVal is already in myArr. If so, don't add to the array. If not, then add to the array. However, the array keeps growing with duplicate values.

what am i doing wrong?

thanks in advance.

Upvotes: -1

Views: 134

Answers (4)

Kung Fu Ninja
Kung Fu Ninja

Reputation: 3752

this did the trick :

$().ready(function () {
     var arr = [];
     $("#myVal").blur(function () {
         if ($.inArray($('#myVal').val(), arr) == -1) {
             arr.push($("#myVal").val());
         }
         $("#myArr").val(arr);
     });
});

Upvotes: 0

Nick Craver
Nick Craver

Reputation: 630349

I believe what you're after is something like this using $.inArray():

$(function() {
 $("#myVal").blur(function() {
   var arr = $("#myArr").val().split(',');
   if ($.inArray($("#myVal").val(), arr) == -1) arr.push($("#myVal").val());
   $("#myArr").val(arr.join(','));
 });
});​

Try a demo here, now this would break if the value had a comma...just choose an appropriate delimiter. What this is going is taking the string out, calling .split() to turn it into an array, splitting the items at the provided delimiter, adding the value if it's missing ($.inArray() returns the postion of the element, -1 if it's not found). Then we're just calling .join() with the same delimiter to turn it back into a string.

Upvotes: 1

Matthew Flaschen
Matthew Flaschen

Reputation: 284786

First, makeArray is meant to take array-like objects as input, not strings. And I don't see the purpose here. If you have an actual array arr (perhaps made using split), you can do:

if ( $.inArray($("#myVal").val(), arr) == -1)

Your current code calls String.indexOf(arr), so arr is implicitly converted to a (comma-separated)string. Then you search for the array string in the new value. This is clearly not what you want.

Upvotes: 1

jigfox
jigfox

Reputation: 18185

try changing

 $("#myVal#").blur(function() {
         ^^^

with

 $("#myVal").blur(function() {
         ^^^

Upvotes: 2

Related Questions