国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Js判斷參數(shù)(String,Array,Object)是否為undefined或者值為空

2024-05-06 15:54:04
字體:
來源:轉載
供稿:網友
在一些前端控件要提交數(shù)據(jù)到服務器端的數(shù)據(jù)驗證過程中,需要判斷提交的數(shù)據(jù)是否為空。如果是普通表單的字符串數(shù)據(jù),只需要在 trim 后判斷 length 即可,而這里需要的數(shù)據(jù)可以是各種不同的類型,通過 JSON.stringify(data) 進行序列化后再傳遞

有時候我們會遇到這樣的情況:在一些前端控件要提交數(shù)據(jù)到服務器端的數(shù)據(jù)驗證過程中,需要判斷提交的數(shù)據(jù)是否為空。如果是普通表單的字符串數(shù)據(jù),只需要在 trim 后判斷 length 即可,而這里需要的數(shù)據(jù)可以是各種不同的類型(數(shù)字、字符串、數(shù)組、對象等等),通過 JSON.stringify(data) 進行序列化后再傳遞。

在這里定義如下的數(shù)據(jù)值為“空值”:

•undefined
•null
•空字符串及純空白字符串:''、'    ' 等。
•空數(shù)組:[]
•空對象:{}

對于除此以外的數(shù)據(jù)值,均認為不為空。

其中 null 和 undefined 很容易識別,但對于其他類型,我們須要得到其數(shù)據(jù)類型才能用相應的方法去檢測數(shù)據(jù)是否為空。最容易想到的方法就是利用typeof 操作符:

復制代碼 代碼如下:


<SPAN>if(typeof data === 'number') {
  //deal with numbers
}</SPAN>


但 typeof 返回的類型字符串只有 'object'、'function'、'number'、'boolean'、'string'、'undefined' 這六種,很多原生對象如 Date、RegExp 對象無法與用 {} 創(chuàng)建的對象進行區(qū)分。另外,typeof 對于一些基本數(shù)據(jù)類型如 (String、Number、Boolean) 與其對應的基本包裝類型數(shù)據(jù)會分別返回不同值,如:

復制代碼 代碼如下:


<SPAN>console.log(typeof false); //'boolean'
console.log(typeof new Boolean(false)); //'object'
console.log(typeof 1); //'number'
console.log(typeof new Number(1)); //'object'
console.log(typeof ''); //'string'
console.log(typeof new String('')); //'object'</SPAN>


這對我們的判斷也有一定的影響。

用 instanceof?這只能判斷對象,而且存在多 frame 時多個同類對象不共享 prototype 的問題,從其他 frame 中取得的對象無法正確判斷。

還好,還有一個最簡單也最可靠的方法:Object.prototype.toString。對于不同類型的數(shù)據(jù),這個方法可以返回 '[object Object]'、'[object Array]'、'[object String]' 這樣的字符串,非常方便判斷。需要注意的是,在 IE8 及其以下瀏覽器中,這個方法對于null、undefined、window 等都會返回 '[object Object]',不過還好,這并不影響我們使用它判斷空對象。

下面直接上代碼,說明就看注釋吧。

復制代碼 代碼如下:


var isEmptyValue = function(value) {

            var type;
            if(value == null) { // 等同于 value === undefined || value === null
                return true;
            }
            type = Object.prototype.toString.call(value).slice(8, -1);
            switch(type) {
            case 'String':
                return !$.trim(value);
            case 'Array':
                return !value.length;
            case 'Object':
                return $.isEmptyObject(value); // 普通對象使用 for...in 判斷,有 key 即為 false
            default:
                return false; // 其他對象均視作非空
            }
        };

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 兰考县| 南宫市| 黑山县| 澎湖县| 乃东县| 合肥市| 大名县| 武城县| 江永县| 南乐县| 金阳县| 迭部县| 阿图什市| 双城市| 安吉县| 鱼台县| 临武县| 庆城县| 白山市| 赤壁市| 砚山县| 赣榆县| 崇文区| 津南区| 龙海市| 碌曲县| 电白县| 金坛市| 奉化市| 余姚市| 威远县| 沾益县| 铜陵市| 班玛县| 桃园市| 纳雍县| 英吉沙县| 古交市| 南和县| 临湘市| 清水河县|