Page
ページは、ブラウザ内の単一のタブ、またはChromiumの拡張機能のバックグラウンドページと対話するためのメソッドを提供します。1つのブラウザインスタンスは、複数のページインスタンスを持つことができます。
この例では、ページを作成し、URLにナビゲートしてから、スクリーンショットを保存します。
const { webkit } = require('playwright'); // Or 'chromium' or 'firefox'.
(async () => {
const browser = await webkit.launch();
const context = await browser.newContext();
const page = await context.newPage();
await page.goto('https://example.com');
await page.screenshot({ path: 'screenshot.png' });
await browser.close();
})();
Pageクラスは、on、once、removeListenerなどのNodeのネイティブなEventEmitterメソッドを使用して処理できるさまざまなイベント(以下に説明)を発行します。
この例では、単一ページのloadイベントのメッセージをログに記録します。
page.once('load', () => console.log('Page loaded!'));
イベントの登録を解除するには、removeListenerメソッドを使用します。
function logRequest(interceptedRequest) {
console.log('A request was made:', interceptedRequest.url());
}
page.on('request', logRequest);
// Sometime later...
page.removeListener('request', logRequest);
メソッド
addInitScript
v1.9より前に追加以下のいずれかのシナリオで評価されるスクリプトを追加します。
- ページがナビゲートされるたびに。
- 子フレームがアタッチまたはナビゲートされるたびに。この場合、スクリプトは新しくアタッチされたフレームのコンテキストで評価されます。
スクリプトは、ドキュメントが作成された後、そのスクリプトが実行される前に評価されます。これは、JavaScript 環境を修正する場合に役立ちます (例: Math.random をシードする場合)。
使用法
ページが読み込まれる前に Math.random をオーバーライドする例
// preload.js
Math.random = () => 42;
// In your playwright script, assuming the preload.js file is in same directory
await page.addInitScript({ path: './preload.js' });
await page.addInitScript(mock => {
window.mock = mock;
}, mock);
browserContext.addInitScript()とpage.addInitScript()を介してインストールされた複数のスクリプトの評価順序は定義されていません。
引数
-
scriptfunction | string | Object#-
pathstring (optional)JavaScriptファイルへのパス。
pathが相対パスの場合、現在の作業ディレクトリを基準に解決されます。オプションです。 -
contentstring (optional)スクリプトの生のコンテンツ。オプションです。
ページで評価されるスクリプト。
-
-
argSerializable (optional)#スクリプトに渡すオプションの引数(関数を渡す場合にのみサポートされます)。
戻り値
addLocatorHandler
追加されたバージョン: v1.42ウェブページをテストしていると、「サインアップ」ダイアログのような予期しないオーバーレイが表示され、ボタンのクリックなどの自動化したいアクションがブロックされることがあります。これらのオーバーレイは常に同じように、または同じ時間に表示されるわけではないため、自動テストで処理するのが難しいです。
このメソッドを使用すると、オーバーレイが表示されていることを検出したときにアクティブになる、ハンドラーと呼ばれる特別な関数を設定できます。ハンドラーの役割はオーバーレイを削除し、オーバーレイがないかのようにテストを続行できるようにすることです。
留意すべき点
- オーバーレイが予測可能に表示される場合は、page.addLocatorHandler()を使用する代わりに、テストで明示的に待機し、通常のテストフローの一部としてそれを閉じることが推奨されます。
- Playwrightは、実行可能性チェックを必要とするアクションを実行または再試行する前、または自動待機アサーションチェックを実行する前に、オーバーレイを常にチェックします。オーバーレイが表示されている場合、Playwrightは最初にハンドラーを呼び出し、その後アクション/アサーションに進みます。ハンドラーはアクション/アサーションを実行した場合にのみ呼び出されることに注意してください。オーバーレイが表示されてもアクションを実行しない場合、ハンドラーはトリガーされません。
- ハンドラーの実行後、Playwrightはハンドラーをトリガーしたオーバーレイがもはや表示されていないことを保証します。この動作はnoWaitAfterでオプトアウトできます。
- ハンドラーの実行時間は、ハンドラーを実行したアクション/アサーションのタイムアウトにカウントされます。ハンドラーの実行時間が長すぎると、タイムアウトが発生する可能性があります。
- 複数のハンドラーを登録できます。ただし、一度に実行されるハンドラーは1つだけです。ハンドラー内のアクションが他のハンドラーに依存しないようにしてください。
ハンドラーを実行すると、テスト中にページのステートが変更されます。たとえば、現在フォーカスされている要素が変更され、マウスが移動します。ハンドラーの後に実行されるアクションが自己完結型であり、フォーカスとマウスのステートが変更されていないことに依存しないことを確認してください。
たとえば、locator.focus()の後にkeyboard.press()を呼び出すテストを考えてみましょう。これらの2つのアクションの間にハンドラーがボタンをクリックすると、フォーカスされている要素が間違っている可能性が高く、キー入力が予期しない要素で発生します。この問題を回避するには、代わりにlocator.press()を使用してください。
別の例として、mouse.move()の後にmouse.down()が続く一連のマウスアクションがあります。ここでも、これらの2つのアクションの間にハンドラーが実行されると、マウスの位置がマウスダウン中に間違っています。ハンドラーによってステートが変更されないことに依存しない、locator.click()のような自己完結型のアクションを優先してください。
使用法
「ニュースレターに登録する」ダイアログが表示されたときに閉じる例
// Setup the handler.
await page.addLocatorHandler(page.getByText('Sign up to the newsletter'), async () => {
await page.getByRole('button', { name: 'No thanks' }).click();
});
// Write the test as usual.
await page.goto('https://example.com');
await page.getByRole('button', { name: 'Start here' }).click();
「セキュリティ詳細の確認」ページが表示されたときにスキップする例
// Setup the handler.
await page.addLocatorHandler(page.getByText('Confirm your security details'), async () => {
await page.getByRole('button', { name: 'Remind me later' }).click();
});
// Write the test as usual.
await page.goto('https://example.com');
await page.getByRole('button', { name: 'Start here' }).click();
すべてのアクション可能チェックでカスタムコールバックを使用する例。常に表示される<body>ロケーターを使用するため、ハンドラーはすべてのアクション可能チェックの前に呼び出されます。ハンドラーが<body>要素を非表示にしないため、noWaitAfterを指定することが重要です。
// Setup the handler.
await page.addLocatorHandler(page.locator('body'), async () => {
await page.evaluate(() => window.removeObstructionsForTestIfNeeded());
}, { noWaitAfter: true });
// Write the test as usual.
await page.goto('https://example.com');
await page.getByRole('button', { name: 'Start here' }).click();
ハンドラーは元のロケーターを引数として受け取ります。timesを設定することで、指定された回数呼び出された後にハンドラーを自動的に削除することもできます。
await page.addLocatorHandler(page.getByLabel('Close'), async locator => {
await locator.click();
}, { times: 1 });
引数
-
ハンドラーをトリガーするロケーター。
-
handlerfunction(Locator):Promise<Object>#ロケーターが表示されたときに実行される関数。この関数は、クリックなどのアクションをブロックする要素を削除する必要があります。
-
optionsObject (optional)
戻り値
addScriptTag
v1.9より前に追加目的のURLまたはコンテンツを持つ<script>タグをページに追加します。スクリプトのonloadが発火したとき、またはスクリプトコンテンツがフレームに挿入されたときに、追加されたタグを返します。
使用法
await page.addScriptTag();
await page.addScriptTag(options);
引数
optionsObject (optional)
戻り値
addStyleTag
v1.9より前に追加目的のURLを持つ<link rel="stylesheet">タグ、またはコンテンツを持つ<style type="text/css">タグをページに追加します。スタイルシートのonloadが発火したとき、またはCSSコンテンツがフレームに挿入されたときに、追加されたタグを返します。
使用法
await page.addStyleTag();
await page.addStyleTag(options);
引数
optionsObject (optional)
戻り値
bringToFront
v1.9より前に追加ページを前面に表示します(タブをアクティブにします)。
使用法
await page.bringToFront();
戻り値
close
v1.9より前に追加runBeforeUnloadがfalseの場合、アンロードハンドラーを実行せず、ページが閉じるのを待ちます。runBeforeUnloadがtrueの場合、メソッドはアンロードハンドラーを実行しますが、ページの閉じを待ちません。
デフォルトでは、page.close()はbeforeunloadハンドラーを実行しません。
runBeforeUnloadがtrueとして渡された場合、beforeunloadダイアログが呼び出される可能性があり、page.on('dialog')イベントを介して手動で処理する必要があります。
使用法
await page.close();
await page.close(options);
引数
optionsObject (optional)-
reasonstring (optional)追加されたバージョン: v1.40#ページの閉鎖によって中断された操作に報告される理由。
-
runBeforeUnloadboolean (optional)#デフォルトは
falseです。before unloadページハンドラーを実行するかどうか。
-
戻り値
content
v1.9より前に追加doctypeを含む、ページの完全なHTMLコンテンツを取得します。
使用法
await page.content();
戻り値
context
v1.9より前に追加ページが属するブラウザコンテキストを取得します。
使用法
page.context();
戻り値
dragAndDrop
追加バージョン: v1.13このメソッドは、ソース要素をターゲット要素にドラッグします。まずソース要素に移動し、mousedownを実行し、次にターゲット要素に移動してmouseupを実行します。
使用法
await page.dragAndDrop('#source', '#target');
// or specify exact positions relative to the top-left corners of the elements:
await page.dragAndDrop('#source', '#target', {
sourcePosition: { x: 34, y: 7 },
targetPosition: { x: 10, y: 20 },
});
引数
-
ドラッグする要素を検索するためのセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
ドロップする要素を検索するためのセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
noWaitAfterboolean (optional)#非推奨このオプションは効果がありません。
このオプションは効果がありません。
-
sourcePositionObject (optional)追加されたバージョン: v1.14#要素のパディングボックスの左上隅を基準としたこの点でソース要素をクリックします。指定しない場合、要素のいくつかの可視点が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
targetPositionObject (optional)追加されたバージョン: v1.14#要素のパディングボックスの左上隅を基準としたこの点でターゲット要素にドロップします。指定しない場合、要素のいくつかの可視点が使用されます。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
設定されている場合、このメソッドはアクション可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。要素がアクションを実行する準備ができるまで、実行せずに待機するのに便利です。
-
戻り値
emulateMedia
v1.9より前に追加このメソッドは、media引数によってCSS media typeを、および/またはcolorScheme引数を使用して'prefers-colors-scheme'メディア機能を変更します。
使用法
await page.evaluate(() => matchMedia('screen').matches);
// → true
await page.evaluate(() => matchMedia('print').matches);
// → false
await page.emulateMedia({ media: 'print' });
await page.evaluate(() => matchMedia('screen').matches);
// → false
await page.evaluate(() => matchMedia('print').matches);
// → true
await page.emulateMedia({});
await page.evaluate(() => matchMedia('screen').matches);
// → true
await page.evaluate(() => matchMedia('print').matches);
// → false
await page.emulateMedia({ colorScheme: 'dark' });
await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches);
// → true
await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches);
// → false
引数
optionsObject (optional)-
colorSchemenull | "light" | "dark" | "no-preference" (optional)追加バージョン: v1.9#prefers-colors-schemeメディア機能をエミュレートします。サポートされる値は
'light'と'dark'です。nullを渡すと、カラースキームのエミュレーションが無効になります。'no-preference'は非推奨です。 -
contrastnull | "no-preference" | "more" (optional)追加バージョン: v1.51#'prefers-contrast'メディア機能をエミュレートします。サポートされる値は'no-preference'、'more'です。nullを渡すと、コントラストエミュレーションが無効になります。 -
forcedColorsnull | "active" | "none" (optional)追加されたバージョン: v1.15#'forced-colors'メディア機能をエミュレートします。サポートされる値は'active'と'none'です。nullを渡すと、強制色エミュレーションが無効になります。 -
medianull | "screen" | "print" (optional)追加バージョン: v1.9#ページのCSSメディアタイプを変更します。許可される値は
'screen'、'print'、およびnullのみです。nullを渡すと、CSSメディアエミュレーションが無効になります。 -
reducedMotionnull | "reduce" | "no-preference" (optional)追加日: v1.12#'prefers-reduced-motion'メディア機能をエミュレートします。サポートされる値は'reduce'、'no-preference'です。nullを渡すと、モーション削減エミュレーションが無効になります。
-
戻り値
evaluate
v1.9より前に追加pageFunctionの呼び出しの値を返します。
page.evaluate()に渡された関数がPromiseを返す場合、page.evaluate()はそのPromiseが解決するのを待ち、その値を返します。
page.evaluate()に渡された関数が非Serializableな値を返す場合、page.evaluate()はundefinedに解決されます。Playwrightは、JSONによってシリアル化できないいくつかの追加の値も転送することをサポートしています: -0、NaN、Infinity、-Infinity。
使用法
pageFunctionに引数を渡す
const result = await page.evaluate(([x, y]) => {
return Promise.resolve(x * y);
}, [7, 8]);
console.log(result); // prints "56"
関数ではなく文字列を渡すこともできます。
console.log(await page.evaluate('1 + 2')); // prints "3"
const x = 10;
console.log(await page.evaluate(`1 + ${x}`)); // prints "11"
ElementHandleインスタンスはpage.evaluate()の引数として渡すことができます。
const bodyHandle = await page.evaluate('document.body');
const html = await page.evaluate<string, HTMLElement>(([body, suffix]) =>
body.innerHTML + suffix, [bodyHandle, 'hello']
);
await bodyHandle.dispose();
引数
-
pageFunctionfunction | string#ページコンテキストで評価される関数。
-
argEvaluationArgument (optional)#pageFunctionに渡すオプションの引数。
戻り値
evaluateHandle
v1.9より前に追加pageFunction呼び出しの値をJSHandleとして返します。
page.evaluate()とpage.evaluateHandle()の唯一の違いは、page.evaluateHandle()がJSHandleを返すことです。
page.evaluateHandle()に渡された関数がPromiseを返す場合、page.evaluateHandle()はそのPromiseが解決するのを待ち、その値を返します。
使用法
// Handle for the window object.
const aWindowHandle = await page.evaluateHandle(() => Promise.resolve(window));
関数ではなく文字列を渡すこともできます。
const aHandle = await page.evaluateHandle('document'); // Handle for the 'document'
JSHandleインスタンスはpage.evaluateHandle()の引数として渡すことができます。
const aHandle = await page.evaluateHandle(() => document.body);
const resultHandle = await page.evaluateHandle(body => body.innerHTML, aHandle);
console.log(await resultHandle.jsonValue());
await resultHandle.dispose();
引数
-
pageFunctionfunction | string#ページコンテキストで評価される関数。
-
argEvaluationArgument (optional)#pageFunctionに渡すオプションの引数。
戻り値
exposeBinding
v1.9より前に追加このメソッドは、このページのすべてのフレームのwindowオブジェクトにnameという関数を追加します。呼び出されると、関数はcallbackを実行し、Promiseを返します。これはcallbackの戻り値に解決されます。callbackがPromiseを返す場合、それが待機されます。
callback関数の最初の引数には、呼び出し元に関する情報が含まれます: { browserContext: BrowserContext, page: Page, frame: Frame }。
コンテキスト全体版については、browserContext.exposeBinding()を参照してください。
page.exposeBinding()を介してインストールされた関数はナビゲーション後も存続します。
使用法
ページURLをページのすべてのフレームに公開する例
const { webkit } = require('playwright'); // Or 'chromium' or 'firefox'.
(async () => {
const browser = await webkit.launch({ headless: false });
const context = await browser.newContext();
const page = await context.newPage();
await page.exposeBinding('pageURL', ({ page }) => page.url());
await page.setContent(`
<script>
async function onClick() {
document.querySelector('div').textContent = await window.pageURL();
}
</script>
<button onclick="onClick()">Click me</button>
<div></div>
`);
await page.click('button');
})();
引数
-
ウィンドウオブジェクト上の関数の名前。
-
Playwright のコンテキストで呼び出されるコールバック関数。
-
optionsObject (optional)
戻り値
exposeFunction
v1.9より前に追加このメソッドは、ページのすべてのフレームのwindowオブジェクトにnameという関数を追加します。呼び出されると、関数はcallbackを実行し、Promiseを返します。これはcallbackの戻り値に解決されます。
callbackがPromiseを返す場合、それが待機されます。
コンテキスト全体の公開関数については、browserContext.exposeFunction()を参照してください。
page.exposeFunction()を介してインストールされた関数はナビゲーション後も存続します。
使用法
ページにsha256関数を追加する例
const { webkit } = require('playwright'); // Or 'chromium' or 'firefox'.
const crypto = require('crypto');
(async () => {
const browser = await webkit.launch({ headless: false });
const page = await browser.newPage();
await page.exposeFunction('sha256', text =>
crypto.createHash('sha256').update(text).digest('hex'),
);
await page.setContent(`
<script>
async function onClick() {
document.querySelector('div').textContent = await window.sha256('PLAYWRIGHT');
}
</script>
<button onclick="onClick()">Click me</button>
<div></div>
`);
await page.click('button');
})();
引数
戻り値
frame
v1.9より前に追加指定された条件に一致するフレームを返します。nameまたはurlのいずれかを指定する必要があります。
使用法
const frame = page.frame('frame-name');
const frame = page.frame({ url: /.*domain.*/ });
引数
-
frameSelectorstring | Object#-
namestring (optional)iframeのname属性で指定されたフレーム名。オプション。 -
urlstring | RegExp | function(URL):boolean (optional)フレームの
urlをURLオブジェクトとして受け取るグロブパターン、正規表現パターン、または述語。オプション。
フレーム名またはその他のフレーム検索オプション。
-
戻り値
frameLocator
追加バージョン: v1.17iframeを操作する場合、iframeに入り、そのiframe内の要素を選択できるフレームロケーターを作成できます。
使用法
次のスニペットは、IDがmy-frameのiframeにあるテキスト「Submit」を持つ要素を検索します(例: <iframe id="my-frame">)。
const locator = page.frameLocator('#my-iframe').getByText('Submit');
await locator.click();
引数
戻り値
frames
v1.9より前に追加ページにアタッチされたすべてのフレームの配列。
使用法
page.frames();
戻り値
getByAltText
追加バージョン: v1.27要素をそのaltテキストで特定できます。
使用法
例えば、このメソッドはaltテキスト「Playwright logo」で画像を見つけます。
<img alt='Playwright logo'>
await page.getByAltText('Playwright logo').click();
引数
-
要素を特定するためのテキスト。
-
optionsObject (optional)
戻り値
getByLabel
追加バージョン: v1.27関連する<label>またはaria-labelledby要素のテキスト、またはaria-label属性によって入力要素を特定できます。
使用法
例えば、このメソッドは以下のDOMでラベル「Username」と「Password」を持つ入力を見つけます。
<input aria-label="Username">
<label for="password-input">Password:</label>
<input id="password-input">
await page.getByLabel('Username').fill('john');
await page.getByLabel('Password').fill('secret');
引数
-
要素を特定するためのテキスト。
-
optionsObject (optional)
戻り値
getByPlaceholder
追加バージョン: v1.27プレースホルダーテキストによって入力要素を特定できます。
使用法
例えば、以下のDOM構造を考えてみましょう。
<input type="email" placeholder="name@example.com" />
プレースホルダーテキストで入力を見つけてから、入力できます。
await page
.getByPlaceholder('name@example.com')
.fill('playwright@microsoft.com');
引数
-
要素を特定するためのテキスト。
-
optionsObject (optional)
戻り値
getByRole
追加バージョン: v1.27要素をそのARIAロール、ARIA属性、およびアクセシブルネームで特定できます。
使用法
以下のDOM構造を考えてみましょう。
<h3>Sign up</h3>
<label>
<input type="checkbox" /> Subscribe
</label>
<br/>
<button>Submit</button>
各要素をその暗黙的なロールで特定できます。
await expect(page.getByRole('heading', { name: 'Sign up' })).toBeVisible();
await page.getByRole('checkbox', { name: 'Subscribe' }).check();
await page.getByRole('button', { name: /submit/i }).click();
引数
-
role"alert" | "alertdialog" | "application" | "article" | "banner" | "blockquote" | "button" | "caption" | "cell" | "checkbox" | "code" | "columnheader" | "combobox" | "complementary" | "contentinfo" | "definition" | "deletion" | "dialog" | "directory" | "document" | "emphasis" | "feed" | "figure" | "form" | "generic" | "grid" | "gridcell" | "group" | "heading" | "img" | "insertion" | "link" | "list" | "listbox" | "listitem" | "log" | "main" | "marquee" | "math" | "meter" | "menu" | "menubar" | "menuitem" | "menuitemcheckbox" | "menuitemradio" | "navigation" | "none" | "note" | "option" | "paragraph" | "presentation" | "progressbar" | "radio" | "radiogroup" | "region" | "row" | "rowgroup" | "rowheader" | "scrollbar" | "search" | "searchbox" | "separator" | "slider" | "spinbutton" | "status" | "strong" | "subscript" | "superscript" | "switch" | "tab" | "table" | "tablist" | "tabpanel" | "term" | "textbox" | "time" | "timer" | "toolbar" | "tooltip" | "tree" | "treegrid" | "treeitem"#必須のariaロール。
-
optionsObject (optional)-
通常、
aria-checkedまたはネイティブの<input type=checkbox>コントロールによって設定される属性。aria-checkedの詳細。 -
通常、
aria-disabledまたはdisabledによって設定される属性。注他のほとんどの属性とは異なり、
disabledはDOM階層を介して継承されます。aria-disabledの詳細。 -
exactboolean (オプション)追加バージョン: v1.28#nameが完全に一致するかどうか: 大文字と小文字を区別し、文字列全体。デフォルトはfalseです。nameが正規表現の場合は無視されます。厳密な一致でも空白はトリムされることに注意してください。
-
通常、
aria-expandedによって設定される属性。aria-expandedの詳細。 -
includeHiddenboolean (optional)#非表示要素が一致するかどうかを制御するオプション。デフォルトでは、ARIAで定義されているように、非表示でない要素のみがロールセレクターによって一致します。
aria-hiddenの詳細。 -
通常、
heading、listitem、row、treeitemのロールに存在する数値属性で、<h1>-<h6>要素のデフォルト値があります。aria-levelの詳細。 -
namestring | RegExp (optional)#アクセシブルネームに一致するオプション。デフォルトでは、大文字と小文字を区別せず、部分文字列を検索します。この動作を制御するにはexactを使用します。
アクセシブルネームの詳細。
-
通常、
aria-pressedによって設定される属性。aria-pressedの詳細。 -
通常、
aria-selectedによって設定される属性。aria-selectedの詳細。
-
戻り値
詳細
ロールセレクターは、アクセシビリティ監査や適合性テストを**置き換えるものではなく**、ARIAガイドラインに関する早期のフィードバックを提供します。
多くのHTML要素には、ロールセレクターによって認識される暗黙的に定義されたロールがあります。サポートされているすべてのロールはこちらで確認できます。ARIAガイドラインは、roleおよび/またはaria-*属性をデフォルト値に設定して暗黙的なロールと属性を重複させることを**推奨しません**。
getByTestId
追加バージョン: v1.27テストIDによって要素を特定します。
使用法
以下のDOM構造を考えてみましょう。
<button data-testid="directions">Itinéraire</button>
テストIDによって要素を特定できます。
await page.getByTestId('directions').click();
引数
戻り値
詳細
デフォルトでは、data-testid属性がテストIDとして使用されます。必要に応じて、selectors.setTestIdAttribute()を使用して別のテストID属性を設定できます。
// Set custom test id attribute from @playwright/test config:
import { defineConfig } from '@playwright/test';
export default defineConfig({
use: {
testIdAttribute: 'data-pw'
},
});
getByText
追加バージョン: v1.27指定されたテキストを含む要素を特定できます。
アクセシブルロールなどの他の基準で一致させ、その後テキストコンテンツでフィルターできるlocator.filter()も参照してください。
使用法
以下のDOM構造を考えてみましょう。
<div>Hello <span>world</span></div>
<div>Hello</div>
テキストの部分文字列、完全な文字列、または正規表現で特定できます。
// Matches <span>
page.getByText('world');
// Matches first <div>
page.getByText('Hello world');
// Matches second <div>
page.getByText('Hello', { exact: true });
// Matches both <div>s
page.getByText(/Hello/);
// Matches second <div>
page.getByText(/^hello$/i);
引数
-
要素を特定するためのテキスト。
-
optionsObject (optional)
戻り値
詳細
テキストによる一致は、厳密な一致であっても常に空白を正規化します。例えば、複数のスペースを1つにまとめ、改行をスペースに変換し、先頭と末尾の空白を無視します。
buttonおよびsubmit型の入力要素は、テキストコンテンツの代わりにそのvalueによって一致します。例えば、テキスト"Log in"で特定すると、<input type=button value="Log in">が一致します。
getByTitle
追加バージョン: v1.27要素をそのタイトル属性で特定できます。
使用法
以下のDOM構造を考えてみましょう。
<span title='Issues count'>25 issues</span>
タイトルテキストで問題数を特定した後、確認できます。
await expect(page.getByTitle('Issues count')).toHaveText('25 issues');
引数
-
要素を特定するためのテキスト。
-
optionsObject (optional)
戻り値
goBack
v1.9より前に追加メインリソース応答を返します。複数のリダイレクトの場合、ナビゲーションは最後のリダイレクトの応答で解決されます。戻ることができない場合、nullを返します。
履歴の前のページに移動します。
使用法
await page.goBack();
await page.goBack(options);
引数
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (optional)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
goForward
v1.9より前に追加メインリソース応答を返します。複数のリダイレクトの場合、ナビゲーションは最後のリダイレクトの応答で解決されます。進むことができない場合、nullを返します。
履歴の次のページに移動します。
使用法
await page.goForward();
await page.goForward(options);
引数
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (optional)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
goto
v1.9より前に追加メインリソース応答を返します。複数のリダイレクトの場合、ナビゲーションは最初の非リダイレクト応答で解決されます。
このメソッドは、以下の場合にエラーをスローします。
- SSLエラーがある場合(例: 自己署名証明書の場合)。
- ターゲットURLが無効な場合。
- ナビゲーション中にtimeoutを超過した場合。
- リモートサーバーが応答しないか、アクセスできない場合。
- メインリソースの読み込みに失敗した場合。
このメソッドは、リモートサーバーから有効なHTTPステータスコード(404 "Not Found"や500 "Internal Server Error"を含む)が返された場合、エラーをスローしません。そのような応答のステータスコードは、response.status()を呼び出すことで取得できます。
このメソッドは、エラーをスローするか、メインリソース応答を返します。唯一の例外は、about:blankへのナビゲーション、または異なるハッシュを持つ同じURLへのナビゲーションであり、これらは成功しnullを返します。
ヘッドレスモードはPDFドキュメントへのナビゲーションをサポートしていません。上流の問題を参照してください。
使用法
await page.goto(url);
await page.goto(url, options);
引数
-
ページをナビゲートするURL。URLにはスキーム(例:
https://)を含める必要があります。コンテキストオプションでbaseURLが提供され、渡されたURLがパスの場合、new URL()コンストラクターによってマージされます。 -
optionsObject (optional)-
Refererヘッダー値。提供された場合、page.setExtraHTTPHeaders()によって設定されたrefererヘッダー値よりも優先されます。
-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (optional)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
isClosed
v1.9より前に追加ページが閉じられたことを示します。
使用法
page.isClosed();
戻り値
locator
追加されたバージョン: v1.14このメソッドは、このページ/フレームでアクションを実行するために使用できる要素ロケーターを返します。ロケーターはアクションを実行する直前に要素に解決されるため、同じロケーターに対する一連のアクションは、実際には異なるDOM要素に対して実行される可能性があります。これは、それらのアクション間でDOM構造が変更された場合に発生します。
使用法
page.locator(selector);
page.locator(selector, options);
引数
-
DOM要素を解決するときに使用するセレクター。
-
optionsObject (optional)-
この相対ロケーターに一致する要素を含む結果にメソッドの結果を絞り込みます。例えば、
text=Playwrightを持つarticleは<article><div>Playwright</div></article>に一致します。内部ロケーターは**外部ロケーターに対して相対的**でなければならず、ドキュメントルートではなく外部ロケーターの一致からクエリが開始されます。例えば、
<article><content><div>Playwright</div></content></article>でdivを持つcontentを見つけることができます。しかし、article divを持つcontentを探すと、内部ロケーターは相対的でなければならず、contentの外部の要素を使用すべきではないため、失敗します。外部ロケーターと内部ロケーターは同じフレームに属している必要があります。内部ロケーターにはFrameLocatorを含めることはできません。
-
hasNotLocator (オプション)追加バージョン: v1.33#内部ロケーターに一致する要素を含まない要素に一致します。内部ロケーターは外部ロケーターに対してクエリされます。例えば、
divを持たないarticleは<article><span>Playwright</span></article>に一致します。外部ロケーターと内部ロケーターは同じフレームに属している必要があります。内部ロケーターにはFrameLocatorを含めることはできません。
-
hasNotTextstring | RegExp (オプション)追加バージョン: v1.33#指定されたテキストを内部のどこか(子または子孫要素内も含む)に含まない要素に一致します。stringが渡された場合、大文字小文字を区別せず、部分文字列を検索します。
-
hasTextstring | RegExp (optional)#指定されたテキストを内部のどこか(子または子孫要素内も含む)に含む要素に一致します。stringが渡された場合、大文字小文字を区別せず、部分文字列を検索します。例えば、
"Playwright"は<article><div>Playwright</div></article>に一致します。
-
戻り値
mainFrame
v1.9より前に追加ページのメインフレーム。ページにはナビゲーション中に持続するメインフレームがあることが保証されます。
使用法
page.mainFrame();
戻り値
opener
v1.9より前に追加ポップアップページの場合にオープナーを返し、その他の場合はnullを返します。オープナーがすでに閉じられている場合、nullを返します。
使用法
await page.opener();
戻り値
pause
追加バージョン: v1.9スクリプトの実行を一時停止します。Playwrightはスクリプトの実行を停止し、ユーザーがページオーバーレイの「Resume」ボタンを押すか、DevToolsコンソールでplaywright.resume()を呼び出すのを待ちます。
ユーザーは一時停止中にセレクターを検査したり、手動のステップを実行したりできます。再開すると、元のスクリプトは一時停止した場所から実行を続けます。
このメソッドは、Playwrightがヘッドレスオプションを偽の値に設定したヘッドモードで起動されている必要があります。
使用法
await page.pause();
戻り値
pdf
v1.9より前に追加PDFバッファを返します。
page.pdf()は、printCSSメディアでページのPDFを生成します。screenメディアでPDFを生成するには、page.pdf()を呼び出す前にpage.emulateMedia()を呼び出します。
デフォルトでは、page.pdf()は印刷用に色が変更されたPDFを生成します。正確な色のレンダリングを強制するには、-webkit-print-color-adjustプロパティを使用します。
使用法
// Generates a PDF with 'screen' media type.
await page.emulateMedia({ media: 'screen' });
await page.pdf({ path: 'page.pdf' });
width、height、marginオプションは、単位付きの値を受け入れます。単位なしの値はピクセルとして扱われます。
いくつかの例
page.pdf({width: 100})- 幅を100ピクセルに設定して印刷page.pdf({width: '100px'})- 幅を100ピクセルに設定して印刷page.pdf({width: '10cm'})- 幅を10センチメートルに設定して印刷。
すべての可能な単位は
px- ピクセルin- インチcm- センチメートルmm- ミリメートル
formatオプションは次のとおりです。
Letter: 8.5インチ x 11インチLegal: 8.5インチ x 14インチTabloid: 11インチ x 17インチLedger: 17インチ x 11インチA0: 33.1インチ x 46.8インチA1: 23.4インチ x 33.1インチA2: 16.54インチ x 23.4インチA3: 11.7インチ x 16.54インチA4: 8.27インチ x 11.7インチA5: 5.83インチ x 8.27インチA6: 4.13インチ x 5.83インチ
headerTemplateとfooterTemplateのマークアップには次の制限があります: > 1. テンプレート内のスクリプトタグは評価されません。 > 2. テンプレート内でページのスタイルは表示されません。
引数
optionsObject (optional)-
displayHeaderFooterboolean (optional)#ヘッダーとフッターを表示します。デフォルトは
falseです。 -
footerTemplatestring (optional)#印刷フッターのHTMLテンプレート。headerTemplateと同じ形式を使用する必要があります。
-
用紙形式。設定されている場合、widthまたはheightオプションよりも優先されます。デフォルトは「Letter」です。
-
headerTemplatestring (optional)#印刷ヘッダーのHTMLテンプレート。印刷値を挿入するために次のクラスが使用される有効なHTMLマークアップである必要があります。
'date'形式化された印刷日付'title'ドキュメントタイトル'url'ドキュメントの場所'pageNumber'現在のページ番号'totalPages'ドキュメントの総ページ数
-
heightstring | number (optional)#用紙の高さ。単位付きの値を受け入れます。
-
用紙の向き。デフォルトは
falseです。 -
-
topstring | number (optional)上余白。単位付きの値を受け入れます。デフォルトは
0です。 -
rightstring | number (optional)右余白。単位付きの値を受け入れます。デフォルトは
0です。 -
bottomstring | number (optional)下余白。単位付きの値を受け入れます。デフォルトは
0です。 -
leftstring | number (optional)左余白。単位付きの値を受け入れます。デフォルトは
0です。
用紙の余白。デフォルトはなし。
-
-
outlineboolean (optional)追加されたバージョン: v1.42#ドキュメントのアウトラインをPDFに埋め込むかどうか。デフォルトは
falseです。 -
印刷するページの範囲。例: '1-5, 8, 11-13'。デフォルトは空文字列で、すべてのページを印刷することを意味します。
-
PDFを保存するファイルパス。pathが相対パスの場合、現在の作業ディレクトリを基準に解決されます。パスが指定されていない場合、PDFはディスクに保存されません。
-
preferCSSPageSizeboolean (optional)#ページで宣言されたCSS
@pageサイズを、widthとheightまたはformatオプションで宣言されたものよりも優先させます。デフォルトはfalseで、コンテンツを用紙サイズに合わせてスケーリングします。 -
printBackgroundboolean (optional)#背景グラフィックを印刷します。デフォルトは
falseです。 -
ウェブページのレンダリングのスケール。デフォルトは
1です。スケール量は0.1から2の間である必要があります。 -
taggedboolean (optional)追加されたバージョン: v1.42#タグ付けされた(アクセシブルな)PDFを生成するかどうか。デフォルトは
falseです。 -
widthstring | number (optional)#用紙の幅。単位付きの値を受け入れます。
-
戻り値
reload
v1.9より前に追加このメソッドは、ユーザーがブラウザの更新をトリガーしたかのように、現在のページをリロードします。メインリソース応答を返します。複数のリダイレクトの場合、ナビゲーションは最後のリダイレクトの応答で解決されます。
使用法
await page.reload();
await page.reload(options);
引数
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (optional)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
removeAllListeners
追加されたバージョン: v1.47指定されたタイプのリスナーをすべて削除します (タイプが指定されていない場合は、登録されているすべてのリスナーを削除します)。非同期リスナーが完了するのを待機したり、それらのリスナーからの後続のエラーを無視したりすることができます。
使用法
page.on('request', async request => {
const response = await request.response();
const body = await response.body();
console.log(body.byteLength);
});
await page.goto('https://playwright.dokyumento.jp', { waitUntil: 'domcontentloaded' });
// Waits for all the reported 'request' events to resolve.
await page.removeAllListeners('request', { behavior: 'wait' });
引数
typestring (オプション)#optionsObject (optional)-
behavior"wait" | "ignoreErrors" | "default" (オプション)#すでに実行中のリスナーを待機するかどうか、およびエラーが発生した場合にどうするかを指定します。
'default'- 現在のリスナー呼び出し (ある場合) が完了するのを待機しません。リスナーがエラーをスローした場合、未処理のエラーが発生する可能性があります。'wait'- 現在のリスナー呼び出し (ある場合) が完了するのを待機します。'ignoreErrors'- 現在のリスナー呼び出し (ある場合) が完了するのを待機しません。削除後にリスナーによってスローされたすべてのエラーは、通知なしにキャッチされます。
-
戻り値
removeLocatorHandler
追加バージョン: v1.44特定のロケーターに対して page.addLocatorHandler() によって追加されたすべてのロケーターハンドラーを削除します。
使用法
await page.removeLocatorHandler(locator);
引数
-
page.addLocatorHandler() に渡されたロケーター。
戻り値
requestGC
追加日: v1.48ページにガベージコレクションを実行するように要求します。到達不能なすべてのオブジェクトが収集される保証はありません。
これはメモリリークを検出するのに役立ちます。たとえば、ページにリークする可能性のある大きなオブジェクト 'suspect' がある場合、WeakRef を使用してリークしないことを確認できます。
// 1. In your page, save a WeakRef for the "suspect".
await page.evaluate(() => globalThis.suspectWeakRef = new WeakRef(suspect));
// 2. Request garbage collection.
await page.requestGC();
// 3. Check that weak ref does not deref to the original object.
expect(await page.evaluate(() => !globalThis.suspectWeakRef.deref())).toBe(true);
使用法
await page.requestGC();
戻り値
route
v1.9より前に追加ルーティングは、ページによって行われるネットワークリクエストを変更する機能を提供します。
ルーティングが有効になると、URLパターンに一致するすべてのリクエストは、続行、完了、または中止されない限り停止します。
レスポンスがリダイレクトの場合、ハンドラーは最初のURLに対してのみ呼び出されます。
page.route() は、サービスワーカーによってインターセプトされたリクエストをインターセプトしません。この issue を参照してください。リクエストインターセプトを使用する際には、serviceWorkers を 'block' に設定してサービスワーカーを無効にすることをお勧めします。
page.route() は、ポップアップページの最初のリクエストをインターセプトしません。代わりに browserContext.route() を使用してください。
使用法
すべての画像リクエストを中止する素朴なハンドラの例
const page = await browser.newPage();
await page.route('**/*.{png,jpg,jpeg}', route => route.abort());
await page.goto('https://example.com');
await browser.close();
または、代わりに正規表現パターンを使用する同じスニペット
const page = await browser.newPage();
await page.route(/(\.png$)|(\.jpg$)/, route => route.abort());
await page.goto('https://example.com');
await browser.close();
リクエストを調べてルートアクションを決定することができます。たとえば、一部の POST データを含むすべてのリクエストをモックし、その他のすべてのリクエストをそのままにするなどです。
await page.route('/api/**', async route => {
if (route.request().postData().includes('my-string'))
await route.fulfill({ body: 'mocked-data' });
else
await route.continue();
});
リクエストが両方のハンドラーに一致する場合、ページルーティングはブラウザコンテキストルーティング (browserContext.route() で設定) よりも優先されます。
ハンドラー付きのルートを削除するには、page.unroute() を使用できます。
ルーティングを有効にすると、HTTP キャッシュが無効になります。
引数
-
urlstring | RegExp | function(URL):boolean#ルーティング中に一致する URL を受け取るグロブパターン、正規表現パターン、または述語。コンテキストオプションで baseURL が設定されており、提供されたURLが
*で始まらない文字列の場合、new URL()コンストラクタを使用して解決されます。 -
handlerfunction(Route, Request):Promise<Object> | Object#リクエストをルーティングするハンドラ関数。
-
optionsObject (optional)
戻り値
routeFromHAR
追加日: v1.23指定されている場合、ページで行われるネットワークリクエストはHARファイルから提供されます。HARからの再生 について詳しくはこちらをご覧ください。
Playwrightは、サービスワーカーによってインターセプトされたリクエストをHARファイルから提供しません。この issue を参照してください。リクエストインターセプトを使用する際には、serviceWorkers を 'block' に設定してサービスワーカーを無効にすることをお勧めします。
使用法
await page.routeFromHAR(har);
await page.routeFromHAR(har, options);
引数
-
事前に記録されたネットワークデータを含む HAR ファイルへのパス。
pathが相対パスの場合、現在の作業ディレクトリに対して解決されます。 -
optionsObject (optional)-
notFound"abort" | "fallback" (オプション)#- 'abort' に設定されている場合、HAR ファイルに見つからないリクエストは中止されます。
- 'fallback' に設定すると、見つからないリクエストはネットワークに送信されます。
デフォルトは abort です。
-
指定されている場合、ファイルから提供する代わりに、実際のネットワーク情報で指定されたHARを更新します。ファイルは browserContext.close() が呼び出されたときにディスクに書き込まれます。
-
updateContent"embed" | "attach" (オプション)追加日: v1.32#リソースコンテンツ管理を制御するためのオプション設定。
attachが指定されている場合、リソースは個別のファイルまたは ZIP アーカイブ内のエントリとして永続化されます。embedが指定されている場合、コンテンツは HAR ファイル内にインラインで格納されます。 -
updateMode"full" | "minimal" (オプション)追加日: v1.32#minimalに設定すると、HAR からルーティングするために必要な情報のみが記録されます。これにより、HAR からリプレイするときに使用されないサイズ、タイミング、ページ、クッキー、セキュリティ、およびその他の種類の HAR 情報が省略されます。デフォルトはminimalです。 -
リクエスト URL に一致するグロブパターン、正規表現、または述語。パターンに一致する URL を持つリクエストのみが HAR ファイルから提供されます。指定されていない場合、すべてのリクエストが HAR ファイルから提供されます。
-
戻り値
routeWebSocket
追加日: v1.48このメソッドを使用すると、ページによって行われるwebsocket接続を変更できます。
このメソッドが呼び出された後に作成された WebSocket のみがルーティングされることに注意してください。ページをナビゲートする前にこのメソッドを呼び出すことをお勧めします。
使用法
以下は、単一のメッセージに応答する簡単なモックの例です。詳細と例については、WebSocketRoute を参照してください。
await page.routeWebSocket('/ws', ws => {
ws.onMessage(message => {
if (message === 'request')
ws.send('response');
});
});
引数
-
urlstring | RegExp | function(URL):boolean#このパターンに一致するURLを持つWebSocketのみがルーティングされます。文字列パターンは、baseURL コンテキストオプションに相対的になります。
-
handlerfunction(WebSocketRoute):Promise<Object> | Object#WebSocket をルーティングするハンドラ関数。
戻り値
screenshot
v1.9より前に追加キャプチャされたスクリーンショットを含むバッファを返します。
使用法
await page.screenshot();
await page.screenshot(options);
引数
optionsObject (optional)-
animations"disabled" | "allow" (オプション)#"disabled"に設定すると、CSSアニメーション、CSSトランジション、Webアニメーションが停止します。アニメーションは期間によって異なる扱いを受けます。- 有限のアニメーションは完了まで早送りされ、
transitionendイベントが発生します。 - 無限のアニメーションは初期状態にキャンセルされ、スクリーンショットの後に再生されます。
デフォルトは
"allow"で、アニメーションはそのまま残されます。 - 有限のアニメーションは完了まで早送りされ、
-
caret"hide" | "initial" (オプション)#"hide"に設定すると、スクリーンショットはテキストキャレットを非表示にします。"initial"に設定すると、テキストキャレットの動作は変更されません。デフォルトは"hide"です。 -
結果の画像のクリッピングを指定するオブジェクト。
-
trueの場合、現在表示されているビューポートではなく、スクロール可能なページ全体のスクリーンショットを撮ります。デフォルトは
falseです。 -
スクリーンショットを撮る際にマスクする必要があるロケーターを指定します。マスクされた要素は、バウンディングボックスを完全に覆うピンクのボックス
#FF00FF(maskColor でカスタマイズ) でオーバーレイされます。マスクは不可視の要素にも適用されます。可視要素のみを照合する を参照して、これを無効にしてください。 -
maskColorstring (オプション)追加されたバージョン: v1.35#CSSカラー形式で、マスクされた要素のオーバーレイボックスの色を指定します。デフォルトの色はピンク
#FF00FFです。 -
omitBackgroundboolean (オプション)#デフォルトの白い背景を非表示にし、透過性のあるスクリーンショットをキャプチャできるようにします。
jpeg画像には適用されません。デフォルトはfalseです。 -
画像を保存するファイルパス。スクリーンショットのタイプはファイル拡張子から推測されます。path が相対パスの場合、現在の作業ディレクトリに相対的に解決されます。パスが指定されていない場合、画像はディスクに保存されません。
-
画像の品質(0~100)。
png画像には適用されません。 -
scale"css" | "device" (オプション)#"css"に設定すると、スクリーンショットはページ上の各CSSピクセルにつき1ピクセルになります。高DPIデバイスの場合、これによりスクリーンショットが小さく保たれます。"device"オプションを使用すると、各デバイスピクセルにつき1ピクセルが生成されるため、高DPIデバイスのスクリーンショットは2倍以上大きくなります。デフォルトは
"device"です。 -
stylestring (オプション)追加日: v1.41#スクリーンショット作成時に適用するスタイルシートのテキスト。これにより、動的な要素を非表示にしたり、要素を見えなくしたり、プロパティを変更したりして、再現性のあるスクリーンショットを作成するのに役立ちます。このスタイルシートはShadow DOMを貫通し、内部フレームにも適用されます。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
type"png" | "jpeg" (オプション)#スクリーンショットの種類を指定します。デフォルトは
pngです。
-
戻り値
setContent
v1.9より前に追加このメソッドは内部的に document.write() を呼び出し、そのすべての特定の特性と動作を継承します。
使用法
await page.setContent(html);
await page.setContent(html, options);
引数
-
ページに割り当てるHTMLマークアップ。
-
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (オプション)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
setDefaultNavigationTimeout
v1.9より前に追加この設定は、以下のメソッドと関連するショートカットのデフォルトの最大ナビゲーション時間を変更します。
- page.goBack()
- page.goForward()
- page.goto()
- page.reload()
- page.setContent()
- page.waitForNavigation()
- page.waitForURL()
使用法
page.setDefaultNavigationTimeout(timeout);
引数
setDefaultTimeout
v1.9より前に追加この設定は、timeout オプションを受け入れるすべてのメソッドのデフォルトの最大時間を変更します。
使用法
page.setDefaultTimeout(timeout);
引数
setExtraHTTPHeaders
v1.9より前に追加追加のHTTPヘッダーは、ページが開始するすべてのリクエストとともに送信されます。
page.setExtraHTTPHeaders() は、送信されるリクエストにおけるヘッダーの順序を保証しません。
使用法
await page.setExtraHTTPHeaders(headers);
引数
戻り値
setViewportSize
v1.9より前に追加単一のブラウザ内に複数のページがある場合、各ページは独自のビューポートサイズを持つことができます。ただし、browser.newContext() を使用すると、コンテキスト内のすべてのページに一度にビューポートサイズ (およびその他の設定) を設定できます。
page.setViewportSize() はページをリサイズします。多くのウェブサイトは携帯電話のサイズが変更されることを想定していないため、ページに移動する前にビューポートサイズを設定する必要があります。page.setViewportSize() は screen サイズもリセットします。これらのプロパティをより細かく制御する必要がある場合は、screen および viewport パラメータを使用して browser.newContext() を使用してください。
使用法
const page = await browser.newPage();
await page.setViewportSize({
width: 640,
height: 480,
});
await page.goto('https://example.com');
引数
戻り値
title
v1.9より前に追加ページのタイトルを返します。
使用法
await page.title();
戻り値
unroute
v1.9より前に追加page.route() で作成されたルートを削除します。handler が指定されていない場合、url のすべてのルートを削除します。
使用法
await page.unroute(url);
await page.unroute(url, handler);
引数
-
urlstring | RegExp | function(URL):boolean#ルーティング中に一致する URL を受け取るグロブパターン、正規表現パターン、または述語。
-
handlerfunction(Route, Request):Promise<Object> | Object (オプション)#リクエストをルーティングするためのオプションのハンドラー関数。
戻り値
unrouteAll
追加日: v1.41page.route() と page.routeFromHAR() で作成されたすべてのルートを削除します。
使用法
await page.unrouteAll();
await page.unrouteAll(options);
引数
optionsObject (optional)-
behavior"wait" | "ignoreErrors" | "default" (オプション)#既に実行中のハンドラを待機するかどうか、およびエラーがスローされた場合の対処方法を指定します。
'default'- 現在のハンドラ呼び出し (もしあれば) の完了を待たず、アンルートされたハンドラがエラーをスローした場合、未処理のエラーが発生する可能性があります。'wait'- 現在のハンドラ呼び出し (もしあれば) の完了を待ちます。'ignoreErrors'- 現在のハンドラ呼び出し (もしあれば) の完了を待たず、アンルーティング後にハンドラによってスローされたすべてのエラーは静かにキャッチされます。
-
戻り値
url
v1.9より前に追加使用法
page.url();
戻り値
video
v1.9より前に追加このページに関連付けられたビデオオブジェクト。
使用法
page.video();
戻り値
viewportSize
v1.9より前に追加使用法
page.viewportSize();
戻り値
waitForEvent
v1.9より前に追加イベントが発生するのを待ち、その値を述語関数に渡します。述語が真の値を返すと解決します。イベントが発生する前にページが閉じられた場合、エラーをスローします。イベントデータ値を返します。
使用法
// Start waiting for download before clicking. Note no await.
const downloadPromise = page.waitForEvent('download');
await page.getByText('Download file').click();
const download = await downloadPromise;
引数
-
イベント名。通常、
*.on(event)に渡されるものと同じです。 -
optionsOrPredicatefunction | Object (オプション)#-
predicatefunctionイベントデータを受け取り、待機が解決されるべきときに真の値を返します。
-
timeoutnumber (optional)ミリ秒単位で待機する最大時間。デフォルトは
0(タイムアウトなし) です。デフォルト値は、設定のactionTimeoutオプション、または browserContext.setDefaultTimeout() または page.setDefaultTimeout() メソッドを使用して変更できます。
イベントを受け取る述語、またはオプションオブジェクトのいずれか。オプションです。
-
-
optionsObject (optional)
戻り値
waitForFunction
v1.9より前に追加pageFunction が真の値を返すと解決します。真の値のJSHandleに解決します。
使用法
page.waitForFunction() はビューポートのサイズ変更を監視するために使用できます。
const { webkit } = require('playwright'); // Or 'chromium' or 'firefox'.
(async () => {
const browser = await webkit.launch();
const page = await browser.newPage();
const watchDog = page.waitForFunction(() => window.innerWidth < 100);
await page.setViewportSize({ width: 50, height: 50 });
await watchDog;
await browser.close();
})();
page.waitForFunction() 関数の述語に引数を渡すには
const selector = '.foo';
await page.waitForFunction(selector => !!document.querySelector(selector), selector);
引数
-
pageFunctionfunction | string#ページコンテキストで評価される関数。
-
argEvaluationArgument (オプション)#pageFunction に渡すオプションの引数。
-
optionsObject (optional)-
pollingnumber | "raf" (オプション)#polling が
'raf'の場合、pageFunction はrequestAnimationFrameコールバックで常に実行されます。polling が数値の場合、関数が実行されるミリ秒単位の間隔として扱われます。デフォルトはrafです。 -
ミリ秒単位で待機する最大時間。デフォルトは
0(タイムアウトなし) です。デフォルト値は、設定のactionTimeoutオプション、または browserContext.setDefaultTimeout() または page.setDefaultTimeout() メソッドを使用して変更できます。
-
戻り値
waitForLoadState
v1.9より前に追加必要な読み込み状態に到達すると解決されます。
これは、ページがデフォルトで load という必要な読み込み状態に達したときに解決します。このメソッドが呼び出されたときにナビゲーションがコミットされている必要があります。現在のドキュメントがすでに必要な状態に達している場合は、すぐに解決されます。
ほとんどの場合、Playwright はすべてのアクションの前に自動待機 するため、このメソッドは必要ありません。
使用法
await page.getByRole('button').click(); // Click triggers navigation.
await page.waitForLoadState(); // The promise resolves after 'load' event.
const popupPromise = page.waitForEvent('popup');
await page.getByRole('button').click(); // Click triggers a popup.
const popup = await popupPromise;
await popup.waitForLoadState('domcontentloaded'); // Wait for the 'DOMContentLoaded' event.
console.log(await popup.title()); // Popup is ready to use.
引数
-
state"load" | "domcontentloaded" | "networkidle" (オプション)#待機するオプションの読み込み状態。デフォルトは
loadです。現在のドキュメントの読み込み中にすでに状態に達している場合、メソッドはすぐに解決されます。以下のいずれかになります。'load'-loadイベントが発火するまで待機します。'domcontentloaded'-DOMContentLoadedイベントが発火するまで待機します。'networkidle'- 非推奨 少なくとも500ミリ秒間ネットワーク接続がないまで待機します。テストにはこのメソッドを使用しないでください。代わりにWebアサーションに頼って準備状況を評価してください。
-
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
waitForRequest
v1.9より前に追加一致するリクエストを待ち、それを返します。イベントの詳細については、イベントの待機 を参照してください。
使用法
// Start waiting for request before clicking. Note no await.
const requestPromise = page.waitForRequest('https://example.com/resource');
await page.getByText('trigger request').click();
const request = await requestPromise;
// Alternative way with a predicate. Note no await.
const requestPromise = page.waitForRequest(request =>
request.url() === 'https://example.com' && request.method() === 'GET',
);
await page.getByText('trigger request').click();
const request = await requestPromise;
引数
-
urlOrPredicatestring | RegExp | function(Request):boolean | Promise<boolean>#リクエストのURL文字列、正規表現、または Request オブジェクトを受け取る述語。
-
optionsObject (optional)-
ミリ秒単位の最大待機時間。デフォルトは30秒。タイムアウトを無効にするには
0を渡します。デフォルト値は page.setDefaultTimeout() メソッドを使用して変更できます。
-
戻り値
waitForResponse
v1.9より前に追加一致したレスポンスを返します。イベントの詳細については、イベントの待機 を参照してください。
使用法
// Start waiting for response before clicking. Note no await.
const responsePromise = page.waitForResponse('https://example.com/resource');
await page.getByText('trigger response').click();
const response = await responsePromise;
// Alternative way with a predicate. Note no await.
const responsePromise = page.waitForResponse(response =>
response.url() === 'https://example.com' && response.status() === 200
&& response.request().method() === 'GET'
);
await page.getByText('trigger response').click();
const response = await responsePromise;
引数
-
urlOrPredicatestring | RegExp | function(Response):boolean | Promise<boolean>#リクエストURL文字列、正規表現、または Response オブジェクトを受け取る述語。コンテキストオプションで baseURL が提供され、渡されたURLがパスの場合、
new URL()コンストラクタを使用してマージされます。 -
optionsObject (optional)-
ミリ秒単位の最大待機時間。デフォルトは30秒。タイムアウトを無効にするには
0を渡します。デフォルト値は browserContext.setDefaultTimeout() または page.setDefaultTimeout() メソッドを使用して変更できます。
-
戻り値
waitForURL
追加されたバージョン: v1.11メインフレームが指定されたURLにナビゲートするのを待ちます。
使用法
await page.click('a.delayed-navigation'); // Clicking the link will indirectly cause a navigation
await page.waitForURL('**/target.html');
引数
-
urlstring | RegExp | function(URL):boolean#ナビゲーションを待機中に一致する URL を受け取るグロブパターン、正規表現パターン、または述語。ワイルドカード文字のない文字列の場合、メソッドは文字列と正確に一致するURLへのナビゲーションを待機することに注意してください。
-
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (オプション)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
workers
v1.9より前に追加このメソッドは、ページに関連付けられたすべての専用 WebWorkers を返します。
これにはサービスワーカーは含まれません
使用法
page.workers();
戻り値
プロパティ
clock
追加されたバージョン: v1.45Playwright には、クロックと時間の経過をモックする機能があります。
使用法
page.clock
タイプ
coverage
v1.9より前に追加現在のところ、Chromium のみで利用可能です。
ブラウザ固有のCoverage実装です。詳細については、Coverage を参照してください。
使用法
page.coverage
タイプ
keyboard
v1.9より前に追加使用法
page.keyboard
タイプ
mouse
v1.9より前に追加使用法
page.mouse
タイプ
request
追加バージョン: v1.16このページに関連付けられたAPIテストヘルパー。このメソッドは、ページのコンテキストにある browserContext.request と同じインスタンスを返します。詳細については、browserContext.request を参照してください。
使用法
page.request
タイプ
touchscreen
v1.9より前に追加使用法
page.touchscreen
タイプ
イベント
on('close')
v1.9より前に追加ページが閉じられたときに発行されます。
使用法
page.on('close', data => {});
イベントデータ
on('console')
v1.9より前に追加ページ内の JavaScript が console.log や console.dir などのコンソール API メソッドのいずれかを呼び出したときに発生します。
console.log に渡された引数は、ConsoleMessage イベントハンドラー引数で利用できます。
使用法
page.on('console', async msg => {
const values = [];
for (const arg of msg.args())
values.push(await arg.jsonValue());
console.log(...values);
});
await page.evaluate(() => console.log('hello', 5, { foo: 'bar' }));
イベントデータ
on('crash')
v1.9より前に追加ページがクラッシュしたときに発行されます。ブラウザページは、あまりにも多くのメモリを割り当てようとするとクラッシュする可能性があります。ページがクラッシュすると、進行中およびその後の操作は例外をスローします。
クラッシュに対処する最も一般的な方法は、例外をキャッチすることです。
try {
// Crash might happen during a click.
await page.click('button');
// Or while waiting for an event.
await page.waitForEvent('popup');
} catch (e) {
// When the page crashes, exception message contains 'crash'.
}
使用法
page.on('crash', data => {});
イベントデータ
on('dialog')
v1.9より前に追加alert、prompt、confirm、または beforeunload のようなJavaScriptダイアログが表示されたときに発行されます。リスナーは、dialog.accept() または dialog.dismiss() のいずれかでダイアログを**処理しなければなりません**。そうしないと、ページはダイアログを待機してフリーズし、クリックなどのアクションは決して完了しません。
使用法
page.on('dialog', dialog => dialog.accept());
page.on('dialog') または browserContext.on('dialog') リスナーが存在しない場合、すべてのダイアログは自動的に閉じられます。
イベントデータ
on('domcontentloaded')
追加バージョン: v1.9JavaScript DOMContentLoaded イベントがディスパッチされたときに発行されます。
使用法
page.on('domcontentloaded', data => {});
イベントデータ
on('download')
v1.9より前に追加添付ファイルのダウンロードが開始されたときに発行されます。ユーザーは、渡された Download インスタンスを介して、ダウンロードされたコンテンツに対する基本的なファイル操作にアクセスできます。
使用法
page.on('download', data => {});
イベントデータ
on('filechooser')
追加バージョン: v1.9<input type=file> のクリック後など、ファイルチューザーが表示されるべきときに発行されます。Playwrightは、fileChooser.setFiles() を使用して入力ファイルを設定することで応答でき、その後それらをアップロードできます。
page.on('filechooser', async fileChooser => {
await fileChooser.setFiles(path.join(__dirname, '/tmp/myfile.pdf'));
});
使用法
page.on('filechooser', data => {});
イベントデータ
on('frameattached')
追加バージョン: v1.9フレームがアタッチされたときに発行されます。
使用法
page.on('frameattached', data => {});
イベントデータ
on('framedetached')
追加バージョン: v1.9フレームがデタッチされたときに発行されます。
使用法
page.on('framedetached', data => {});
イベントデータ
on('framenavigated')
追加バージョン: v1.9フレームが新しいURLにナビゲートされたときに発行されます。
使用法
page.on('framenavigated', data => {});
イベントデータ
on('load')
v1.9より前に追加JavaScript load イベントがディスパッチされたときに発行されます。
使用法
page.on('load', data => {});
イベントデータ
on('pageerror')
追加バージョン: v1.9ページ内でキャッチされない例外が発生したときに発行されます。
// Log all uncaught errors to the terminal
page.on('pageerror', exception => {
console.log(`Uncaught exception: "${exception}"`);
});
// Navigate to a page with an exception.
await page.goto('data:text/html,<script>throw new Error("Test")</script>');
使用法
page.on('pageerror', data => {});
イベントデータ
on('popup')
v1.9より前に追加ページが新しいタブまたはウィンドウを開いたときに発行されます。このイベントは browserContext.on('page') に加えて発行されますが、このページに関連するポップアップに対してのみです。
ページが利用可能になる最も早い瞬間は、初期URLにナビゲートされたときです。たとえば、window.open('http://example.com') でポップアップを開く場合、このイベントは「http://example.com」へのネットワークリクエストが完了し、そのレスポンスがポップアップで読み込みを開始したときに発生します。このネットワークリクエストをルーティング/リッスンしたい場合は、Page の同様のメソッドの代わりに、それぞれ browserContext.route() と browserContext.on('request') を使用してください。
// Start waiting for popup before clicking. Note no await.
const popupPromise = page.waitForEvent('popup');
await page.getByText('open the popup').click();
const popup = await popupPromise;
console.log(await popup.evaluate('location.href'));
ページが特定の状態になるまで待機するには、page.waitForLoadState() を使用します (ほとんどの場合、必要ありません)。
使用法
page.on('popup', data => {});
イベントデータ
on('request')
v1.9より前に追加ページがリクエストを発行したときに発行されます。request オブジェクトは読み取り専用です。リクエストをインターセプトして変更するには、page.route() または browserContext.route() を参照してください。
使用法
page.on('request', data => {});
イベントデータ
on('requestfailed')
追加バージョン: v1.9リクエストがタイムアウトなどで失敗したときに発行されます。
page.on('requestfailed', request => {
console.log(request.url() + ' ' + request.failure().errorText);
});
404や503などのHTTPエラーレスポンスは、HTTPの観点からは依然として成功したレスポンスであるため、リクエストは page.on('requestfinished') イベントで完了し、page.on('requestfailed') では完了しません。リクエストは、クライアントがサーバーからHTTPレスポンスを取得できない場合にのみ失敗と見なされます (例: ネットワークエラー net::ERR_FAILED)。
使用法
page.on('requestfailed', data => {});
イベントデータ
on('requestfinished')
追加バージョン: v1.9レスポンスボディのダウンロード後にリクエストが正常に完了したときに発行されます。成功したレスポンスの場合、イベントのシーケンスは request、response、requestfinished です。
使用法
page.on('requestfinished', data => {});
イベントデータ
on('response')
v1.9より前に追加リクエストの レスポンス ステータスとヘッダーが受信されたときに発行されます。成功したレスポンスの場合、イベントのシーケンスは request、response、requestfinished です。
使用法
page.on('response', data => {});
イベントデータ
on('websocket')
追加バージョン: v1.9WebSocket リクエストが送信されたときに発行されます。
使用法
page.on('websocket', data => {});
イベントデータ
on('worker')
v1.9より前に追加専用の WebWorker がページによって生成されたときに発行されます。
使用法
page.on('worker', data => {});
イベントデータ
非推奨
$
追加バージョン: v1.9代わりにロケーターベースの page.locator() を使用してください。ロケーター について詳しくはこちらをご覧ください。
このメソッドは、ページ内で指定されたセレクターに一致する要素を検索します。セレクターに一致する要素がない場合、戻り値は null に解決されます。ページ上の要素を待機するには、locator.waitFor() を使用します。
使用法
await page.$(selector);
await page.$(selector, options);
引数
-
クエリするセレクター。
-
optionsObject (optional)
戻り値
$$
追加バージョン: v1.9代わりにロケーターベースの page.locator() を使用してください。ロケーター について詳しくはこちらをご覧ください。
このメソッドは、ページ内で指定されたセレクターに一致するすべての要素を検索します。セレクターに一致する要素がない場合、戻り値は [] に解決されます。
使用法
await page.$$(selector);
引数
戻り値
$eval
追加バージョン: v1.9このメソッドは、要素がアクション性チェックに合格するのを待機しないため、不安定なテストにつながる可能性があります。代わりに、locator.evaluate()、その他の Locator ヘルパーメソッド、またはウェブファーストアサーションを使用してください。
このメソッドは、ページ内で指定されたセレクターに一致する要素を検索し、それを pageFunction の最初の引数として渡します。セレクターに一致する要素がない場合、このメソッドはエラーをスローします。pageFunction の値を返します。
pageFunction が Promise を返す場合、page.$eval() はプロミスが解決されるのを待ってその値を返します。
使用法
const searchValue = await page.$eval('#search', el => el.value);
const preloadHref = await page.$eval('link[rel=preload]', el => el.href);
const html = await page.$eval('.main-container', (e, suffix) => e.outerHTML + suffix, 'hello');
// In TypeScript, this example requires an explicit type annotation (HTMLLinkElement) on el:
const preloadHrefTS = await page.$eval('link[rel=preload]', (el: HTMLLinkElement) => el.href);
引数
-
クエリするセレクター。
-
pageFunctionfunction(Element) | string#ページコンテキストで評価される関数。
-
argEvaluationArgument (オプション)#pageFunction に渡すオプションの引数。
-
optionsObject (optional)
戻り値
$$eval
追加バージョン: v1.9ほとんどの場合、locator.evaluateAll()、その他の Locator ヘルパーメソッド、およびウェブファーストアサーションの方が優れています。
このメソッドは、ページ内で指定されたセレクターに一致するすべての要素を検索し、一致する要素の配列を pageFunction の最初の引数として渡します。pageFunction 呼び出しの結果を返します。
pageFunction が Promise を返す場合、page.$$eval() はプロミスが解決されるのを待ってその値を返します。
使用法
const divCounts = await page.$$eval('div', (divs, min) => divs.length >= min, 10);
引数
-
クエリするセレクター。
-
pageFunctionfunction(Array<Element>) | string#ページコンテキストで評価される関数。
-
argEvaluationArgument (オプション)#pageFunction に渡すオプションの引数。
戻り値
accessibility
v1.9より前に追加使用法
page.accessibility
タイプ
check
v1.9より前に追加代わりにロケーターベースの locator.check() を使用してください。ロケーター について詳しくはこちらをご覧ください。
このメソッドは、以下の手順を実行して セレクター に一致する要素をチェックします。
- セレクター に一致する要素を検索します。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- 一致する要素がチェックボックスまたはラジオ入力であることを確認します。そうでない場合、このメソッドは例外をスローします。要素がすでにチェックされている場合、このメソッドはすぐに戻ります。
- force オプションが設定されていない限り、一致する要素に対する アクション性 チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- page.mouse を使用して、要素の中央をクリックします。
- 要素が現在チェックされていることを確認します。そうでない場合、このメソッドはスローします。
すべての手順が指定された timeout 内に完了しなかった場合、このメソッドは TimeoutError をスローします。タイムアウトをゼロにすると、これを無効にします。
使用法
await page.check(selector);
await page.check(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
positionObject (オプション)追加されたバージョン: v1.11#要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定されている場合、このメソッドはアクション可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。要素がアクションを実行する準備ができるまで、実行せずに待機するのに便利です。
-
戻り値
click
v1.9より前に追加代わりに、ロケーターベースのlocator.click()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素をクリックします。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- 要素の中心、または指定されたpositionをクリックするためにpage.mouseを使用します。
- noWaitAfterオプションが設定されていない限り、開始されたナビゲーションが成功または失敗するまで待機します。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
使用法
await page.click(selector);
await page.click(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
button"left" | "right" | "middle" (任意)#デフォルトは
leftです。 -
デフォルトは 1 です。UIEvent.detail を参照してください。
-
mousedownとmouseupの間の待機時間 (ミリ秒単位)。デフォルトは 0 です。 -
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
modifiersArray<"Alt" | "Control" | "ControlOrMeta" | "Meta" | "Shift"> (任意)#押す修飾キー。操作中にこれらの修飾キーのみが押されていることを保証し、現在の修飾キーを元に戻します。指定しない場合、現在押されている修飾キーが使用されます。"ControlOrMeta" は、Windows と Linux では "Control" に、macOS では "Meta" に解決されます。
-
非推奨
このオプションは将来
trueになります。ナビゲーションを開始するアクションは、これらのナビゲーションが発生し、ページがロードを開始するのを待機します。このフラグを設定することで、待機をオプトアウトできます。これは、アクセスできないページにナビゲートするなどの例外的な場合にのみ必要です。デフォルトは
falseです。 -
要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定すると、このメソッドはアクション実行可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。アクションを実行せずに要素がアクションの準備が整うまで待機するのに便利です。キーボードの修飾子は、それらのキーが押されたときにのみ表示される要素をテストできるように、trialに関係なく押されます。
-
戻り値
dblclick
v1.9より前に追加代わりに、ロケーターベースのlocator.dblclick()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素をダブルクリックします。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- 要素の中心、または指定されたpositionをダブルクリックするためにpage.mouseを使用します。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
page.dblclick()は、2つのclickイベントと1つのdblclickイベントをディスパッチします。
使用法
await page.dblclick(selector);
await page.dblclick(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
button"left" | "right" | "middle" (任意)#デフォルトは
leftです。 -
mousedownとmouseupの間の待機時間 (ミリ秒単位)。デフォルトは 0 です。 -
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
modifiersArray<"Alt" | "Control" | "ControlOrMeta" | "Meta" | "Shift"> (任意)#押す修飾キー。操作中にこれらの修飾キーのみが押されていることを保証し、現在の修飾キーを元に戻します。指定しない場合、現在押されている修飾キーが使用されます。"ControlOrMeta" は、Windows と Linux では "Control" に、macOS では "Meta" に解決されます。
-
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定すると、このメソッドはアクション実行可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。アクションを実行せずに要素がアクションの準備が整うまで待機するのに便利です。キーボードの修飾子は、それらのキーが押されたときにのみ表示される要素をテストできるように、trialに関係なく押されます。
-
戻り値
dispatchEvent
v1.9より前に追加代わりに、ロケーターベースのlocator.dispatchEvent()を使用してください。ロケーターの詳細については、こちらをご覧ください。
以下のスニペットは、要素に対してclickイベントをディスパッチします。要素の可視状態に関わらず、clickイベントがディスパッチされます。これはelement.click()を呼び出すのと同等です。
使用法
await page.dispatchEvent('button#submit', 'click');
内部的には、指定されたtypeに基づいてイベントのインスタンスを作成し、eventInitプロパティで初期化し、要素にディスパッチします。イベントはデフォルトでcomposed、cancelable、およびバブルします。
eventInitはイベント固有であるため、初期プロパティのリストについてはイベントのドキュメントを参照してください。
- DeviceMotionEvent
- DeviceOrientationEvent
- DragEvent
- Event
- FocusEvent
- KeyboardEvent
- MouseEvent
- PointerEvent
- TouchEvent
- WheelEvent
ライブオブジェクトをイベントに渡したい場合は、プロパティ値としてJSHandleを指定することもできます。
// Note you can only create DataTransfer in Chromium and Firefox
const dataTransfer = await page.evaluateHandle(() => new DataTransfer());
await page.dispatchEvent('#source', 'dragstart', { dataTransfer });
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
DOM イベントタイプ:
"click"、"dragstart"など。 -
eventInitEvaluationArgument (任意)#オプションのイベント固有の初期化プロパティ。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
fill
v1.9より前に追加代わりに、ロケーターベースのlocator.fill()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、セレクターに一致する要素を待機し、アクション実行可能性チェックを待機し、要素にフォーカスし、値を入力し、入力後にinputイベントをトリガーします。入力フィールドをクリアするために空の文字列を渡すことができることに注意してください。
ターゲット要素が <input>、<textarea>、または [contenteditable] 要素でない場合、このメソッドはエラーをスローします。ただし、要素が関連付けられた コントロール を持つ <label> 要素内にある場合、代わりにコントロールが入力されます。
細かいキーボードイベントを送信するには、locator.pressSequentially()を使用します。
使用法
await page.fill(selector, value);
await page.fill(selector, value, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
<input>、<textarea>、または[contenteditable]要素に入力する値。 -
optionsObject (optional)-
forceboolean (任意)追加バージョン: v1.13#アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
focus
v1.9より前に追加代わりに、ロケーターベースのlocator.focus()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、セレクターに一致する要素を取得し、フォーカスします。セレクターに一致する要素がない場合、一致する要素がDOMに表示されるまでメソッドは待機します。
使用法
await page.focus(selector);
await page.focus(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
getAttribute
v1.9より前に追加代わりに、ロケーターベースのlocator.getAttribute()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素の属性値を返します。
使用法
await page.getAttribute(selector, name);
await page.getAttribute(selector, name, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
値を取得する属性名。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
hover
v1.9より前に追加代わりに、ロケーターベースのlocator.hover()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素にカーソルを合わせます。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- 要素の中心、または指定されたpositionにカーソルを合わせるためにpage.mouseを使用します。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
使用法
await page.hover(selector);
await page.hover(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
modifiersArray<"Alt" | "Control" | "ControlOrMeta" | "Meta" | "Shift"> (任意)#押す修飾キー。操作中にこれらの修飾キーのみが押されていることを保証し、現在の修飾キーを元に戻します。指定しない場合、現在押されている修飾キーが使用されます。"ControlOrMeta" は、Windows と Linux では "Control" に、macOS では "Meta" に解決されます。
-
noWaitAfterboolean (optional)追加バージョン: v1.28#非推奨このオプションは効果がありません。
このオプションは効果がありません。
-
要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定すると、このメソッドはアクション実行可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。アクションを実行せずに要素がアクションの準備が整うまで待機するのに便利です。キーボードの修飾子は、それらのキーが押されたときにのみ表示される要素をテストできるように、trialに関係なく押されます。
-
戻り値
innerHTML
v1.9より前に追加代わりに、ロケーターベースのlocator.innerHTML()を使用してください。ロケーターの詳細については、こちらをご覧ください。
element.innerHTMLを返します。
使用法
await page.innerHTML(selector);
await page.innerHTML(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
innerText
v1.9より前に追加代わりに、ロケーターベースのlocator.innerText()を使用してください。ロケーターの詳細については、こちらをご覧ください。
element.innerTextを返します。
使用法
await page.innerText(selector);
await page.innerText(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
inputValue
追加バージョン: v1.13代わりに、ロケーターベースのlocator.inputValue()を使用してください。ロケーターの詳細については、こちらをご覧ください。
選択された<input>、<textarea>、または<select>要素のinput.valueを返します。
非入力要素に対しては例外をスローします。ただし、要素が関連付けられたコントロールを持つ<label>要素内にある場合は、コントロールの値を返します。
使用法
await page.inputValue(selector);
await page.inputValue(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
isChecked
v1.9より前に追加代わりに、ロケーターベースのlocator.isChecked()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素がチェックされているかどうかを返します。要素がチェックボックスまたはラジオ入力でない場合、スローします。
使用法
await page.isChecked(selector);
await page.isChecked(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
isDisabled
v1.9より前に追加代わりに、ロケーターベースのlocator.isDisabled()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素が無効になっているかどうかを返します。enabledの反対です。
使用法
await page.isDisabled(selector);
await page.isDisabled(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
isEditable
v1.9より前に追加代わりに、ロケーターベースのlocator.isEditable()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素が編集可能かどうかを返します。
使用法
await page.isEditable(selector);
await page.isEditable(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
isEnabled
v1.9より前に追加代わりに、ロケーターベースのlocator.isEnabled()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素が有効かどうかを返します。
使用法
await page.isEnabled(selector);
await page.isEnabled(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
isHidden
v1.9より前に追加代わりに、ロケーターベースのlocator.isHidden()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素が非表示になっているかどうかを返します。visibleの反対です。selectorがどの要素にも一致しない場合、非表示と見なされます。
使用法
await page.isHidden(selector);
await page.isHidden(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
非推奨
このオプションは無視されます。page.isHidden()は、要素が非表示になるのを待たずにすぐに返します。
-
戻り値
isVisible
v1.9より前に追加代わりに、ロケーターベースのlocator.isVisible()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素が表示可能かどうかを返します。selectorがどの要素にも一致しない場合、表示不可と見なされます。
使用法
await page.isVisible(selector);
await page.isVisible(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
非推奨
このオプションは無視されます。page.isVisible()は、要素が表示されるのを待たずにすぐに返します。
-
戻り値
press
v1.9より前に追加代わりに、ロケーターベースのlocator.press()を使用してください。ロケーターの詳細については、こちらをご覧ください。
要素にフォーカスし、keyboard.down()とkeyboard.up()を使用します。
keyは、意図したkeyboardEvent.key値を指定するか、テキストを生成するための一文字を指定できます。key値のスーパーセットはこちらで見つけることができます。キーの例は次のとおりです。
F1 - F12, Digit0- Digit9, KeyA- KeyZ, Backquote, Minus, Equal, Backslash, Backspace, Tab, Delete, Escape, ArrowDown, End, Enter, Home, Insert, PageDown, PageUp, ArrowRight, ArrowUpなど。
以下の修飾ショートカットもサポートされています:Shift, Control, Alt, Meta, ShiftLeft, ControlOrMeta。 ControlOrMetaはWindowsおよびLinuxではControlに、macOSではMetaに解決されます。
Shiftを押し続けると、keyに対応するテキストが大文字で入力されます。
keyが一文字の場合、大文字と小文字を区別するため、aとAの値はそれぞれ異なるテキストを生成します。
key: "Control+o"、key: "Control++、key: "Control+Shift+T"のようなショートカットもサポートされています。修飾キーを指定した場合、修飾キーは押し続けられ、その後に続くキーが押されます。
使用法
const page = await browser.newPage();
await page.goto('https://keycode.info');
await page.press('body', 'A');
await page.screenshot({ path: 'A.png' });
await page.press('body', 'ArrowLeft');
await page.screenshot({ path: 'ArrowLeft.png' });
await page.press('body', 'Shift+O');
await page.screenshot({ path: 'O.png' });
await browser.close();
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
押すキーの名前、または
ArrowLeftやaなどの生成する文字。 -
optionsObject (optional)-
keydownとkeyupの間の待機時間 (ミリ秒)。デフォルトは 0 です。 -
非推奨
このオプションは将来
trueになります。ナビゲーションを開始するアクションは、これらのナビゲーションが発生し、ページがロードを開始するのを待機します。このフラグを設定することで、待機をオプトアウトできます。これは、アクセスできないページにナビゲートするなどの例外的な場合にのみ必要です。デフォルトは
falseです。 -
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
selectOption
v1.9より前に追加代わりに、ロケーターベースのlocator.selectOption()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、セレクターに一致する要素を待機し、アクション実行可能性チェックを待機し、指定されたすべてのオプションが<select>要素に存在し、それらのオプションを選択します。
ターゲット要素が<select>要素でない場合、このメソッドはエラーをスローします。ただし、要素が関連するコントロールを持つ<label>要素内にある場合、代わりにそのコントロールが使用されます。
正常に選択されたオプション値の配列を返します。
提供されたすべてのオプションが選択されると、changeおよびinputイベントをトリガーします。
使用法
// Single selection matching the value or label
page.selectOption('select#colors', 'blue');
// single selection matching the label
page.selectOption('select#colors', { label: 'Blue' });
// multiple selection
page.selectOption('select#colors', ['red', 'green', 'blue']);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
valuesnull | string | ElementHandle | Array<string> | Object | Array<ElementHandle> | Array<Object>#-
valuestring (任意)option.valueで一致します。任意。 -
labelstring (任意)option.labelで一致します。任意。 -
indexnumber (任意)インデックスで一致します。任意。
選択するオプション。
<select>にmultiple属性がある場合、一致するすべてのオプションが選択され、そうでない場合は、渡されたオプションのいずれかに一致する最初のオプションのみが選択されます。文字列値は値とラベルの両方に一致します。すべての指定されたプロパティが一致する場合、オプションは一致すると見なされます。 -
-
optionsObject (optional)-
forceboolean (任意)追加バージョン: v1.13#アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
setChecked
追加されたバージョン: v1.15代わりに、ロケーターベースのlocator.setChecked()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素をチェックまたはアンチェックします。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- 一致する要素がチェックボックスまたはラジオ入力であることを確認します。そうでない場合、このメソッドはエラーをスローします。
- 要素がすでに正しいチェック状態である場合、このメソッドはすぐに戻ります。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- page.mouse を使用して、要素の中央をクリックします。
- 要素がチェックまたはチェック解除されたことを確認します。そうでない場合、このメソッドはエラーをスローします。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
使用法
await page.setChecked(selector, checked);
await page.setChecked(selector, checked, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
チェックボックスをチェックするか、チェックを外すか。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
設定されている場合、このメソッドはアクション可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。要素がアクションを実行する準備ができるまで、実行せずに待機するのに便利です。
-
戻り値
setInputFiles
v1.9より前に追加代わりに、ロケーターベースのlocator.setInputFiles()を使用してください。ロケーターの詳細については、こちらをご覧ください。
ファイル入力の値をこれらのファイルパスまたはファイルに設定します。filePathsの一部が相対パスの場合、それらは現在の作業ディレクトリに対して解決されます。空の配列の場合、選択されたファイルをクリアします。[webkitdirectory]属性を持つ入力の場合、単一のディレクトリパスのみがサポートされます。
このメソッドは、セレクターが入力要素を指すことを期待します。ただし、要素が関連付けられたコントロールを持つ<label>要素内にある場合は、代わりにコントロールをターゲットにします。
使用法
await page.setInputFiles(selector, files);
await page.setInputFiles(selector, files, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
tap
v1.9より前に追加代わりに、ロケーターベースのlocator.tap()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素をタップします。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- 要素の中心、または指定されたpositionをタップするためにpage.touchscreenを使用します。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
ブラウザコンテキストのhasTouchオプションがfalseの場合、page.tap()メソッドは例外をスローします。
使用法
await page.tap(selector);
await page.tap(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
modifiersArray<"Alt" | "Control" | "ControlOrMeta" | "Meta" | "Shift"> (任意)#押す修飾キー。操作中にこれらの修飾キーのみが押されていることを保証し、現在の修飾キーを元に戻します。指定しない場合、現在押されている修飾キーが使用されます。"ControlOrMeta" は、Windows と Linux では "Control" に、macOS では "Meta" に解決されます。
-
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定すると、このメソッドはアクション実行可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。アクションを実行せずに要素がアクションの準備が整うまで待機するのに便利です。キーボードの修飾子は、それらのキーが押されたときにのみ表示される要素をテストできるように、trialに関係なく押されます。
-
戻り値
textContent
v1.9より前に追加代わりに、ロケーターベースのlocator.textContent()を使用してください。ロケーターの詳細については、こちらをご覧ください。
element.textContentを返します。
使用法
await page.textContent(selector);
await page.textContent(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
type
v1.9より前に追加ほとんどの場合、代わりにlocator.fill()を使用する必要があります。ページに特別なキーボード処理がある場合のみ、キーを一つずつ押す必要があります - この場合はlocator.pressSequentially()を使用してください。
テキスト内の各文字に対してkeydown、keypress/input、およびkeyupイベントを送信します。page.typeは、細かいキーボードイベントを送信するために使用できます。フォームフィールドに値を入力するには、page.fill()を使用します。
ControlやArrowDownのような特殊キーを押すには、keyboard.press()を使用します。
使用法
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
フォーカスされた要素に入力するテキスト。
-
optionsObject (optional)-
キー押下間の待機時間(ミリ秒)。デフォルトは0です。
-
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
uncheck
v1.9より前に追加代わりに、ロケーターベースのlocator.uncheck()を使用してください。ロケーターの詳細については、こちらをご覧ください。
このメソッドは、以下の手順を実行することで、セレクターに一致する要素のチェックを外します。
- セレクターに一致する要素を見つけます。一致する要素がない場合は、一致する要素がDOMにアタッチされるまで待機します。
- 一致する要素がチェックボックスまたはラジオ入力であることを確認します。そうでない場合、このメソッドは例外をスローします。要素がすでにチェックされていない場合、このメソッドはすぐに返します。
- forceオプションが設定されていない限り、一致した要素に対してアクション実行可能性チェックを待機します。チェック中に要素がデタッチされた場合、アクション全体が再試行されます。
- 必要に応じて要素を表示するためにスクロールします。
- page.mouse を使用して、要素の中央をクリックします。
- 要素がチェックされていないことを確認します。そうでない場合、このメソッドはエラーをスローします。
指定されたtimeout中にすべてのステップが完了しなかった場合、このメソッドはTimeoutErrorをスローします。タイムアウトをゼロに設定すると、これを無効にできます。
使用法
await page.uncheck(selector);
await page.uncheck(selector, options);
引数
-
要素を検索するセレクター。セレクターを満たす要素が複数ある場合、最初のものが使用されます。
-
optionsObject (optional)-
アクション可能チェックをバイパスするかどうか。デフォルトは
falseです。 -
非推奨
このオプションは効果がありません。
このオプションは効果がありません。
-
positionObject (オプション)追加されたバージョン: v1.11#要素のパディングボックスの左上隅を基準に使用する点。指定しない場合は、要素の可視点の一部が使用されます。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
trialboolean (オプション)追加されたバージョン: v1.11#設定されている場合、このメソッドはアクション可能性チェックのみを実行し、アクションはスキップします。デフォルトは
falseです。要素がアクションを実行する準備ができるまで、実行せずに待機するのに便利です。
-
戻り値
waitForNavigation
v1.9より前に追加このメソッドは本質的に競合状態になりやすいため、代わりにpage.waitForURL()を使用してください。
メインフレームのナビゲーションを待機し、メインリソースのレスポンスを返します。複数のリダイレクトが発生した場合、ナビゲーションは最後のRリダイレクトのレスポンスで解決されます。異なるアンカーへのナビゲーションやHistory APIの使用によるナビゲーションの場合、ナビゲーションはnullで解決されます。
使用法
これは、ページが新しいURLにナビゲートするか、再読み込みされるときに解決されます。ページが間接的にナビゲーションを引き起こすコードを実行する場合に便利です。例えば、クリックターゲットにsetTimeoutからナビゲーションをトリガーするonclickハンドラーがある場合などです。この例を考えてみてください。
// Start waiting for navigation before clicking. Note no await.
const navigationPromise = page.waitForNavigation();
await page.getByText('Navigate after timeout').click();
await navigationPromise;
URLを変更するためのHistory APIの使用はナビゲーションと見なされます。
引数
optionsObject (optional)-
最大操作時間(ミリ秒)。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのnavigationTimeoutオプション、またはbrowserContext.setDefaultNavigationTimeout()、browserContext.setDefaultTimeout()、page.setDefaultNavigationTimeout()、またはpage.setDefaultTimeout()メソッドを使用して変更できます。 -
urlstring | RegExp | function(URL):boolean (任意)#ナビゲーションを待機中に一致する URL を受け取るグロブパターン、正規表現パターン、または述語。ワイルドカード文字のない文字列の場合、メソッドは文字列と正確に一致するURLへのナビゲーションを待機することに注意してください。
-
waitUntil"load" | "domcontentloaded" | "networkidle" | "commit" (任意)#操作が成功したと見なすタイミング。デフォルトは
loadです。イベントは次のいずれかです。'domcontentloaded'-DOMContentLoadedイベントが発火したときに操作が終了したと見なします。'load'-loadイベントが発火したときに操作が終了したと見なします。'networkidle'- 推奨されません 少なくとも500ミリ秒間ネットワーク接続がないときに操作が終了したと見なします。テストにはこのメソッドを使用せず、代わりにWebアサーションに依存して準備状況を評価してください。'commit'- ネットワーク応答が受信され、ドキュメントの読み込みが開始されたときに操作が終了したと見なします。
-
戻り値
waitForSelector
v1.9より前に追加代わりに、可視性をアサートするWebアサーションまたはロケーターベースのlocator.waitFor()を使用してください。ロケーターの詳細については、こちらをご覧ください。
セレクターで指定された要素がstateオプションを満たすと返します。hiddenまたはdetachedを待機している場合はnullを返します。
Playwrightは、アクションを実行する前に要素が準備完了状態になるのを自動的に待機します。LocatorオブジェクトとWebファーストのアサーションを使用すると、コードでセレクターの待機が不要になります。
セレクターがstateオプションを満たすまで(DOMに表示/非表示になるか、可視/非表示になるまで)待機します。メソッド呼び出しの時点でセレクターがすでに条件を満たしている場合、メソッドはすぐに返します。timeoutミリ秒間、セレクターが条件を満たさない場合、関数は例外をスローします。
使用法
このメソッドはナビゲーション全体で動作します。
const { chromium } = require('playwright'); // Or 'firefox' or 'webkit'.
(async () => {
const browser = await chromium.launch();
const page = await browser.newPage();
for (const currentURL of ['https://google.com', 'https://bbc.com']) {
await page.goto(currentURL);
const element = await page.waitForSelector('img');
console.log('Loaded image: ' + await element.getAttribute('src'));
}
await browser.close();
})();
引数
-
クエリするセレクター。
-
optionsObject (optional)-
state"attached" | "detached" | "visible" | "hidden" (任意)#デフォルトは
'visible'です。以下のいずれかになります。'attached'- 要素がDOMに存在することを待ちます。'detached'- 要素がDOMに存在しないことを待ちます。'visible'- 要素が空でない境界ボックスを持ち、visibility:hiddenがないことを待ちます。コンテンツがない要素やdisplay:noneの要素は空の境界ボックスを持つため、可視とはみなされないことに注意してください。'hidden'- 要素がDOMからデタッチされているか、空の境界ボックスを持つか、またはvisibility:hiddenを持つことを待ちます。これは'visible'オプションとは逆です。
-
strictboolean (optional)追加されたバージョン: v1.14#trueの場合、呼び出しはセレクターが単一の要素に解決されることを必要とします。指定されたセレクターが複数の要素に解決される場合、呼び出しは例外をスローします。
-
最大ミリ秒。デフォルトは
0で、タイムアウトなし。デフォルト値は、configのactionTimeoutオプション、またはbrowserContext.setDefaultTimeout()またはpage.setDefaultTimeout()メソッドを使用して変更できます。
-
戻り値
waitForTimeout
v1.9より前に追加本番環境でタイムアウトを待機することは絶対に避けてください。時間を待機するテストは本質的に不安定です。Locatorアクションと自動的に待機するWebアサーションを使用してください。
指定されたミリ秒単位のtimeoutを待機します。
page.waitForTimeout()はデバッグ目的でのみ使用されるべきであることに注意してください。本番環境でタイマーを使用するテストは不安定になる可能性があります。代わりに、ネットワークイベント、セレクターの表示など、他のシグナルを使用してください。
使用法
// wait for 1 second
await page.waitForTimeout(1000);
引数
戻り値