آموزش طراحی سایت-آموزش عبارات با قاعده در جاوا اسکریپت

آموزش طراحی سایت-آموزش عبارات با قاعده در جاوا اسکریپت

در این مقاله از مجموعه مقالات آموزش طراحی سایت به بررسی عبارات با قاعده در جاوا اسکریپت می پردازیم..عبارات با قاعده (Regular Expressions) رشته یا توالی از کاراکترها هستند که یک یگ الگو جستجو (search pattern) تعریف می کنند. برای انجام عملیات جستجو برای کلمات و یا کاراکترهای مورد نظر در متن یک صفحه می توان از این عبارات کمک گرفت. الگوی جستجو را می توان برای انجام عملیاتی همچون جستجو در متن و جایگزینی نوشته هایی در متن مورد استفاده قرار داد.عبارت با قاعده (Regular Expression) شی ای است که درباره ی الگوی کاراکترها شرح می دهد. زمانی که در یک متن به دنبال داده یا اطلاعات معینی به جستجو می پردازید، می توانید از یک الگوی خاص برای کلمه ی مورد جستجو استفاده نمایید. یک کاراکتر تنها، می تواند یک الگوی ساده باشد. یک الگوی پیچیده تر ممکن است شامل کاراکترهای بیشتری باشد و از آن می توان برای اجرای عملیاتی همچون تجزیه کردن، قالب دهی، بررسی کردن و جایگزینی استفاده کرد.‎/pattern/modifiers;‎var patt = / tahlildadeh /i;‎توضیح مثال : /w3schools/i یک عبارت با قاعده است. w3schools نیز یک یک الگو است که در جستجو به کار می رود. i یک modifier می باشد (باعث می شود جستجو به کوچک بزرگی حروف حساسیت نشان ندهد). https://aparat.com/v/X84lF عبارات با قاعده در جاوا اسکریپت اغلب با دو متد رشته ای ()search و ()replace بکار می رود.متد () Search : جهت جستجو برای کشف وجود يا عدم وجود يک کلمه خاص در يک متغیر رشته ای بکار گرفته می شود.متد () Replace : از اين متد به منظور جستجو به دنبال يک حرف يا کلمه خاص در يک متغير رشته ای و جايگزينی آن با يک مقدار جديد استفاده می شود.مثال :var str = &quotVisit Tahlildadeh”
var n = str.search(/Tahlildadeh/i);‎نتیجه :نمونه یک :function myFunction() {
var str = &quotVisit Tahlildadeh!”
var n = str.search(/Tahlildadeh/i);
document.getElementById(&quotdemo&quot) = n;
}تابع جستجو (search method) همچنین می تواند یک رشته به عنوان آرگومان جستجو بپذیرد. آرگومان گفته شده به یک عبارت با قاعده (regular expression) تبدیل می شود.مثال :با استفاده از یک رشته به عنوان آرگومان ورودی تابع () search برای یافتن واژه ی “Tahlildadeh” در string جستجو انجام می دهیم.نمونه دو :var str = &quotVisit Tahlildadeh!”
var n = str.search(Tahlildadeh);در این مثال با استفاده از تابع () replace یک عبارت با قاعده ی case-insensitive (Tahlildadeh) را جایگزین کلمه ی Microsoft می کنیم.نمونه سه :function myFunction() {
var str = document.getElementById(&quotdemo&quot);
var txt = str.replace(/microsoft/i, &quotTahlildadeh&quot);
document.getElementById(&quotdemo&quot) = txt;
}تابع () replace نیز می تواند مانند متد () search یک رشته به عنوان آرگومان ورودی می پذیرد.نمونه چهار :function myFunction() {
var str = document.getElementById(&quotdemo&quot);
var txt = str.replace(&quotMicrosoft&quot, &quotTahlildadeh&quot);
document.getElementById(&quotdemo&quot) = txt;
}اگر به مثال های بالا خوب دقت کرده باشید متوجه می شوید که می توان به جای string argument (آرگومان رشته ای) از آرگومان های regular expression در توابع یاد شده استفاده کرد. با بهره گیری از عبارات با قاعده می توان جستجو را قوی تر یا به مراتب کارآمدتر ساخت(برای مثال آن را نسبت به کوچک بزرگی حروف بی تفاوت کرد). https://aparat.com/v/vsEJ0 عبارت Modifier یک کاراکتر است که با استفاده از آن جستجو به دنبال کلمه یا حرف مد نظر را case-insensitive (بی تفاوت به کوچک و بزرگی حروف) کرده یا آن را سراسری (global) می کنیم.حرف i : بیانگر case-insensitive (حساس نبودن به کوچک و بزرگی حروف) بودن جستجو است.حرف g : نشانگر سراسری بودن جستجو می باشد (جستجو پس از یافتن مورد اول متوقف نمی شود).حرف m : جستجو را در چندین خط انجام می دهد.الگو (Pattern) عبارتی است که در متن می خواهیم به دنبال آن بگردیم. با استفاده از کاراکتر [] می توان مجموعه ای از کاراکترها را جستجو کرد (یافت).عبارت [abc] : هر کاراکتری که درون (محصور در) [] باشد را پیدا می کند.عبارت [9-0] : هر عددی که بین براکت باز و بسته محصور شده باشد را پیدا می کند.عبارت (x|y) : هر کاراکتر ی (جایگزین) که با ” | ” از هم جدا شده باشند را پیدا می کند.متا کاراکتر (Metacharacter) کاراکتری است که معنای به خصوصی برای برنامه ی کامپیوتری داشته باشد.متا کاراکتر d : یک عدد را پیدا می کند.متا کاراکتر s : یک کاراکتر خط فاصله را می یابد.متا کاراکتر b : مورد مد نظر (match) را در ابتدا یا انتهای یک کلمه می یابد.متا کاراکتر uxxxx : کاراکتر Unicode که توسط عدد مبنای 16 (hexadecimal) xxxx مشخص شده را می یابد.کمیت سنج ها (Quantifiers) مقادیر یا کمیت را تعیین می کنند.کمیت سنج n+ : با رشته ای match می شود که دربردانده ی حداقل یک n باشد.کمیت سنج n : با رشته ای match می شود که دربردارنده ی 0 یا بیشتر تکرار (نمونه) از n باشد.کمیت سنج n? : با رشته ای match می شود که دربردارنده ی 0 یا بیشتر تکرار (نمونه) از n باشد.استفاده از شی RegExp در دوره آموزش طراحی وب : شی ای است دارای توابع و خواص از پیش تعریف شده ای است.متد ()Test : این تابع در یک رشته به دنبال الگوی موردنظر جستجو انجام داده سپس بسته به نتیجه، مقدار true یا false باز می گرداند. به عبارتی دیگر، متد ()test، یک رشته را داخل یک مقدار مشخص جستجو کرده و براساس نتیجه، true یا false برمی گرداند.مثال :در این مثال، در یک رشته به دنبال “e” می گردد.نمونه پنج :function myFunction() {
text = document.getElementById(&quotp01&quot);
document.getElementById(&quotdemo&quot) = /e/.test(text);
}به این خاطر که “e” در رشته ی مورد نظر یافت می شود، خروجی کد true خواهد بود.نیازی نیست عبارت با قاعده را درون یک متغیر قرار دهید. دو خط کد مثال بالا را می توان در یک خط (به طور خلاصه) نوشت./e/.test(&quotThe best things in life are free!&quot);‎تابع ()exec : این متد داخل یک رشته به دنبال الگوی مورد نظر جستجو انجام داده، سپس نوشته ی یافت شده را بر می گرداند یا به عبارت دیگر متد ()exec، یک رشته را داخل یک مقدار مشخص جستجو می کند و با توجه به نتیجه ی حاصل، مقدار جستجو شده یا false را بازیابی می کند. حال در صورتی که مورد (match) یافت نشد، متد ذکر شده null باز می گرداند.مثال :در این مثال، در یک رشته به دنبال “e” می گردد.نمونه شش : function myFunction() {
text = document.getElementById(&quotp01&quot);
document.getElementById(&quotdemo&quot) = /e/.exec(text);
}به این خاطر که “e” در رشته ی مورد نظر یافت می شود، خروجی کد e خواهد بود.با دیگر مقالات ما در زمینه آموزش طراحی وبسایت همراه ما باشید..

Author: admin

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *