JavaScript или jQuery-эквивалент PHP-функции strstr()
Есть ли функция в jQuery или JavaScript, которая делает то же самое, что и strstr()
в PHP?
У меня есть ответ AJAX, который должен быть 1,2,3,12,13,23 или 123. Я хочу проверить, существует ли 1, тогда, если 2 существует, то если 3 существует.
5 ответов
Хорошо, я только что нашел то, что работает!
http://my-sliit.blogspot.com/2008/06/search-string-javascript-like-strstr-in.html
Спасибо за ваш вклад:)
Попробуйте использовать это:
function strstr(haystack, needle, bool) {
// Finds first occurrence of a string within another
//
// version: 1103.1210
// discuss at: http://phpjs.org/functions/strstr // + original by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
// + bugfixed by: Onno Marsman
// + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
// * example 1: strstr(‘Kevin van Zonneveld’, ‘van’);
// * returns 1: ‘van Zonneveld’ // * example 2: strstr(‘Kevin van Zonneveld’, ‘van’, true);
// * returns 2: ‘Kevin ‘
// * example 3: strstr(‘name@example.com’, ‘@’);
// * returns 3: ‘@example.com’
// * example 4: strstr(‘name@example.com’, ‘@’, true); // * returns 4: ‘name’
var pos = 0;
haystack += "";
pos = haystack.indexOf(needle); if (pos == -1) {
return false;
} else {
if (bool) {
return haystack.substr(0, pos);
} else {
return haystack.slice(pos);
}
}
}
(С http://phpjs.org/functions/strstr:551)
В целом phpjs довольно феноменальный.
Прочтите об этих функциях JavaScript - indexOF() и lastIndexOf().
Ну, не встроенный. String.indexOf( String str )
возвращает целочисленный индекс подстроки, но затем вы можете легко создать его: http://aimtb.wordpress.com/2011/03/16/strstr-in-javascript/
function strstr(haystack, needle, bool) {
// Finds first occurrence of a string within another
//
// version: 1103.1210
// discuss at: http://phpjs.org/functions/strstr // + original by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
// + bugfixed by: Onno Marsman
// + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
// * example 1: strstr(‘Kevin van Zonneveld’, ‘van’);
// * returns 1: ‘van Zonneveld’ // * example 2: strstr(‘Kevin van Zonneveld’, ‘van’, true);
// * returns 2: ‘Kevin ‘
// * example 3: strstr(‘name@example.com’, ‘@’);
// * returns 3: ‘@example.com’
// * example 4: strstr(‘name@example.com’, ‘@’, true); // * returns 4: ‘name’
var pos = 0;
haystack += "";
pos = haystack.indexOf(needle); if (pos == -1) {
return false;
} else {
if (bool) {
return haystack.substr(0, pos);
} else {
return haystack.slice(pos);
}
}
}
Вот реализация без каких-либо вызовов библиотеки / метода:
function strstr (haystack, needle) {
var i = 0,
tempLength = 0,
temp = [];
for (;;) {
if (haystack[i] === undefined || needle == null) {
return "No match";
}
//if the char doesn't match then reset
else if (haystack[i] !== needle[tempLength]) {
temp = [];
tempLength = 0;
}
//the char matches so let's store it.
else if (haystack[i] === needle[tempLength]) {
temp[tempLength] = haystack[i];
if (needle[tempLength + 1] === undefined) {
return temp;
}
tempLength++;
}
i++;
}
};
const isSame = function(indx, haystack, needle){
let j = 0;
for(let i=indx, len = indx + needle.length; i< len; i++) {
if (haystack[i] !== needle[j++]){
return false;
}
}
return true;
}
var strStr = function(haystack, needle) {
if (!needle) {
return 0;
}
for(let i=0; i<haystack.length; i++) {
if (haystack[i] === needle[0]){
if(isSame(i, haystack, needle)){
return i;
};
}
}
return -1;
};
console.log(strStr("hello", "ll"));
console.log(strStr("mississippi", "issip"));
Базовые условия:- когда игла является пустой строкой, возвращается 0. Если совпадений не найдено, возвращается -1.