जवाबों:
के .toLowerCase()
बाद जोड़ें referrer
। यह विधि स्ट्रिंग को कम केस स्ट्रिंग में बदल देती है। फिर, के बजाय का उपयोग .indexOf()
कर का उपयोग करें ।ral
Ral
if (referrer.toLowerCase().indexOf("ral") === -1) {
एक नियमित अभिव्यक्ति (विशेष रूप से उपयोगी जब आप गतिशील पैटर्न के खिलाफ परीक्षण करना चाहते हैं) का उपयोग करके भी इसे प्राप्त किया जा सकता है:
if (!/Ral/i.test(referrer)) {
// ^i = Ignore case flag for RegExp
.search
विधि का उपयोग करें:var index = referrer.search(/Ral/i);
एक अन्य विकल्प खोज विधि का उपयोग इस प्रकार है:
if (referrer.search(new RegExp("Ral", "i")) == -1) { ...
यह अधिक सुरुचिपूर्ण दिखता है और पूरे स्ट्रिंग को निचले मामले में परिवर्तित करता है और यह अधिक कुशल हो सकता है।
साथ toLowerCase()
कोड है स्ट्रिंग पर दो पास, एक पास पूरी स्ट्रिंग पर है लोअर केस में यह परिवर्तित करने के लिए और एक अन्य वांछित सूचकांक देखने के लिए है। कोड के
साथ RegExp
स्ट्रिंग के ऊपर एक पास होता है जो वांछित सूचकांक से मेल खाता है।
इसलिए, लंबे स्ट्रिंग्स पर मैं RegExp
संस्करण का उपयोग करने की सलाह देता हूं (मुझे लगता है कि शॉर्ट स्ट्रिंग्स पर यह दक्षता RegExp
ऑब्जेक्ट बनाने के कारण आती है )
एक RegExp का उपयोग करें:
if (!/ral/i.test(referrer)) {
...
}
या, उपयोग करें .toLowerCase()
:
if (referrer.toLowerCase().indexOf("ral") == -1)
ES2016 से आप थोड़ा बेहतर / आसान / अधिक सुरुचिपूर्ण विधि (केस-संवेदी) का उपयोग कर सकते हैं:
if (referrer.includes("Ral")) { ... }
या (केस-असंवेदनशील):
if (referrer.toLowerCase().includes(someString.toLowerCase())) { ... }
यहाँ कुछ तुलना की गई है .indexOf()
और .includes()
:
https://dev.to/adroitcoder/includes-vs-indexof-in-wasascript
includes
है केस-संवेदी में क्रोम: कोशिश 'fooBar'.includes('bar')
==>false
यहाँ कुछ दृष्टिकोण हैं।
यदि आप इस उदाहरण के लिए केस-असंवेदनशील जांच करना चाहते हैं, तो निम्न जैसा कुछ करें।
if (referrer.toLowerCase().indexOf("Ral".toLowerCase()) == -1) {
...
वैकल्पिक रूप से, यदि आप इस चेक को नियमित रूप से कर रहे हैं, तो आप इसमें एक नई indexOf()
तरह की विधि जोड़ सकते हैं String
, लेकिन इसे असंवेदनशील बना सकते हैं।
String.prototype.indexOfInsensitive = function (s, b) {
return this.toLowerCase().indexOf(s.toLowerCase(), b);
}
// Then invoke it
if (referrer.indexOfInsensitive("Ral") == -1) { ...
defineProperty
, मैं सुझाव देता हूं Object.defineProperty(String.prototype, 'indexOfInsensitive', {value: function(s,b){return this.toLowerCase().indexOf((s+'').toLowerCase(),b);}});
। दो अपडेट: स्पष्ट स्ट्रिंग रूपांतरण का उपयोग करना (s+'')
, और एक लूप में गैर-एन्यूमरेबल ( for(var i in '') ...
नहीं दिखाता है indexOfInsensitive
।
if (referrer.toUpperCase().indexOf("RAL") == -1) { ...
आप यह कोशिश कर सकते हैं
str = "Wow its so COOL"
searchStr = "CoOl"
console.log(str.toLowerCase().includes(searchStr.toLowerCase()))
किसी भी भाषा के लिए उदाहरण:
'My name is Хведор'.toLocaleLowerCase().includes('ХвЕдОр'.toLocaleLowerCase())
यह 2016 है, और ऐसा करने का कोई स्पष्ट तरीका नहीं है? मैं कुछ कोपिपास्ता की उम्मीद कर रहा था। मुझे जाना होगा।
डिज़ाइन नोट्स: मैं स्मृति उपयोग को कम करना चाहता था, और इसलिए गति में सुधार - इसलिए स्ट्रिंग्स की कोई नकल / उत्परिवर्तन नहीं है। मुझे लगता है कि V8 (और अन्य इंजन) इस फ़ंक्शन को अनुकूलित कर सकते हैं।
//TODO: Performance testing
String.prototype.naturalIndexOf = function(needle) {
//TODO: guard conditions here
var haystack = this; //You can replace `haystack` for `this` below but I wan't to make the algorithm more readable for the answer
var needleIndex = 0;
var foundAt = 0;
for (var haystackIndex = 0; haystackIndex < haystack.length; haystackIndex++) {
var needleCode = needle.charCodeAt(needleIndex);
if (needleCode >= 65 && needleCode <= 90) needleCode += 32; //ToLower. I could have made this a function, but hopefully inline is faster and terser
var haystackCode = haystack.charCodeAt(haystackIndex);
if (haystackCode >= 65 && haystackCode <= 90) haystackCode += 32; //ToLower. I could have made this a function, but hopefully inline is faster and terser
//TODO: code to detect unicode characters and fallback to toLowerCase - when > 128?
//if (needleCode > 128 || haystackCode > 128) return haystack.toLocaleLowerCase().indexOf(needle.toLocaleLowerCase();
if (haystackCode !== needleCode)
{
foundAt = haystackIndex;
needleIndex = 0; //Start again
}
else
needleIndex++;
if (needleIndex == needle.length)
return foundAt;
}
return -1;
}
मेरे नाम का कारण:
क्यों नहीं...:
toLowerCase()
- एक ही स्ट्रिंग पर संभावित बार-बार कॉल toLowerCase।RegExp
- चर के साथ खोज करने के लिए अजीब। यहां तक कि RegExp ऑब्जेक्ट पात्रों से बचने के लिए अजीब हैएक बेहतर खोज करने के लिए निम्नलिखित कोड का उपयोग करें,
var myFav = "javascript";
var theList = "VB.NET, C#, PHP, Python, JavaScript, and Ruby";
// Check for matches with the plain vanilla indexOf() method:
alert( theList.indexOf( myFav ) );
// Now check for matches in lower-cased strings:
alert( theList.toLowerCase().indexOf( myFav.toLowerCase() ) );
पहले अलर्ट में (), जावास्क्रिप्ट ने "-1" लौटाया - दूसरे शब्दों में, indexOf () को एक मैच नहीं मिला: यह केवल इसलिए है क्योंकि "जावास्क्रिप्ट" पहले स्ट्रिंग में लोअरकेस में है, और दूसरे में ठीक से कैपिटल है। IndexOf () के साथ केस-असंवेदनशील खोजों को करने के लिए, आप दोनों स्ट्रिंग को अपरकेस या लोअरकेस बना सकते हैं। इसका मतलब है कि, दूसरे अलर्ट () के रूप में, जावास्क्रिप्ट केवल उस स्ट्रिंग की घटना की जांच करेगा जिसे आप खोज रहे हैं, पूंजीकरण की अनदेखी की गई है।
संदर्भ, http://freewebdesigntutorials.com/javaScriptTutorials/jsStringObject/indexOfMethod.htm
यदि referrer
एक सरणी है, तो आप उपयोग कर सकते हैंfindIndex()
if(referrer.findIndex(item => 'ral' === item.toLowerCase()) == -1) {...}
यहाँ मेरा ले रहा है:
स्क्रिप्ट :
var originalText = $("#textContainer").html()
$("#search").on('keyup', function () {
$("#textContainer").html(originalText)
var text = $("#textContainer").html()
var val = $("#search").val()
if(val=="") return;
var matches = text.split(val)
for(var i=0;i<matches.length-1;i++) {
var ind = matches[i].indexOf(val)
var len = val.length
matches[i] = matches[i] + "<span class='selected'>" + val + "</span>"
}
$("#textContainer").html(matches.join(""))
HTML:
<input type="text" id="search">
<div id="textContainer">
lorem ipsum is simply dummy text of the printing and typesetting industry. lorem ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of letraset sheets containing lorem ipsum passages, and more recently with desktop publishing software like Aldus pagemaker including versions of lorem ipsum.</div>
RegExp
उपयोगकर्ता इनपुट से सीधे बनाने के नुकसान को ध्यान में रखना चाहिए । उदाहरण के लिए एक उपयोगकर्ता प्रवेश कर सकता है*
और एक त्रुटि कोRegExp
कंस्ट्रक्टर में फेंक दिया जाएगा । स्वीकृत समाधान में यह समस्या नहीं है।