Fuse.js प्लेग्राउंड
Fuse.js फज़ी सर्च लाइब्रेरी के परीक्षण और प्रयोग के लिए इंटरैक्टिव प्लेग्राउंड। सभी सर्च विकल्प कॉन्फ़िगर करें और रियल-टाइम परिणाम देखें।
इनपुट
आउटपुट
रीडमी
फ़ज़ी सर्च क्या है?
फ़ज़ी सर्च एक खोज तकनीक है जो खोज क्वेरी के टेक्स्ट से बिल्कुल मेल न खाने पर भी मिलान ढूँढ़ लेती है। सटीक खोज में जहाँ “apple” केवल “apple” से ही मेल खाता है, फ़ज़ी सर्च “aple” (टाइपो के साथ), “Apple” (भिन्न केस) या “apples” (बहुवचन) को भी खोज सकता है। यह दो स्ट्रिंग्स की समानता की गणना करके काम करता है, जिसमें टाइपो, गलत वर्तनी, विभिन्न अक्षर केस और छोटे‑छोटे अंतर शामिल होते हैं। यह उपयोगकर्ता‑मित्र खोज अनुभव बनाने के लिए आवश्यक है, जहाँ उपयोगकर्ताओं को सटीक क्वेरी टाइप करने की ज़रूरत नहीं होती।
Fuse.js कैसे काम करता है?
Fuse.js एक JavaScript लाइब्रेरी है जो फ़ज़ी सर्च को एक अनुमानित स्ट्रिंग मिलान एल्गोरिदम के माध्यम से लागू करती है। यह निम्नलिखित चरणों से काम करती है:
- इंडेक्सिंग: आपके सर्चेबल डेटा से एक कुशल डेटा संरचना बनाना
- स्कोरिंग: खोज क्वेरी और प्रत्येक आइटम के बीच समानता स्कोर की गणना करना (0.0 = पूर्ण मिलान, 1.0 = कोई मिलान नहीं)
- फ़िल्टरिंग: थ्रेशोल्ड मानदंड को पूरा करने वाले परिणाम लौटाना
- रैंकिंग: स्कोर के आधार पर परिणामों को प्रासंगिकता के अनुसार क्रमबद्ध करना
लाइब्रेरी कॉन्फ़िगरेबल विकल्पों जैसे threshold (खोज कितनी फ़ज़ी होनी चाहिए), location (मिलान की अपेक्षित स्थिति) और distance (अपेक्षित स्थान से अधिकतम दूरी) का उपयोग करती है, जिससे डेवलपर्स को खोज व्यवहार पर सूक्ष्म नियंत्रण मिलता है।
टूल विवरण
Fuse.js Playground एक इंटरैक्टिव परीक्षण वातावरण है जो Fuse.js फ़ज़ी सर्च लाइब्रेरी के लिए बनाया गया है। यह डेवलपर्स को सभी उपलब्ध खोज कॉन्फ़िगरेशन विकल्पों के साथ प्रयोग करने और कस्टम या सैंपल डेटा पर रियल‑टाइम परिणाम देखने की सुविधा देता है। आप खोज कुंजियों को कस्टम वज़न के साथ कॉन्फ़िगर कर सकते हैं, केस सेंसिटिविटी और स्कोर शामिल करने जैसे बेसिक विकल्पों को समायोजित कर सकते हैं, तथा थ्रेशोल्ड, लोकेशन और डिस्टेंस जैसे उन्नत पैरामीटर को फाइन‑ट्यून कर सकते हैं। टूल तुरंत विज़ुअल फ़ीडबैक प्रदान करता है जिससे कॉन्फ़िगरेशन परिवर्तन का परिणामों पर प्रभाव स्पष्ट हो जाता है, जिससे सर्च फ़ंक्शनैलिटी को लागू करने से पहले प्रोटोटाइप बनाना आसान हो जाता है।
विशेषताएँ
- कस्टम डेटा इनपुट: वास्तविक डेटासेट पर सर्च व्यवहार का परीक्षण करने के लिए अपना स्वयं का JSON डेटा लोड करें
- कॉन्फ़िगर करने योग्य खोज कुंजियाँ: कस्टम वज़न प्राथमिकताओं के साथ किन फ़ील्ड्स को खोजा जाए, निर्धारित करें
- रियल‑टाइम परिणाम: खोज क्वेरी या विकल्प बदलते ही तुरंत फ़ीडबैक देखें
- मूल विकल्प: केस सेंसिटिविटी, डायाक्रिटिक हैंडलिंग, सॉर्टिंग और स्कोर डिस्प्ले को नियंत्रित करें
- उन्नत सूक्ष्म समायोजन: थ्रेशोल्ड, लोकेशन, डिस्टेंस, फ़ील्ड नॉर्मलाइज़ेशन आदि को समायोजित करें
- विस्तारित खोज सिंटैक्स: प्रीफ़िक्स सर्च (^), एक्सैक्ट मैच (!), आदि जैसे उन्नत क्वेरी पैटर्न का परीक्षण करें
- परिणाम दृश्यांकन: वैकल्पिक मैच स्कोर के साथ सॉर्टेबल टेबल में सर्च परिणाम देखें
- नमूना डेटासेट: तुरंत परीक्षण और प्रयोग के लिए प्री‑लोडेड बुक कलेक्शन
उदाहरण
बेसिक सर्च:
- क्वेरी:
"fantasy"→ फ़ैंटेसी श्रेणी की सभी किताबें मिलती हैं - क्वेरी:
"tolkien"→ लेखक J.R.R. Tolkien की किताबें मिलती हैं - क्वेरी:
"lord rings"→ “The Lord of the Rings” मिलती है, भले ही शब्द गायब हों
फ़ज़ी मैचिंग:
- क्वेरी:
"hary poter"(टाइपो) → फिर भी “Harry Potter” मिलती है - क्वेरी:
"1984"→ जॉर्ज ऑरवेल की किताब मिलती है - क्वेरी:
"scifi"→ “Science Fiction” श्रेणी से मिलान होता है
विस्तारित खोज (सक्षम होने पर):
- क्वेरी:
"^The"→ “The” से शुरू होने वाले शीर्षक मिलते हैं - क्वेरी:
"!Fantasy"→ “Fantasy” श्रेणी के लिए सटीक मिलान - क्वेरी:
"'Dune"→ शब्द “Dune” शामिल करने वाले आइटम मिलते हैं
कॉन्फ़िगरेशन विकल्प
खोज कुंजियाँ:
- कौन से फ़ील्ड्स को खोजा जाए (जैसे title, author, category) निर्धारित करें
- कुछ फ़ील्ड्स को प्राथमिकता देने के लिए वज़न असाइन करें (उच्च वज़न = अधिक महत्व)
मूल विकल्प:
- केस संवेदनशील: अक्षर केस को बिल्कुल मिलाएँ
- स्कोर शामिल करें: प्रासंगिकता स्कोर दिखाएँ (0.0 = पूर्ण, 1.0 = खराब)
- डायाक्रिटिक को नज़रअंदाज़ करें: एक्सेंटेड अक्षरों को उनके बेस फ़ॉर्म में मानें (é = e)
- परिणाम सॉर्ट करें: परिणामों को प्रासंगिकता स्कोर के अनुसार क्रमबद्ध करें
- सभी मैच खोजें: पहला मिलान मिलने के बाद भी खोज जारी रखें
उन्नत विकल्प:
- न्यूनतम मैच अक्षर लंबाई: मिलान के लिए आवश्यक न्यूनतम अक्षर संख्या (डिफ़ॉल्ट: 1)
- स्थान: टेक्स्ट में मिलान की अपेक्षित स्थिति (डिफ़ॉल्ट: 0 = शुरुआत)
- थ्रेशोल्ड: फ़ज़ीनेस स्तर, 0.0 (सटीक) से 1.0 (बहुत फ़ज़ी) तक
- दूरी: अपेक्षित स्थान से अधिकतम खोज दूरी
- विस्तारित खोज उपयोग करें: उन्नत क्वेरी सिंटैक्स (^, !, ', आदि) सक्षम करें
- स्थान को नज़रअंदाज़ करें: मिलान करते समय स्थिति को अनदेखा करें
- फ़ील्ड नॉर्म को नज़रअंदाज़ करें: स्कोरिंग में फ़ील्ड लंबाई को ध्यान में न रखें
- फ़ील्ड नॉर्म वज़न: स्कोरिंग पर फ़ील्ड लंबाई का कितना प्रभाव पड़ेगा
उपयोग केस
- सर्च इम्प्लीमेंटेशन परीक्षण: कोडिंग से पहले सर्च फ़ंक्शनैलिटी का प्रोटोटाइप और वैधता जांचें
- API कॉन्फ़िगरेशन: आपके एप्लिकेशन के लिए सर्वोत्तम Fuse.js सेटिंग्स निर्धारित करें
- सर्च व्यवहार विश्लेषण: विभिन्न विकल्पों का परिणाम गुणवत्ता पर प्रभाव समझें
- क्लाइंट डेमो: वास्तविक डेटा के साथ सर्च कैसे काम करता है, स्टेकहोल्डर्स को दिखाएँ
- Fuse.js सीखना: लाइब्रेरी की क्षमताओं को समझने के लिए हैंड‑ऑन प्रयोग करें
- डेटा स्ट्रक्चर परीक्षण: जांचें कि आपका JSON डेटा स्ट्रक्चर फ़ज़ी सर्च के साथ काम करता है या नहीं
- सर्च क्वालिटी ट्यूनिंग: बेहतरीन परिणामों के लिए थ्रेशोल्ड और अन्य पैरामीटर को फाइन‑ट्यून करें