js 判断字符串中是否包含某个字符串的实现代码
indexOf方法
根据国外大神的测试结果显示,indexOf在速度上可能是最快的,因此推荐大家在日常中还是经常使用indexOf这个方法。
ES5或者更老版本
String.prototype.indexOf方法用来返回一个字符串在另一个字符串中的位置,如果没找到那就返回 -1 。
代码如下:
var string = "foo", substring = "oo"; string.indexOf(substring) !== -1;//true
如果大量使用可以定义一个函数,方便调用
function instr(str, find) { if (str.indexOf(find) != -1) { return 1; } else { return 0; } }
string.lastIndexOf()
和indexOf()的区别,从字符串的尾部开始查找
返回值:匹配成功的第一个字符的下标,未匹配则返回-1
用法:string.indexOf(searchValue, start)
let searchVal = 'yyds' let searchResult = searchVal.lastIndexOf('y') console.log(searchResult) // 1
ES6 includes 方法
返回值:Boolean
用法: string.includes(searchValue, start) 第二个参数从是指定下标开始查找
兼容补丁(polyfill)
if (!String.prototype.includes) { String.prototype.includes = function(search, start) { 'use strict'; if (typeof start !== 'number') { start = 0; } if (start + search.length > this.length) { return false; } else { return this.indexOf(search, start) !== -1; } }; }
示例
var str = 'To be, or not to be, that is the question.'; console.log(str.includes('To be')); // true console.log(str.includes('question')); // true console.log(str.includes('nonexistent')); // false console.log(str.includes('To be', 1)); // false console.log(str.includes('TO BE')); // false
当包含时返回true,不包含时返回false,代码实例如下:
var string = "foo"; var substring1 = "oo"; var substring2 = "oq"; string.includes(substring1); //true string.includes(substring2); //false
let searchVal = 'yyds' let searchResult = searchVal.includes('y', 1) console.log(searchResult) // true
string.search()
定义和用法
search() 方法将字符串与正则表达式匹配。
注释:如果搜索值为字符串,则转换为正则表达式。
search() 方法返回第一个匹配项的索引(位置)。
如果未找到匹配项,则 search() 方法返回 -1。
提示:search() 方法区分大小写。
返回值:匹配成功的第一个字符的下标,未匹配则返回-1
用法:string.search(searchValue)
search方法与indexOf类似,用来返回一个字符串在另一个字符串中的位置,如果没找到那就返回-1,。
唯一需要注意的是,search方法的参数是一个正则表达式。
代码如下:
var string = "foo", expr = /oo/; string.search(expr);// 返回1
let searchVal = 'yyds' let searchResult = searchVal.search('y') console.log(searchResult) // 0
不区分大小写的搜索
let text = "Mr. Blue has a blue house"; let position = text.search(/blue/i);
lodash includes方法
使用Javascript工具库lodash的includes方法,该方法返回一个布尔值,代码如下:
_.includes('foobar', 'ob'); // → true
RegExp正则表达式
使用正则表达式的match来判断是否包含,代码如下:
var string = "foo", expr = /oo/; // no quotes here expr.test(string);//true
Match方法
使用match的方法,该方法字符串不匹配的话就返回null,代码如下:
var string = "foo", expr = /oo/, expr2 = /oa/; string.match(expr);//["oo", index: 1, input: "foo", groups: undefined] string.match(expr2);//null
到此这篇关于js 判断字符串中是否包含某个字符串的实现代码的文章就介绍到这了,更多相关字符串中是否包含某个字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- JS中判断某个字符串是否包含另一个字符串的五种方法
- js判断一个字符串是否包含一个子串的方法
- JS获取字符串实际长度(包含汉字)的简单方法
- javascript 判断字符串是否包含某字符串及indexOf使用示例
- js判断数组是否包含某个字符串变量的实例
- 用javascript实现截取字符串包含中文处理的函数
- JS判断字符串包含的方法
- js计算字符串长度包含的中文是utf8格式
- JS实现快速比较两个字符串中包含有相同数字的方法
- JS不用正则验证输入的字符串是否为空(包含空格)的实现代码
- JavaScript判断一个字符串是否包含指定子字符串的方法
- JS中append字符串包含onclick无效传递参数失败的解决方案
- JS给Array添加是否包含字符串的简单方法
- js处理包含中文的字符串实例
- javascript自动生成包含数字与字符的随机字符串
- JavaScript获取字符串实际长度(包含中英文)
- JavaScript面试中常考的字符串操作方法大全(包含ES6)
- JavaScript字符串包含问题
相关文章
JavaScript onclick与addEventListener使用的区别介绍
addEventListener()方法用于向指定元素添加事件句柄,使用 removeEventListener()方法来移除,onclick和addEventListener事件区别是:onclick事件会被覆盖,而addEventListener可以先后运行不会被覆盖,addEventListener可以监听多个事件2022-09-09JavaScript中使用Substring删除字符串最后一个字符
删除字符串最后一个字符的方法有很多,在本文将为大家介绍下js中的substring是如何做到的,需要的朋友可以参考下2013-11-11
最新评论