在使用JavaScript處理對象時,有時需要在代碼中做出條件性的判斷,以確保對象已經被正確創建並且存在。本篇文章將從多個方面對JS判斷對象是否存在做詳細闡述。
一、JS判斷對象是否存在屬性
我們可以使用以下代碼判斷一個對象是否具有某個屬性:
if (myObj.hasOwnProperty('myProp')) {
console.log('myProp exists in myObj');
} else {
console.log('myProp does not exist in myObj');
}
如果對象myObj中具有屬性myProp,則控制台將輸出“myProp exists in myObj”,否則將輸出“myProp does not exist in myObj”。
二、JS判斷是否為對象
我們可以使用以下代碼判斷一個變量是否為對象:
if (typeof myVar === 'object' && myVar !== null) {
console.log('myVar is an object');
} else {
console.log('myVar is not an object');
}
如果變量myVar是一個對象,則控制台將輸出“myVar is an object”,否則將輸出“myVar is not an object”。
三、JS判斷對象是否存在某個屬性
我們可以使用以下代碼判斷一個對象是否包含某個屬性:
if ('myProp' in myObj) {
console.log('myProp exists in myObj');
} else {
console.log('myProp does not exist in myObj');
}
如果對象myObj中具有屬性myProp,則控制台將輸出“myProp exists in myObj”,否則將輸出“myProp does not exist in myObj”。
四、JS判斷數據是否在對象中
我們可以使用以下代碼判斷一個值是否存在於一個對象中:
if (myValue in myObj) {
console.log(myValue + ' exists in myObj');
} else {
console.log(myValue + ' does not exist in myObj');
}
如果值myValue存在於對象myObj中,則控制台將輸出“myValue exists in myObj”,否則將輸出“myValue does not exist in myObj”。
五、JS判斷對象是否存在某個方法
我們可以使用以下代碼判斷一個對象是否具有某個方法:
if (typeof myObj.myMethod === 'function') {
console.log('myObj has a method called myMethod');
} else {
console.log('myObj does not have a method called myMethod');
}
如果對象myObj具有方法myMethod,則控制台將輸出“myObj has a method called myMethod”,否則將輸出“myObj does not have a method called myMethod”。
六、JS判斷兩個對象是否相等
我們可以使用以下代碼判斷兩個對象是否相等:
if (JSON.stringify(myObj1) === JSON.stringify(myObj2)) {
console.log('myObj1 and myObj2 are equal');
} else {
console.log('myObj1 and myObj2 are not equal');
}
如果對象myObj1與myObj2相等,則控制台將輸出“myObj1 and myObj2 are equal”,否則將輸出“myObj1 and myObj2 are not equal”。
七、JS判斷對象是否存在某個元素
我們可以使用以下代碼判斷一個對象是否包含某個元素:
if (myObj.indexOf(myValue) !== -1) {
console.log(myValue + ' exists in myObj');
} else {
console.log(myValue + ' does not exist in myObj');
}
如果對象myObj中存在元素myValue,則控制台將輸出“myValue exists in myObj”,否則將輸出“myValue does not exist in myObj”。
八、JS判斷對象中是否包含某個元素
我們可以使用以下代碼判斷一個對象中是否包含某個元素:
if (Object.values(myObj).indexOf(myValue) !== -1) {
console.log(myValue + ' exists in myObj');
} else {
console.log(myValue + ' does not exist in myObj');
}
如果對象myObj中存在元素myValue,則控制台將輸出“myValue exists in myObj”,否則將輸出“myValue does not exist in myObj”。
九、JS判斷對象是否為空
我們可以使用以下代碼判斷一個對象是否為空:
if (Object.keys(myObj).length === 0 && myObj.constructor === Object) {
console.log('myObj is empty');
} else {
console.log('myObj is not empty');
}
如果對象myObj為空,則控制台將輸出“myObj is empty”,否則將輸出“myObj is not empty”。
十、JS判斷數組對象是否重複選取
我們可以使用以下代碼判斷對象中的數組對象是否存在重複選取:
let myArray = myObj.myArray;
let myArraySet = new Set(myArray);
if (myArray.length !== myArraySet.size) {
console.log('myArray contains duplicate selections');
} else {
console.log('myArray does not contain duplicate selections');
}
如果myArray中存在重複選取,則控制台將輸出“myArray contains duplicate selections”,否則將輸出“myArray does not contain duplicate selections”。
原創文章,作者:AFXW,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/133691.html