autocorrect

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Experimental: これは実験的な機能です。
本番で使用する前にブラウザー互換性一覧表をチェックしてください。

autocorrectグローバル属性で、列挙型属性であり、編集可能なテキストの綴りや句読点の誤りを自動修正するかどうかを制御します。

どの単語が自動修正されるかを含め、特定の自動修正の動作はユーザーエージェントと基盤となる端末で指定されたサービスに依存します。 例えば、 macOS ではユーザーエージェントが登録済みの置き換えテキストや句読点に頼っている場合があります。 他にも、端末やブラウザーによって、使用されているさまざまな手法があります。

自動修正は編集可能なテキスト要素に関連しています。

編集可能な要素には既定では自動修正機能が有効になっていますが、 <form> 要素内では、既定値がフォームから継承されることがあります。 属性を明示的に設定するには、既定値を上書きします。

取りうる値は次の通りです。

on または "" (空文字列)

綴りや句読点の誤りを自動修正する機能を有効にします。

off

編集可能なテキストの自動修正を無効にします。

<input> 要素型のうち、自動修正に対応していないものは、常に off の状態になります。passwordemailurl です。

編集可能なその他の要素については、上記以外の値を設定しても、常に on として扱われます。 <form> 内に含まれていない要素の既定値は on です。

<form> に含まれている場合、そのフォームに autocorrect の既定値が設定されている場合は、<button><fieldset><input><output><select><textarea> の各要素はその値を継承します。

基本的な例

この例は、基本的な autocorrect 属性の使用方法を示しています。

HTML

autocorrect 属性に異なる値を持つ 2 つの <input> 要素を記載しています。

html
<label for="vegetable">野菜: </label>
<input id="vegetable" name="vegetable" type="text" autocorrect="on" />

<label for="fruit">果物: </label>
<input id="fruit" name="fruit" type="text" autocorrect="off" />

結果

上記にある果物と野菜のテキスト入力項目に不正なテキストを入力してください。 お使いのブラウザーが自動修正に対応しており、端末で適切な修正が指定されている場合、野菜名の入力でタイプミスを自動修正できます。 果物の名前の項目では、タイプミスを修正しません。

自動修正の有効化と無効化

この例では、 autocorrect 属性を使用して自動修正を無効または有効にする方法を示しています。

HTML

HTML マークアップは、<button>、「名前」の <input> 要素(type="text")、「経歴」の <textarea> 要素、および 2 つの <label> 要素を定義しています。

"username" の要素には autocorrect="off" が設定されています。名前の自動修正は煩わしいからです。 bio には autocorrect の値が指定されていません。つまり、有効になっているということです(off 以外の任意の要素を設定することもできます)。

html
<button id="reset">リセット</button>
<label for="username">名前: </label>
<input id="username" name="username" type="text" autocorrect="off" />
<label for="bio">経歴: </label>
<textarea id="bio" name="bio"></textarea>

JavaScript

このコードは、プロトタイプに autocorrect が存在するかどうかをチェックすることで、それが対応しているかどうかを確認します。 存在しない場合は、その事実が記録されます。 存在する場合は、各テキスト入力要素の autocorrect プロパティの値が記録されます。

ボタンにクリックハンドラーを追加し、入力テキストとログ出力をリセットできるようにします。

js
const resetButton = document.querySelector("#reset");
const userNameElement = document.querySelector("#username");
const bioElement = document.querySelector("#bio");

if (!("autocorrect" in HTMLElement.prototype)) {
  log("自動修正に対応していません");
} else {
  log(`userNameElement.autocorrect: ${userNameElement.autocorrect}`);
  log(`bioElement.autocorrect: ${bioElement.autocorrect}`);
}

resetButton.addEventListener("click", (e) => {
  userNameElement.value = "";
  bioElement.value = "";
});

結果

自動修正機能がブラウザーに対応している場合、「経歴」と「名前」の入力欄の下記にあるログ出力領域に、「経歴」の入力欄には有効であるが、「名前」の入力欄には有効ではないことを示すメッセージが表示されます。

名前と経歴のテキスト入力項目に不正なテキストを入力します。 端末に指定された単語の代替が存在する場合、この単語が「経歴」入力項目(のみ)のテキストの自動修正に使用されます。

仕様書

Specification
HTML
# attr-autocorrect

ブラウザーの互換性

Report problems with this compatibility data on GitHub
desktopmobile
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
autocorrect

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
Partial support
Partial support
In development. Supported in a pre-release version.
In development. Supported in a pre-release version.
No support
No support