پرش به محتوای اصلی

شیء المنت (Element)

شیء المنت یک آبجکت است که نشان‌دهنده یک عنصر در عامل کاربر راه دور است، مانند DOM Node هنگام اجرای یک جلسه در مرورگر یا یک عنصر موبایل برای موبایل. این شیء می‌تواند با استفاده از یکی از دستورات متعدد جستجوی عنصر دریافت شود، مانند $، custom$، react$ یا shadow$.

خصوصیات

یک شیء المنت دارای خصوصیات زیر است:

نامنوعجزئیات
sessionIdStringشناسه جلسه تعیین شده از سرور راه دور.
elementIdStringمرجع عنصر وب مرتبط که می‌تواند برای تعامل با عنصر در سطح پروتکل استفاده شود
selectorStringانتخابگر مورد استفاده برای جستجوی عنصر.
parentObjectیا شیء مرورگر هنگامی که عنصر از آن دریافت می‌شود (مثلا const elem = browser.$('selector')) یا یک شیء المنت اگر از محدوده یک عنصر دریافت شده باشد (مثلا elem.$('selector'))
optionsObjectگزینه‌های WebdriverIO بسته به اینکه شیء مرورگر چگونه ایجاد شده است. برای اطلاعات بیشتر انواع راه‌اندازی را ببینید.

متدها

یک شیء المنت تمام متدها را از بخش پروتکل ارائه می‌دهد، مانند پروتکل WebDriver و همچنین دستوراتی که در بخش عنصر فهرست شده‌اند. دستورات پروتکل موجود به نوع جلسه بستگی دارد. اگر یک جلسه مرورگر خودکار را اجرا کنید، هیچ یک از دستورات Appium در دسترس نخواهد بود و برعکس.

علاوه بر این، دستورات زیر در دسترس هستند:

نامپارامترهاجزئیات
addCommand- commandName (نوع: String)
- fn (نوع: Function)
امکان تعریف دستورات سفارشی را می‌دهد که می‌تواند از شیء مرورگر برای اهداف ترکیبی فراخوانی شود. اطلاعات بیشتر را در راهنمای دستور سفارشی بخوانید.
overwriteCommand- commandName (نوع: String)
- fn (نوع: Function)
امکان بازنویسی هر دستور مرورگر با عملکرد سفارشی را می‌دهد. با احتیاط استفاده کنید زیرا ممکن است کاربران فریم‌ورک را گیج کند. اطلاعات بیشتر را در راهنمای دستور سفارشی بخوانید.

نکات

زنجیره المنت

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

const header = await $('#header')
const headline = await header.$('#headline')
console.log(await headline.getText()) // outputs "I am a headline"

با ساختارهای تو در توی عمیق، اختصاص هر عنصر تو در تو به یک آرایه برای استفاده از آن می‌تواند بسیار طولانی باشد. بنابراین WebdriverIO مفهوم جستجوهای زنجیره‌ای عنصر را دارد که امکان بازیابی عناصر تو در تو را به این شکل فراهم می‌کند:

console.log(await $('#header').$('#headline').getText())

این همچنین هنگام بازیابی مجموعه‌ای از عناصر نیز کار می‌کند، مانند:

// get the text of the 3rd headline within the 2nd header
console.log(await $$('#header')[1].$$('#headline')[2].getText())

هنگام کار با مجموعه‌ای از عناصر، این می‌تواند به ویژه هنگام تلاش برای تعامل با آنها مفید باشد، بنابراین به جای انجام:

const elems = await $$('div')
const locations = await Promise.all(
elems.map((el) => el.getLocation())
)

شما می‌توانید مستقیماً متدهای آرایه را در زنجیره عنصر فراخوانی کنید، مانند:

const location = await $$('div').map((el) => el.getLocation())

مشابه:

const divs = await $$('div')
const location = await divs.map((el) => el.getLocation())

WebdriverIO از یک پیاده‌سازی سفارشی استفاده می‌کند که از تکرارکننده‌های غیرهمزمان پشتیبانی می‌کند، بنابراین تمام دستورات از API آنها نیز برای این موارد استفاده پشتیبانی می‌شوند.

نکته: تمام تکرارکننده‌های غیرهمزمان حتی اگر callback شما یک promise برنگرداند، یک promise برمی‌گردانند، مانند:

const divs = await $$('div')
console.log(divs.map((div) => div.selector)) // ❌ returns "Promise<string>[]"
console.log(await divs.map((div) => div.selector)) // ✅ returns "string[]"

دستورات سفارشی

شما می‌توانید دستورات سفارشی را در محدوده مرورگر تنظیم کنید تا گردش‌کارهایی را که معمولاً استفاده می‌شوند، انتزاعی کنید. برای اطلاعات بیشتر، راهنمای ما در مورد دستورات سفارشی را بررسی کنید.

Welcome! How can I help?

WebdriverIO AI Copilot