web-dev-qa-db-fra.com

jQuery: vérifier si la valeur d'un champ est null (vide)

Est-ce un bon moyen de vérifier si la valeur d'un champ est null?

if($('#person_data[document_type]').value() != 'NULL'){}

Ou y a-t-il un meilleur moyen?

84
ziiweb

La valeur d'un champ ne peut pas être null, c'est toujours une valeur de chaîne.

Le code vérifiera si la valeur de la chaîne est la chaîne "NULL". Vous voulez vérifier si c'est une chaîne vide à la place:

if ($('#person_data[document_type]').val() != ''){}

ou:

if ($('#person_data[document_type]').val().length != 0){}

Si vous voulez vérifier si l'élément existe, vous devriez le faire avant d'appeler val:

var $d = $('#person_data[document_type]');
if ($d.length != 0) {
  if ($d.val().length != 0 ) {...}
}
142
Guffa

Je voudrais aussi couper le champ de saisie, car un espace pourrait le faire sembler rempli

if ($.trim($('#person_data[document_type]').val()) != '')
{

}
36
Flipke

En supposant

var val = $('#person_data[document_type]').value();

vous avez ces cas:

val === 'NULL';  // actual value is a string with content "NULL"
val === '';      // actual value is an empty string
val === null;    // actual value is null (absence of any value)

Alors, utilisez ce dont vous avez besoin.

11
darioo

cela dépend du type d’information que vous transmettez au conditionnel.

parfois, votre résultat sera null ou undefined ou '' ou 0, pour ma simple validation, je l'utilise si.

( $('#id').val() == '0' || $('#id').val() == '' || $('#id').val() == 'undefined' || $('#id').val() == null )

NOTE: null! = 'null'

10
_helpers: {
        //Check is string null or empty
        isStringNullOrEmpty: function (val) {
            switch (val) {
                case "":
                case 0:
                case "0":
                case null:
                case false:
                case undefined:
                case typeof this === 'undefined':
                    return true;
                default: return false;
            }
        },

        //Check is string null or whitespace
        isStringNullOrWhiteSpace: function (val) {
            return this.isStringNullOrEmpty(val) || val.replace(/\s/g, "") === '';
        },

        //If string is null or empty then return Null or else original value
        nullIfStringNullOrEmpty: function (val) {
            if (this.isStringNullOrEmpty(val)) {
                return null;
            }
            return val;
        }
    },

Utilisez cette aide pour y parvenir.

5
Nilesh Moradiya

Essayer

if( this["person_data[document_type]"].value != '') { 
  console.log('not empty');
}
<input id="person_data[document_type]" value="test" />
0
Kamil Kiełczewski

jquery fournit les fonctions val() et not value(). Vous pouvez vérifier la chaîne vide en utilisant jquery

if($('#person_data[document_type]').val() != ''){}
0
Chinmayee G