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.

Другие вопросы по тегам