آیا می‌دانید انتخابگر صحیح برای استفاده در خراش دادن وب کدام است؟ اسکرپینگ وب در دهه اخیر برای استخراج داده ها از اینترنت بسیار محبوب بوده است. این به کسب و کارها کمک می کند تا داده ها را به دست آورند و تجزیه و تحلیل کنند تا تصمیمات تجاری بهتری بگیرند. به لطف فناوری‌های خودکار، خراش دادن وب هرگز آسان‌تر از آنچه اکنون است نبوده است.

با این حال، صرف‌نظر از ابزار یا چارچوبی که انتخاب می‌کنید، باید تصمیم مهمی بگیرید تا مطمئن شوید که اسکراپر شما داده‌ها را مودبانه می‌خراشد. این یعنی استخراج عناصر وب با استفاده از انتخابگرهای XPath یا CSS، که در این مقاله خواهید آموخت. زبان. با این حال، از دستور غیر XML برای انتخاب برچسب ها یا گروه هایی از برچسب ها از یک سند XML یا HTML استفاده می کند، مانند خراش دادن وب. XPath شما را قادر می سازد تا عباراتی بنویسید تا به یک عنصر HTML یا XML مستقیماً بدون عبور از کل درخت HTML دسترسی داشته باشید.

برای درک اینکه چگونه می‌توانید با استفاده از XPath به یک عنصر دسترسی پیدا کنید، اجازه دهید با یک کد HTML عمیق‌تر کاوش کنیم. من فرض می‌کنم که شما قبلاً برخی از HTML اولیه را می‌دانید.




    
    محصولات عالی در دسترس شما



    

شرح ویژگی‌های محصول

این محصولات عالی هستند. بنابراین بیایید فقط به ویژگی‌ها نگاه کنیم!

  • Item 1
  • Item 2
  • Item 3

شما می‌توانید کد بالا را در ویرایشگر دلخواه خود تایپ کنید و آن را به عنوان products.html ذخیره کنید. سپس می‌توانید آن را در یک مرورگر مشاهده کنید (ترجیحاً Google Chrome همانطور که در این مثال با آن مرور خواهیم کرد). آن را به عنوان DOM (مدل شیء سند) به شکل زیر می‌شناسند:

 انتخابگر برای خراش دادن وب

می‌توانید اطلاعات بیشتری در مورد DOM در پیوند داده شده بخوانید. اکنون تمرکز ما در اینجا بر روی XPath است که چگونه می توان بلافاصله به هر یک از این عناصر پیمایش کرد بدون اینکه کل درخت را طی کنیم. بنابراین بیایید با اصطلاحات اولیه Xpath شروع کنیم.

Node ها چیست؟

در XPath، اساسی ترین عنصر یک گره است. خوب، گره ها به سادگی عناصر فردی هستند که شما در درخت DOM دیدید. همانطور که در این مقاله پیش می رویم، حتی بیشتر متوجه خواهید شد که گره ها از عناصر برچسب، ویژگی ها، مقادیر رشته های اختصاص داده شده به آن و غیره تشکیل شده اند. در هر صفحه XML یا HTML هفت عدد وجود دارد، و بیایید هر نوع گره را از نزدیک بررسی کنیم. به عنوان مثال، در مثال ما، گره های عناصر عبارتند از ، <meta>، <body>، </p> <h1>، </p> <p>، </p> <ul>، و </p> <li> <li>019-196، <li>0، [196] 196.0. می تواند گره های عناصر را دارای ویژگی هایی برای دادن نام های منحصر به فرد یا اعمال سبک های CSS باشد. در این مثال، عنصر <ul> را با ویژگی‌های «id» و «class» ارائه کرده‌ایم. بعداً درباره شناسه‌ها و کلاس‌ها بیشتر توضیح می‌دهید.</li> </ul> <ul> <li><strong> مقادیر اتمی </strong> – اینها مقادیری هستند که در عناصر گره قرار دارند. در اینجا، مقادیر اتمی متن داخل <title>،<br /> <h1>، </p> <p> و هر یک از سه عنصر </p> <li> هستند. چهار مورد زیر را فقط برای اطلاعات بدانید.</p> <ul> <li><strong>Namespace</strong>: از آنجایی که XPath با اسناد XML نیز سر و کار دارد، استانداردی است که نحوه استفاده از عناصر و ویژگی ها را مشخص می کند. توسط URI (شناسه منبع یکسان) شناسایی می شود. برای آخرین نسخه HTML 5، می توانید فضای نام را به این صورت تنظیم کنید: <html xmlns=”http://www.w3.org/1999/xhtml”  lang=”en” xml:lang=”en”>.</li> </ul> <ul> <li><strong> نظرات: </strong> اینها قسمت نظرات یک سند HTML یا XML هستند که کامپایلر یا تجزیه کننده آن را پردازش نمی کند.[19659021]دستورالعمل فرآیند</strong>: مانند مورد اسناد HTML، آنها گره هایی هستند که فایل های خارجی مانند فایل های CSS و جاوا اسکریپت را به هم پیوند می دهند. به عنوان مثال، گره <link> شامل فایل های CSS و گره <src> برای شامل فایل های جاوا اسکریپت. <html> node.</li> </ul> <h3 id="what-is-the-relationship-between-nodes">رابطه بین گره ها چیست؟</h3> <ul> <li><strong>Parent:</strong> اینها عناصر ریشه درخت DOM هستند که دقیقاً یک سطح بالاتر هستند. هر عنصر دقیقاً یک والد دارد. طبق مثال ما، والد عنصر <li> <ul> است. طبق مثال ما </p> <h1>، </p> <p> و </p> <ul> عناصر فرزندان عنصر <body> هستند. در مثال ما، هر دو عنصر </p> <li> خواهر و برادر والدین <ul> هستند. همچنین </p> <h1>، </p> <p> و </p> <ul> خواهر و برادر هستند زیرا به یک والدین تعلق دارند <body>. برای مثال، عنصر <title> از نسل عنصر <head> است. در مثال ما </p> <li> اجداد عنصر <ul>، <body> و <html> هستند.</li> </ul> <h3 id="how-to-find-the-xpath-of-an-html-element"> چگونه XPath یک عنصر HTML را پیدا کنیم؟</h3> <p> دو راه برای انجام این کار وجود دارد. ابتدا، اجازه دهید آن را نشان دهیم یا یک مثال کدنویسی کنیم. همانطور که در بالا ذکر کردم، امیدوارم آن را در دیسک محلی خود ذخیره کرده باشید و آماده باشید تا در مرورگر خود مشاهده شود.</p> <p> وقتی صفحه بارگیری شد، ماوس خود را روی مورد 1 ببرید و روی آن کلیک راست کنید. سپس Inspect را از آیتم‌های منو که در تصویر زیر نشان داده شده است انتخاب کنید:</p> <figure class="wp-block-image size-full is-resized"><img decoding="async" loading="lazy" alt="" width="590" height="393" data- data-src="https://giftscharge.ir/wp-content/uploads/2022/02/_773_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" data- class="wp-image-4424 lazyload" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="/><noscript><img decoding="async" loading="lazy" src="https://giftscharge.ir/wp-content/uploads/2022/02/_773_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" alt="" class="wp-image-4424" width="590" height="393" /></noscript></figure> <p> سپس می‌توانید XPath کامل را با کلیک بر روی عنصر </p> <li> در کنسول و انتخاب «کپی» از فهرست باز شده پیدا کنید. منوی پایین، و سپس مشخص کردن «کپی کامل XPath همانطور که در زیر نشان داده شده است:</p> <figure class="wp-block-image size-full"><img decoding="async" loading="lazy" width="901" height="555" alt="" data- data-src="https://giftscharge.ir/wp-content/uploads/2022/02/_879_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" data- class="wp-image-4423 lazyload" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="/><noscript><img decoding="async" loading="lazy" width="901" height="555" src="https://giftscharge.ir/wp-content/uploads/2022/02/_879_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" alt="" class="wp-image-4423" /></noscript></figure> <p>سپس پس از چسباندن آن در یک فایل متنی یا جایی، دریافت خواهید کرد: مسیر مطلق <strong>. </strong> در زیر توضیح خواهم داد که چگونه آن را استخراج کرده اید.</p> <pre class="wp-block-code"><code class="">مرحله 1 => li[1] //در اینجا یکی نشان دهنده اولین عنصر li است. مرحله 2 => /li[1] مرحله 3 => ul/li[1] مرحله 4 => /ul/li[1] مرحله 5 => body/ul/li[1] مرحله 6 => /body/ul/li[1] مرحله 7 => html/body/ul/li[1] مرحله 8 => /html/body/ul/li[1] </code></pre> <h4 id="absolute-path">مسیر مطلق</h4> <p>با این روش، باید مسیر خود را به سمت عقب حرکت کنید، از عنصر هدف شروع کنید تا به عنصر اصلی برگردید. هنگام نوشتن هر عنصر، قبل از عنصری که به تازگی اضافه کرده اید، یک اسلش رو به جلو اضافه می کنید. بنابراین بیایید ببینیم چگونه می‌توانید XPath را برای اولین عنصر </p> <li> به صورت دستی کار کنید:</p> <p> اگرچه روش فوق طولانی به نظر می‌رسد، به شما کمک می‌کند تا بفهمید چگونه XPath کامل را بسازید. اکنون به روش نسبی می پردازیم.</p> <h4 id="relative-path">Relative Path</h4> <pre class="wp-block-code"><code class="">//*[@id="product-list"]/li[1]</code></pre> <p> همانطور که می بینید، بسیار کوتاه است و مسیر نسبت به عنصر والد </p> <ul> است. از آنجایی که عنصر </p> <li> ویژگی id ندارد، مسیر نسبی آن نسبت به عنصر <ul> است. </p> <h4 id="the-difference-between-relative-and-absolute-paths">تفاوت بین مسیرهای نسبی و مطلق</h4> <p>تفاوت های مهم این است که XPath کامل خوانا نیست و نگهداری آن سخت است. نگرانی آشکار دیگر این است که اگر تغییراتی در هر عنصری وجود داشته باشد که از عنصر ریشه شروع می شود، XPath مطلق معتبر نخواهد بود. بنابراین منطقی است که از XPath نسبی استفاده کنیم.</p> <p> با این حال، قبل از توضیح بیشتر در مورد آن، اجازه دهید ابتدا به مزایا و معایب نگاه کنیم. اگر نام یک عنصر را نمی دانید، نباید نگران باشید، زیرا می توانید از تابع contain برای جستجوی مطابقت های احتمالی استفاده کنید. بنابراین، می‌توانید هنگام جستجو برای خراش دادن موارد، DOM را بالا ببرید.</p> <p> مزیت مهم دیگر CSS این است که در مرورگرهای قدیمی‌تر مانند نسخه‌های قدیمی اینترنت اکسپلورر کار می‌کند.</p> <h4 id="disadvantages"> معایب</h4> <p> همانطور که یاد گرفتید. در بالا، مهم ترین نقطه ضعف آن زمانی که عناصر مسیر را تغییر می دهید، راحت تر شکسته می شود. درک آن در مقایسه با انتخابگرهای CSS که در زیر خواهید فهمید، دشوار است.</p> <p> همچنین، هنگام بازیابی عناصر از XPath، عملکرد آن بسیار کندتر از CSS است.</p> <h2 id="what-is-a-css-selector"> انتخابگر CSS چیست؟ </h2> <p> همانطور که می دانید، CSS مخفف عبارت Cascading Style Sheets است که به طور برجسته در شکل دادن به عناصر HTML در یک صفحه وب استفاده می شود. این سبک‌ها شامل اعمال رنگ‌ها به فونت، تصاویر پس‌زمینه، و رنگ‌ها، تراز کردن و قرار دادن عناصر، و افزایش/کاهش فاصله بین پاراگراف‌ها می‌شود.</p> <p> برای تنظیم یک سبک برای یک عنصر HTML، باید آن را از طریق انتخابگر CSS مشخص کنید. بیایید با یک مثال ساده شروع کنیم که با نشانه گذاری در بخش بعدی شروع می شود.</p> <h3 id="how-are-css-selectors-created">انتخابگرهای CSS چگونه ایجاد می شوند؟</h3> <pre class="wp-block-code"><code class=""><h1 id="main-heading" class="header-styles" name="h1name">انتخاب کنندگان CSS چیست؟</h1></code></pre> <p>بنابراین در اینجا انتخابگر CSS برای عنصر بالا آمده است: </p> <ul> <li> <h1>– با نام عنصر </p> <h1></li> <li>#main-heading – #شناسه عنصر را مشخص می‌کند</li> <li>.header-styles – نقطه نشان‌دهنده نام کلاس است</li> <li>[name=”h1name”] – می‌توانید ویژگی‌ها را در براکت مشخص کنید. </li> </ul> <p> می‌توانید آنها را نیز ترکیب کنید:</p> <p><strong>h1.header-styles-</strong>این انتخابگر CSS عناصر h1 را با سبک‌های هدر کلاس انتخاب می‌کند. برای انتخاب کودکان در مقابل، عملگر + اولین خواهر و برادر را انتخاب می‌کند و عملگر ~ برای انتخاب همه خواهر و برادرها استفاده می‌شود. چند نمونه به شرح زیر است:</p> <ul> <li>ul#product-list > li – <li> عناصری را انتخاب می کند که فرزندان <ul> با شناسه لیست محصول هستند.</li> <li>ul#product-list li – <li> را انتخاب می کند. </li> <li>ul#product-list + li – اولین عنصر <li> بعد از <ul> را با شناسه فهرست محصول انتخاب می‌کند.</li> <li>ul#product. -list ~ li – همه عناصر <li> را بعد از <ul> با شناسه لیست محصول انتخاب می کند. </li> </ul> <h2 id="advantages-and-disadvantages-of-using-css-selectors">مزایا و معایب استفاده از انتخابگرهای CSS</h2> <h3 id="advantages">مزایا</h3> <p>برخلاف XPath که Beautiful Soup از آن پشتیبانی نمی‌کند، انتخابگرهای CSS با مؤثرترین کتابخانه‌های خراشینگ پشتیبانی می‌شوند. همچنین، برخلاف XPath، انتخابگرهای CSS برای یادگیری و نگهداری آسان‌تر هستند. تقریباً همه مرورگرها از آن پشتیبانی می کنند، به جز مرورگرهای قدیمی زیر اینترنت اکسپلورر نسخه 8. با این حال، مردم در عصر حاضر به ندرت از آن مرورگرها استفاده می کنند. </p> <p> از آنجایی که نسخه‌های CSS مختلفی وجود دارد، می‌توانند بین توسعه‌دهندگان و مبتدیان به طور یکسان سردرگمی ایجاد کنند.</p> <p>یکی دیگر از عوامل حیاتی در فناوری وب امروزی، امنیت CSS است. </p> <h2 id="what-are-the-differences-between-css-selectors-and-xpath">تفاوت بین انتخابگرهای CSS و XPath چیست؟</h2> <figure class="wp-block-image size-large"><img decoding="async" loading="lazy" width="1024" height="474" alt="انتخاب کننده برای خراش دادن وب" data- data-src="https://giftscharge.ir/wp-content/uploads/2022/02/_14_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" data- class="wp-image-4415 lazyload" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="/><noscript><img decoding="async" loading="lazy" width="1024" height="474" src="https://giftscharge.ir/wp-content/uploads/2022/02/_14_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" alt="انتخاب کننده برای خراشیدن وب" class="wp-image-4415" /></noscript></figure> <p>تفاوت ظاهری بین XPath و CSS این است که XPath دو جهته است. این بدان معنی است که شما می توانید در درخت DOM در هر دو جهت پیمایش کنید. با این حال، شما فقط می توانید از گره والد به گره های فرزند با CSS، که به عنوان جریان یک جهته شناخته می شود، عبور کنید.</p> <p> همانطور که در بخش های قبلی بحث شد، نگهداری XPath سخت تر است و کاندیدای مناسبی برای خوانایی موثر نیست. از سوی دیگر، اگرچه XPath ممکن است در مرورگرهای قدیمی کار کند، اما نحوه رندر کردن آن از یک مرورگر به مرورگر دیگر متفاوت است. 19659005]XPATH متمایز است زیرا CSS فقط می تواند از والدین به فرزند در مناطق خاصی مانند عبور از درخت DOM عبور کند. تا آنجا که به سرعت مربوط می شود، CSS دارای برتری است.</p> <p> با این حال، تفاوت سرعت بین XPath و CSS در مورد اسکراپینگ وب اهمیت زیادی ندارد. عوامل دیگری نیز وجود دارد که باید در نظر بگیرید، مانند تأخیر شبکه در حذف وب. </p> <p> CSS اولین انتخاب شما در مورد سوپ زیبا خواهد بود زیرا از XPath پشتیبانی نمی کند.</p> <h2 id="conclusion"> نتیجه</h2> <p> پاسخ دقیقی وجود ندارد. انتخابگرهایی که برای پروژه خراش دادن وب خود استفاده کنید. همانطور که در این مقاله متوجه شدید، XPath در موقعیت‌های خاص برتری دارد، در حالی که CSS در موقعیت‌های دیگر برجسته است. </p> <p>بنابراین، باید نکات حیاتی خاصی مانند پیمایش، پشتیبانی مرورگر و برخی از قابلیت‌های فنی را که در مورد آنها بحث کردیم، در نظر بگیرید. امیدواریم آنچه را که آموخته اید تمرین کنید و منتظر مقالات بیشتر باشید.</p> </div> <p><a href="/" title="ProxyScrape"> <img decoding="async" src="https://giftscharge.ir/wp-content/uploads/2022/02/_16_انتخاب-انتخابگر-مناسب-برای-اسکرپینگ-و.png" title="ProxyScrape" width="350"></a></p> </div><!-- .entry-content --> <footer class="entry-footer"> <span class="cat-links">Posted in <a href="https://giftscharge.ir/category/%d8%ae%d8%b1%db%8c%d8%af-vpn-%da%a9%d8%b1%db%8c%d9%88-%d8%a7%d9%86%d8%af%d8%b1%d9%88%db%8c%d8%af/" rel="category tag">خرید vpn کریو اندروید</a></span> </footer><!-- .entry-footer --> </article><!-- #post-3668 --> <div class="card-body"> <nav class="navigation post-navigation" aria-label="Posts"> <h2 class="screen-reader-text">راهبری نوشته</h2> <div class="nav-links"><div class="nav-previous"><a href="https://giftscharge.ir/%d8%ae%d8%b1%db%8c%d8%af-%d8%aa%d8%b9%d8%b7%db%8c%d9%84%d8%a7%d8%aa-%d8%b1%d8%a7-%d8%a8%d8%a7-%da%a9%d8%a7%d8%b1%d8%aa-%d9%87%d8%a7%db%8c-%d9%87%d8%af%db%8c%d9%87-%d8%b3%d8%a7%d8%af%d9%87-%da%a9%d9%86/" rel="prev">خرید تعطیلات را با کارت های هدیه ساده کنید!</a></div></div> </nav> </div> </div> </main><!-- #main --> </div><!-- #primary --> <aside id="secondary" class="widget-area col-sm-12 col-lg-4 mt-xs-4"> <section id="recent-posts-3" class="widget card shadow-sm mb-4 widget_recent_entries"> <h5 class="widget-title card-title">نوشته‌های تازه</h5> <ul> <li> <a href="https://giftscharge.ir/%d8%a7%d9%86%d8%aa%d8%ae%d8%a7%d8%a8-%d8%a7%d9%86%d8%aa%d8%ae%d8%a7%d8%a8%da%af%d8%b1-%d9%85%d9%86%d8%a7%d8%b3%d8%a8-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%b3%da%a9%d8%b1%d9%be%db%8c%d9%86%da%af-%d9%88/" aria-current="page">انتخاب انتخابگر مناسب برای اسکرپینگ وب: CSS یا XPath</a> </li> <li> <a href="https://giftscharge.ir/%d8%ae%d8%b1%db%8c%d8%af-%d8%aa%d8%b9%d8%b7%db%8c%d9%84%d8%a7%d8%aa-%d8%b1%d8%a7-%d8%a8%d8%a7-%da%a9%d8%a7%d8%b1%d8%aa-%d9%87%d8%a7%db%8c-%d9%87%d8%af%db%8c%d9%87-%d8%b3%d8%a7%d8%af%d9%87-%da%a9%d9%86/">خرید تعطیلات را با کارت های هدیه ساده کنید!</a> </li> <li> <a href="https://giftscharge.ir/%d9%be%d8%b1%d9%88%da%a9%d8%b3%db%8c-%d9%88%d8%a8-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86-%d8%b3%d9%88%d9%86%d9%88%d8%b3-%d8%b1%d8%a7-%d9%85%d8%aa%d9%82%d8%a7%d8%b9%d8%af-%d9%85%db%8c-%da%a9%d9%86%d8%af/">پروکسی وب پایتون سونوس را متقاعد می کند تا یوتیوب را پخش کند</a> </li> <li> <a href="https://giftscharge.ir/%d8%b3%d8%b1%d9%88%d8%b1%d9%87%d8%a7%db%8c-%d8%ac%d8%af%db%8c%d8%af-%d9%81%d8%b1%d8%a7%d9%86%d8%b3%d9%87-mehr-vpn/">سرورهای جدید فرانسه – Mehr VPN</a> </li> </ul> </section></aside><!-- #secondary --> </div><!-- .row --> </div><!-- .container --> </div><!-- #content --> <footer id="colophon" class="site-footer border-top"> <div class="container py-3"> <div class="site-info"> <div class="footer-menu-left"> <span class="sep mr-1"> | </span> <span> </span> </div> </div> </div> </footer><!-- #colophon --> </div><!-- #page --> <script type="speculationrules"> {"prefetch":[{"source":"document","where":{"and":[{"href_matches":"/*"},{"not":{"href_matches":["/wp-*.php","/wp-admin/*","/wp-content/uploads/*","/wp-content/*","/wp-content/plugins/*","/wp-content/themes/%2Beducational-zone/*","/*\\?(.+)"]}},{"not":{"selector_matches":"a[rel~=\"nofollow\"]"}},{"not":{"selector_matches":".no-prefetch, .no-prefetch a"}}]},"eagerness":"conservative"}]} </script> <style> :root { -webkit-user-select: none; -webkit-touch-callout: none; -ms-user-select: none; -moz-user-select: none; user-select: none; } </style> <script type="text/javascript"> /*<![CDATA[*/ document.oncontextmenu = function(event) { if (event.target.tagName != 'INPUT' && event.target.tagName != 'TEXTAREA') { event.preventDefault(); } }; document.ondragstart = function() { if (event.target.tagName != 'INPUT' && event.target.tagName != 'TEXTAREA') { event.preventDefault(); } }; /*]]>*/ </script> <script> /(trident|msie)/i.test(navigator.userAgent)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var t,e=location.hash.substring(1);/^[A-z0-9_-]+$/.test(e)&&(t=document.getElementById(e))&&(/^(?:a|select|input|button|textarea)$/i.test(t.tagName)||(t.tabIndex=-1),t.focus())},!1); </script> <script type="text/javascript" src="https://giftscharge.ir/wp-includes/js/imagesloaded.min.js?ver=5.0.0" id="imagesloaded-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-includes/js/masonry.min.js?ver=4.2.2" id="masonry-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/magical-posts-display/assets/js/venobox.min.js?ver=1.0.0" id="venobox-js-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/magical-posts-display/assets/js/mgp-bootstrap.js?ver=1.2.57" id="mgp-bootstrap-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/magical-posts-display/assets/js/main.js?ver=1.2.57" id="mpd-main-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/magical-posts-display/assets/js/mgpd-premium-features.js?ver=1.2.57" id="mgpd-premium-features-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/themes/%2Beducational-zone/assets/js/popper.js?ver=b35946f9fefbcd1e3d083e1b458da49f" id="educational-zone-popper-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/themes/%2Beducational-zone/assets/js/bootstrap.js?ver=b35946f9fefbcd1e3d083e1b458da49f" id="educational-zone-bootstrapjs-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/themes/%2Beducational-zone/assets/js/theme-script.js?ver=b35946f9fefbcd1e3d083e1b458da49f" id="themejs-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/themes/%2Beducational-zone/assets/js/skip-link-focus-fix.js?ver=20151215" id="educational-zone-skip-link-focus-fix-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/gallery-box/assets/js/isotope.pkgd.min.js?ver=2.5.1" id="isotope.pkgd-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/gallery-box/assets/js/venobox.min.js?ver=2.5.1" id="venobox-js"></script> <script type="text/javascript" src="https://giftscharge.ir/wp-content/plugins/gallery-box/assets/js/slick.min.js?ver=2.5.1" id="slick.min-js"></script> <script id="wp-emoji-settings" type="application/json"> {"baseUrl":"https://s.w.org/images/core/emoji/17.0.2/72x72/","ext":".png","svgUrl":"https://s.w.org/images/core/emoji/17.0.2/svg/","svgExt":".svg","source":{"concatemoji":"https://giftscharge.ir/wp-includes/js/wp-emoji-release.min.js?ver=b35946f9fefbcd1e3d083e1b458da49f"}} </script> <script type="module"> /* <![CDATA[ */ /*! This file is auto-generated */ const a=JSON.parse(document.getElementById("wp-emoji-settings").textContent),o=(window._wpemojiSettings=a,"wpEmojiSettingsSupports"),s=["flag","emoji"];function i(e){try{var t={supportTests:e,timestamp:(new Date).valueOf()};sessionStorage.setItem(o,JSON.stringify(t))}catch(e){}}function c(e,t,n){e.clearRect(0,0,e.canvas.width,e.canvas.height),e.fillText(t,0,0);t=new Uint32Array(e.getImageData(0,0,e.canvas.width,e.canvas.height).data);e.clearRect(0,0,e.canvas.width,e.canvas.height),e.fillText(n,0,0);const a=new Uint32Array(e.getImageData(0,0,e.canvas.width,e.canvas.height).data);return t.every((e,t)=>e===a[t])}function p(e,t){e.clearRect(0,0,e.canvas.width,e.canvas.height),e.fillText(t,0,0);var n=e.getImageData(16,16,1,1);for(let e=0;e<n.data.length;e++)if(0!==n.data[e])return!1;return!0}function u(e,t,n,a){switch(t){case"flag":return n(e,"\ud83c\udff3\ufe0f\u200d\u26a7\ufe0f","\ud83c\udff3\ufe0f\u200b\u26a7\ufe0f")?!1:!n(e,"\ud83c\udde8\ud83c\uddf6","\ud83c\udde8\u200b\ud83c\uddf6")&&!n(e,"\ud83c\udff4\udb40\udc67\udb40\udc62\udb40\udc65\udb40\udc6e\udb40\udc67\udb40\udc7f","\ud83c\udff4\u200b\udb40\udc67\u200b\udb40\udc62\u200b\udb40\udc65\u200b\udb40\udc6e\u200b\udb40\udc67\u200b\udb40\udc7f");case"emoji":return!a(e,"\ud83e\u1fac8")}return!1}function f(e,t,n,a){let r;const o=(r="undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope?new OffscreenCanvas(300,150):document.createElement("canvas")).getContext("2d",{willReadFrequently:!0}),s=(o.textBaseline="top",o.font="600 32px Arial",{});return e.forEach(e=>{s[e]=t(o,e,n,a)}),s}function r(e){var t=document.createElement("script");t.src=e,t.defer=!0,document.head.appendChild(t)}a.supports={everything:!0,everythingExceptFlag:!0},new Promise(t=>{let n=function(){try{var e=JSON.parse(sessionStorage.getItem(o));if("object"==typeof e&&"number"==typeof e.timestamp&&(new Date).valueOf()<e.timestamp+604800&&"object"==typeof e.supportTests)return e.supportTests}catch(e){}return null}();if(!n){if("undefined"!=typeof Worker&&"undefined"!=typeof OffscreenCanvas&&"undefined"!=typeof URL&&URL.createObjectURL&&"undefined"!=typeof Blob)try{var e="postMessage("+f.toString()+"("+[JSON.stringify(s),u.toString(),c.toString(),p.toString()].join(",")+"));",a=new Blob([e],{type:"text/javascript"});const r=new Worker(URL.createObjectURL(a),{name:"wpTestEmojiSupports"});return void(r.onmessage=e=>{i(n=e.data),r.terminate(),t(n)})}catch(e){}i(n=f(s,u,c,p))}t(n)}).then(e=>{for(const n in e)a.supports[n]=e[n],a.supports.everything=a.supports.everything&&a.supports[n],"flag"!==n&&(a.supports.everythingExceptFlag=a.supports.everythingExceptFlag&&a.supports[n]);var t;a.supports.everythingExceptFlag=a.supports.everythingExceptFlag&&!a.supports.flag,a.supports.everything||((t=a.source||{}).concatemoji?r(t.concatemoji):t.wpemoji&&t.twemoji&&(r(t.twemoji),r(t.wpemoji)))}); //# sourceURL=https://giftscharge.ir/wp-includes/js/wp-emoji-loader.min.js /* ]]> */ </script> </body> </html>