JS 开发问题:url.includes is not a function

  • 在 JavaScript 开发中,出现如下错误信息

    Uncaught TypeError: url.includes is not a function

问题原因
  • 这个错误是,尝试调用 url 的 includes 方法,但 url 不是一个字符串
问题复现
  1. 例如,url 是一个数字
js 复制代码
let url = 123;

if (url.includes("test")) {
    console.log("Found!");
} else {
    console.log("Not found!");
}
复制代码
# 输出结果

Uncaught TypeError: url.includes is not a function
...
  1. 例如,url 是一个对象
js 复制代码
let url = { href: "https://test.com" };

if (url.includes("test")) {
    console.log("Found!");
} else {
    console.log("Not found!");
}
复制代码
# 输出结果

Uncaught TypeError: url.includes is not a function
...
注意事项
  1. 如果 url 为 null,则会出现如下错误信息
js 复制代码
let url = null;

if (url.includes("test")) {
    console.log("Found!");
} else {
    console.log("Not found!");
}
复制代码
# 输出结果

Uncaught TypeError: Cannot read properties of null (reading 'includes')
...
  1. 如果 url 为 undefined,则会出现如下错误信息
js 复制代码
let url = undefined;

if (url.includes("test")) {
    console.log("Found!");
} else {
    console.log("Not found!");
}
复制代码
# 输出结果

Uncaught TypeError: Cannot read properties of undefined (reading 'includes')
...
处理策略
  1. 异常捕获处理
js 复制代码
try {
    let url = { href: "https://test.com" };

    if (url.includes("test")) {
        console.log("Found!");
    } else {
        console.log("Not found!");
    }
} catch (error) {
    console.log(error);
}
复制代码
# 输出结果

TypeError: url.includes is not a function
...
  1. 确保 url 是字符串
js 复制代码
let url = { href: "https://test.com" };

if (typeof url === "string" && url.includes("test")) {
    console.log("Found!");
} else {
    console.log("Not found!");
}
复制代码
# 输出结果

Not found!
相关推荐
2501_945425152 小时前
C++编译期字符串处理
开发语言·c++·算法
m0_733612212 小时前
模板编译期哈希计算
开发语言·c++·算法
weixin199701080162 小时前
义乌购商品详情页前端性能优化实战
前端·性能优化
汪啊汪2 小时前
Day 3:Hooks 原理
前端
阿蒙Amon2 小时前
C#常用类库-详解SqlSugar
开发语言·数据库·c#
汪啊汪2 小时前
Day 2:JSX 转换原理
前端
似水明俊德2 小时前
06-C#
开发语言·c++·算法·c#
学以智用2 小时前
Vue3 + Vue Router 4 完整示例(可直接运行)
前端·vue.js
云栖梦泽2 小时前
易语言开发从入门到精通:进阶篇·图形图像高级实战
开发语言