JavaScript 假值示例详解

JavaScript 假值有 :false、0、''、null、undefined、NaN

javascript 复制代码
// false- 布尔值假
if (false) {
        console.log("这行永远不会执行");
    } else {
        console.log("false 是假值,所以执行这里");
    }
    // 输出: "false 是假值,所以执行这里"

    // 0 值
    if (0) {
        console.log("这行永远不会执行");
    } else {
        console.log("0 是假值");
    }
    // 输出: "0 是假值"

    // 1. 空字符串
    if ('') {
        console.log("这行永远不会执行");
    } else {
        console.log("空字符串是假值");
    }
    // 输出: "空字符串是假值"

    // 1. 直接使用
    if (null) {
        console.log("这行永远不会执行");
    } else {
        console.log("null 是假值");
    }
    // 输出: "null 是假值"


    // 未初始化的变量
    let declaredButUndefined;
    if (declaredButUndefined) {
        console.log("这行永远不会执行");
    } else {
        console.log("undefined 是假值");
    }
    // 输出: "undefined 是假值"

    // NaN- 非数字
    if (NaN) {
        console.log("这行永远不会执行");
    } else {
        console.log("NaN 是假值");
    }
    // 输出: "NaN 是假值"

	// 3. 假值在实际应用中的处理
	function processUserInput(input) {
	    // 处理各种假值情况
	    if (!input) {
	        return "输入无效";
	    }
	    return `处理结果: ${input}`;
	}

    //null == undefined
    console.log(`null == undefined 值为:`);
    console.log(null == undefined); // 输出 true

注意 几个 "假值" 之间的比较,如下:

javascript 复制代码
// 使用双等号比较
console.log("\n双等号比较 (==):");
console.log(false == 0);        // true
console.log(false == '');       // true
console.log(0 == '');           // true
console.log(null == undefined); // true
console.log(NaN == NaN);        // false (特殊!)

// 使用三等号比较
console.log("\n三等号比较 (===):");
console.log(false === 0);        // false
console.log(false === '');       // false
console.log(0 === '');           // false
console.log(null === undefined); // false
console.log(NaN === NaN);        // false

有没有一种方法,只检查null与undefined了?

?? 是 JavaScript 中的逻辑运算符,用于检查左侧表达式是否为 null或 undefined,如果是,则返回右侧的值;否则返回左侧的值。

javascript 复制代码
// 只有当左侧是 null 或 undefined 时,才返回右侧
null ?? '默认值'       // 返回 '默认值'
undefined ?? '默认值'  // 返回 '默认值'

// 其他任何值(包括假值)都返回左侧
0 ?? 100              // 返回 0
false ?? true         // 返回 false
'' ?? '空字符串'      // 返回 ''
NaN ?? 10            // 返回 NaN
[] ?? '数组'         // 返回 []
{} ?? '对象'         // 返回 {}
相关推荐
SilentSamsara1 分钟前
高并发 API 压测与调优:locust + 火焰图 + 瓶颈定位
开发语言·python·青少年编程·docker·中间件
SoaringHeart2 分钟前
Flutter进阶|源码修改:DecorationImage 添加网络图片占位图
前端·flutter
myenjoy_14 分钟前
开源!Go+Wails+Vue3 手搓一个 PLC 实时监控桌面工具
开发语言·golang·开源
小新1107 分钟前
vue 实战项目 天气查询
前端·javascript·vue.js
Flash.kkl7 分钟前
C++基于websocketpp的多用户网页五子棋项目
开发语言·网络·数据库·c++·websocket·mysql
7yue7 分钟前
用 TypScript 学习 Claude Code
前端·typescript·claude
酉鬼女又兒8 分钟前
零基础入门计算机网络物理层:核心概念、传输媒体、传输方式、编码调制与信道极限容量完整知识点总结
开发语言·网络·计算机网络·考研·职场和发展·php·信息与通信
Rain5098 分钟前
实战:搭建 AI Code Review 自动化流水线
前端·人工智能·git·ci/cd·自动化·ai编程·代码复审
竹林8189 分钟前
用 wagmi v2 + viem 监听合约事件踩坑实录:从轮询到实时推送,我终于搞懂了
javascript