7.5. 文書~lifecycle
【この訳に特有な表記規約】
◎表記記号7.5.2. ~HTML文書の読込n法
`~HTML文書を読込む@ ときは、 所与の ( `~navi~params$ %~navi~params ) に対し: ◎ To load an HTML document, given navigation params navigationParams:
- %文書 ~LET `文書を作成して初期化する$( `html^l, `text/html^l, %~navi~params ) ◎ Let document be the result of creating and initializing a Document object given "html", "text/html", and navigationParams.
-
~IF[ %文書 の`~URL$doc ~EQ `~about_blank$sc ] ⇒ `文書を~html-head-bodyで拡充する$( %文書 ) ◎ If document's URL is about:blank, then populate with html/head/body given document.
注記: この特別な事例では、 %文書 が`初期~about_blank な文書$でない場合でも, 要素~nodeが同期的に与えられる — これは、 配備-済みな内容と互換にするために必要yである。 言い換えれば、 次の段 ~ELSE 以下の分岐へ入って[ %文書 を非同期的に拡充するよう,`~HTML構文解析器$の中へ空な`~byte列$を投入する ]こととは互換でない。 ◎ This special case, where even non-initial about:blank Documents are synchronously given their element nodes, is necessary for compatible with deployed content. In other words, it is not compatible to instead go down the "otherwise" branch and feed the empty byte sequence into an HTML parser to asynchronously populate document.
-
~ELSE ⇒ 新たな`~HTML構文解析器$ %構文解析器 を作成して %文書 に結付ける — ~UAは、 以下に挙げる各項に従うモノトスル: ◎ Otherwise, create an HTML parser and associate it with the document.\
- ~fetchingを走らせている間に`~network用~task~source$から`~task~queue$に設置される各`~task$には、 %構文解析器 への`入力~byte~stream$を~fetchされた~byte列で埋めた上で, 入力~streamの適切な処理を %構文解析器 に遂行させる。 ◎ Each task that the networking task source places on the task queue while fetching runs must then fill the parser's input byte stream with the fetched bytes and cause the HTML parser to perform the appropriate processing of the input stream.
- 前項の`~task$のうち,最初に設置されたものは、 %構文解析器 により処理された後に,次を走らす ⇒ `~link~header群を処理する$( %文書, %~navi~params の`応答$nvP, `media^l ) ◎ The first task that the networking task source places on the task queue while fetching runs must process link headers given document, navigationParams's response, and "media", after the task has been processed by the HTML parser.
-
%文書 用に`~scriptを走らせてもよい$とされる時点まで,~script実行は生じさせない。 ◎ Before any script execution occurs, the user agent must wait for scripts may run for the newly-created document to be true for document.
注記: `入力~byte~stream$に渡された~byte列は、文字~並びに変換されて`~tokenizer$に渡される。 この処理nの一部は、 資源の~~真の `~Content-Type~metadata$から見出される文字~符号化法~情報に依拠する — 資源から`算出される~MIME型$は、 その目的には利用されない。 ◎ The input byte stream converts bytes into characters for use in the tokenizer. This process relies, in part, on character encoding information found in the real Content-Type metadata of the resource; the computed type is not used for this purpose.
-
可用な~byte列が尽きたときは、 次を遂行する ⇒ `大域~taskを~queueする$( `~network用~task~source$, %文書 に`関連な大域~obj$, 次の手続き ) ◎ When no more bytes are available, the user agent must queue a global task on the networking task source given document's relevant global object to\
手続きは ⇒ 構文解析器に暗黙な~EOF文字を処理させる (これは、最終的に `load$et ~eventを発火させることになる) ◎ have the parser process the implied EOF character, which eventually causes a load event to be fired.
- ~RET %文書 ◎ Return document.
7.5.3. ~XML文書の読込n法
~UAは,~XML~fileを~inlineに表示することになった場合には、 供された ( `~navi~params$ %~navi~params, 文字列 %~MIME型 ) に対し, 次に挙げる各~仕様 ⇒# `XML$r, `XMLNS$r, `RFC7303$r, `DOM$r, 関連な他の仕様 ◎終 に定義される要件に従う下で,次を行うモノトスル:
- %文書 ~LET `文書を作成して初期化する$( `xml^l, %~MIME型, %~navi~params )
- 対応する`~XML構文解析器$を作成する
- ~RET %文書
注記: これを書いている時点では,~XML仕様~communityは、 実際には,~XMLと~DOMとがどう相互作用するか まだ指定していない。 ◎ At the time of writing, the XML specification community had not actually yet specified how XML and the DOM interact.
~UAは、 作成した`文書$ %文書 に対し,以下に挙げる各項に従うモノトスル: ◎ ↓
- ~fetchingを走らす間に[ `~network用~task~source$から`~task~queue$に対し設置された最初の`~task$ ]は、 `~XML構文解析器$により処理された後に,次を走らす ⇒ `~link~header群を処理する$( %文書, %~navi~params の`応答$nvP, `media^l ) ◎ The first task that the networking task source places on the task queue while fetching runs must process link headers given document, navigationParams's response, and "media", after the task has been processed by the XML parser.
- [ 上に挙げた各 仕様の規則に則って,文字~符号化法を決定する ]ときには、[ 実際の~HTTP~headerや他の~metadata ]のうち[ この仕様が与える~algoにより[ 変異される/含意される ]~header ]でないものを利用した上で、 %文書 の`符号化法$docは,そのように確立された符号化法に設定する。 ◎ The actual HTTP headers and other metadata, not the headers as mutated or implied by the algorithms given in this specification, are the ones that must be used when determining the character encoding according to the rules given in the above specifications. Once the character encoding is established, the document's character encoding must be set to that character encoding.
- %文書 用に`~scriptを走らせてもよい$とされる時点まで,~script実行は生じさせない。 ◎ Before any script execution occurs, the user agent must wait for scripts may run for the newly-created document to be true for the newly-created Document.
-
構文解析が完了したなら、 %文書 の`読込ng中における~WebDriver-BiDi用の~navi~ID$docを ~NULL に設定する。 ◎ Once parsing is complete, the user agent must set document's during-loading navigation ID for WebDriver BiDi to null.
注記: ~HTML文書に対しては,これは、 構文解析を完了したとき `load^et ~eventを発火した後に設定し直される ◎ For HTML documents this is reset when parsing is complete, after firing the load event.
~UAは、 構文解析-時の~error(例: ~XML名前空間 整形式性~error)に際しては, 当の`文書$を変異して~inlineに報告してもヨイ。 ◎ Error messages from the parse process (e.g., XML namespace well-formedness errors) may be reported inline by mutating the Document.
7.5.4. ~text文書の読込n法
`~text文書を読込む@ ときは、 所与の ( `~navi~params$ %~navi~params, 文字列 %~MIME型 ) に対し: ◎ To load a text document, given a navigation params navigationParams and a string type:
- %文書 ~LET `文書を作成して初期化する$( `html^l, %~MIME型, %~navi~params ) ◎ Let document be the result of creating and initializing a Document object given "html", type, and navigationParams.
- %文書 の`構文解析器は~modeを変更できないか$ ~SET ~T ◎ Set document's parser cannot change the mode flag to true.
- %文書 の`~mode$doc ~SET `no-quirks^l ◎ Set document's mode to "no-quirks".
-
新たな`~HTML構文解析器$を作成して %文書 に結付ける — ~UAは、 以下に挙げる各項に従うモノトスル: ◎ Create an HTML parser and associate it with the document.\
- この構文解析器は、 その~tokenizerが すでに次を順に行ったかのように動作する ⇒# ~tag名 `pre^l の開始~tag~tokenを発した; 1 個の文字 U+000A (LF)を発した; `~PLAINTEXT状態$に切替えた ◎ Act as if the tokenizer had emitted a start tag token with the tag name "pre" followed by a single U+000A LINE FEED (LF) character, and switch the HTML parser's tokenizer to the PLAINTEXT state.\
- ~fetchingを走らせている間に`~network用~task~source$から`~task~queue$に設置される各`~task$は、 構文解析器の`入力~byte~stream$を~fetchされた~byte列で埋めて,構文解析器に入力~streamの適切な処理を遂行させる。 ◎ Each task that the networking task source places on the task queue while fetching runs must then fill the parser's input byte stream with the fetched bytes and cause the HTML parser to perform the appropriate processing of the input stream.
- %文書 の`符号化法$docは、 当の文書を復号する間に利用した文字~符号化法に設定する。 ◎ document's encoding must be set to the character encoding used to decode the document during parsing.
- 前述の`~task$のうち,最初に設置されたものは、 %構文解析器 により処理された後に,次を走らす ⇒ `~link~header群を処理する$( %文書, %~navi~params の`応答$nvP, `media^l ) ◎ The first task that the networking task source places on the task queue while fetching runs must process link headers given document, navigationParams's response, and "media", after the task has been processed by the HTML parser.
- %文書 用に`~scriptを走らせてもよい$とされる時点まで,~script実行は生じさせない。 ◎ Before any script execution occurs, the user agent must wait for scripts may run for the newly-created document to be true for document.
-
可用な~byte列が尽きたときは、 次を遂行する ⇒ `大域~taskを~queueする$( `~network用~task~source$, %文書 に`関連な大域~obj$, 次の手続き ) ◎ When no more bytes are available, the user agent must queue a global task on the networking task source given document's relevant global object to\
手続きは ⇒ 構文解析器に暗黙な~EOF文字を処理させる (これは、最終的に `load$et ~eventを発火させることになる) ◎ have the parser process the implied EOF character, which eventually causes a load event to be fired.
-
任意選択で ⇒ %文書 の `head$e 要素に内容を追加する — 例: ~stylesheetへ~linkする/ ~scriptを供する/ 文書に `title$e を与える/ 等々。 ◎ User agents may add content to the head element of document, e.g., linking to a style sheet, providing script, or giving the document a title.
注記: 特に、 RFC 3676 の `Format=Flowed^c 特能を~supportする~UAは、[ ~textを正しく折返す/ 【行頭の ">" による】 引用用の特能を取扱う ]ために,何らかの~styleを適用する必要が生じることになる。 これは、 例えば~CSS拡張を利用して遂行することもできる。 ◎ In particular, if the user agent supports the Format=Flowed feature of RFC 3676 then the user agent would need to apply extra styling to cause the text to wrap correctly and to handle the quoting feature. This could be performed using, e.g., a CSS extension.
- ~RET %文書 ◎ Return document.
素な~text文書の~byte列を 実際の文字に変換する規則,および その~textを利用者~向けに実際に具現化する規則は、 当の資源から`算出される~MIME型$(すなわち, %~MIME型 )の仕様により定義される。 ◎ The rules for how to convert the bytes of the plain text document into actual characters, and the rules for actually rendering the text to the user, are defined by the specifications for the computed MIME type of the resource (i.e., type).
7.5.5. `multipart/x-mixed-replace$mt 文書の読込n法
`multipart/x-mixed-replace 文書を読込む@ ときは、 所与の ⇒# `~navi~params$ %~navi~params, `~source~snapshot~params$ %~source~snapshot~params, `生成元$ %起動元~生成元 ◎終 に対し: ◎ To load a multipart/x-mixed-replace document, given navigation params navigationParams, source snapshot params sourceSnapshotParams, and origin initiatorOrigin:
- %~navi~params の`応答$nvPの`本体$rsを `RFC2046$r による複-部位t( `multipart^c )型~用の規則を利用して構文解析する ◎ Parse navigationParams's response's body using the rules for multipart types. [RFC2046]
- %最初の部位t用の~navi~params ~LET %~navi~params の複製 ◎ Let firstPartNavigationParams be a copy of navigationParams.
- %最初の部位t用の~navi~params の`応答$nvP ~SET %~navi~params の`応答$nvPの`本体$rsの複-部位t~streamを成す最初の部位tを表現している新たな`応答$ ◎ Set firstPartNavigationParams's response to a new response representing the first part of navigationParams's response's body's multipart stream.
-
%文書 ~LET `文書を読込む$( %最初の部位t用の~navi~params, %~source~snapshot~params, %起動元~生成元 ) ◎ Let document be the result of loading a document given firstPartNavigationParams, sourceSnapshotParams, and initiatorOrigin.
%~navi~params の`応答$nvPから得された 2 個目以降の各 本体~部位tに対しては、 ~UAは,次を行うモノトスル ⇒ `~navigableを~URLへ~navigateする$( %文書 の`~node~navigable$, %~navi~params の`要請$nvPの`~URL$rq, %文書 ) — 次を与える下で ⇒# `応答^i ~SET %~navi~params の`応答$nvP, `履歴~取扱い^i ~SET `replace$hH ◎ For each additional body part obtained from navigationParams's response, the user agent must navigate document's node navigable to navigationParams's request's URL, using document, with response set to navigationParams's response and historyHandling set to "replace".
- ~RET %文書 ◎ Return document.
~UAは、 これらの[ 各 本体~部位tを完全に自立的な資源であったかのように処理する目的 ]においては、 各 本体~部位tに対し[ それに後続する境界に達した所で,当の資源~用の~byte列は尽きた ]かのように動作するモノトスル。 ◎ For the purposes of algorithms processing these body parts as if they were complete stand-alone resources, the user agent must act as if there were no more bytes for those resources whenever the boundary following the body part is reached.
注記: したがって, `load$et ~event(および,対になる `unload$et ~event)は、 各 本体~部位tが読込まれる度に発火されることになる。 ◎ Thus, load events (and for that matter unload events) do fire for each body part loaded.
7.5.6. ~media文書の読込n法
`~media文書を読込む@ ときは、 所与の ( `~navi~params$ %~navi~params, 文字列 %~MIME型 ) に対し: ◎ To load a media document, given navigationParams and a string type:
- %文書 ~LET `文書を作成して初期化する$( `html^l, %~MIME型, %~navi~params ) ◎ Let document be the result of creating and initializing a Document object given "html", type, and navigationParams.
- %文書 の`~mode$doc ~SET `no-quirks^l ◎ Set document's mode to "no-quirks".
- ( %html, %head, %body ) ~LET `文書を~html-head-bodyで拡充する$( %文書 ) ◎ Populate with html/head/body given document.
- %要素~型 ~LET 【 %~MIME型 から導出される】当の資源の~media型に応じて ⇒# 画像ならば `img$e / 動画ならば `video$e / 音声ならば `audio$e ◎ ↓
- %~host要素 ~LET `要素を作成する$( %文書, %要素~型, `~HTML名前空間$ ) ◎ ↓
- %body に`~nodeを付加する$( %要素 ) ◎ Append an element host element for the media,\ ↓↓as described below, to the body element.
-
%~host要素 の`属性~値を設定する$( `src^l, 当の資源の~address )
(これは、[ 画像の場合は `img$e の `src@~HEimages#attr-img-src$a / [ 動画/音声 ]の場合は[ `video$e / `audio$e ]の `src@~HEmedia#attr-media-src$a ]を設定する。)
◎ Set the appropriate attribute of the element host element, as described below, to the address of the image, video, or audio resource. ◎ ↓↓ -
任意選択で ⇒# %head に内容を追加する/ %~host要素 に属性を追加する ◎ User agents may add content to the head element of document, or attributes to host element,\
例 ⇒# ある~stylesheetへ~linkする ある~scriptを供する/ 当の文書に `title$e を与える/ 当の~mediaを `autoplay$a にする ◎ e.g., to link to a style sheet, to provide a script, to give the document a title, or to make the media autoplay.
- `~link~header群を処理する$( %文書, %~navi~params の`応答$nvP, `media^l ) ◎ Process link headers given document, navigationParams's response, and "media".
- %文書 の`構文解析を停止した$かのように動作する ◎ Act as if the user agent had stopped parsing document.
- ~RET %文書 ◎ Return document. ◎ ↑↑ The element host element to create for the media is the element given in the table below in the second cell of the row whose first cell describes the media. The appropriate attribute to set is the one given by the third cell in that same row. ◎ ↑↑ Type of media|Element for the media|Appropriate attribute Image|img|src Video|video|src Audio|audio|src
~UAは、 `文書$用に`~scriptを走らせてもよい$とされる時点まで, ~script実行は生じさせないモノトスル。 ◎ Before any script execution occurs, the user agent must wait for scripts may run for the newly-created document to be true for the Document.
7.5.7. ~DOMを有さない~inline内容~用の文書の読込n法
~UAは,[ ~UA~page/~PDF~viewer ]を~inlineに表示するための文書を作成するときは、 供された ⇒# `~navigable$ %~navigable, `~navi~ID$ %~navi~ID, `NavigationTimingType$I %~navi計時~種別, `~naviに対する利用者-関与i$ %利用者-関与i ◎終 に対し,次に従うベキである: ◎ When the user agent is to create a document to display a user agent page or PDF viewer inline, provided a navigable navigable, a navigation ID navigationId, a NavigationTimingType navTimingType, and a user navigation involvement userInvolvement, the user agent should:
- %生成元 ~LET 新たな`不透明な生成元$ ◎ Let origin be a new opaque origin.
- %~COOP ~LET 新たな`~opener施策$ ◎ Let coop be a new opener policy.
- %~COOP施行n結果 ~LET 新たな`~opener施策の施行n結果$ — その ⇒# `~URL$cooP ~SET %応答 の`~URL$rs, `生成元$cooP ~SET %生成元, `~opener施策$cooP ~SET %~COOP ◎ Let coopEnforcementResult be a new opener policy enforcement result with ◎ url • response's URL origin • origin opener policy • coop
- %~navi~params ~LET 新たな`~navi~params$ — その ⇒# `~ID$nvP ~SET %~navi~ID, `~navigable$nvP ~SET %~navigable, `要請$nvP ~SET ~NULL, `応答$nvP ~SET 新たな`応答$, `生成元$nvP ~SET %生成元, `~fetch制御器$nvP ~SET ~NULL, `早期~hintを~commitする$nvP ~SET ~NULL, `~COOP施行n結果$nvP ~SET %~COOP施行n結果, `予約-済み環境$nvP ~SET ~NULL, `施策~容器$nvP ~SET 新たな`施策~容器$, `最終-~sandbox~flag集合$nvP ~SET 空な集合, `~opener施策$nvP ~SET %COOP, `~navi計時~種別$nvP ~SET %~navi計時~種別, `~about基底~URL$nvP ~SET ~NULL, `利用者-関与i$nvP ~SET %利用者-関与i ◎ Let navigationParams be a new navigation params with ◎ id • navigationId navigable • navigable request • null response • a new response origin • origin fetch controller • null commit early hints • null COOP enforcement result • coopEnforcementResult reserved environment • null policy container • a new policy container final sandboxing flag set • an empty set opener policy • coop navigation timing type • navTimingType about base URL • null user involvement • userInvolvement
- %文書 ~LET `文書を作成して初期化する$( `html^l, `text/html^l, %~navi~params ) ◎ Let document be the result of creating and initializing a Document object given "html", "text/html", and navigationParams.
-
次のいずれかを行う: ◎ Either\
- %文書 に~customな — `文書$の通常の具現化~規則を利用しない — 具現化を結付ける ◎ associate document with a custom rendering that is not rendered using the normal Document rendering rules, or\
- %文書 を[ ~UAが具現化するよう求める内容 ]を表現するよう変異させる ◎ mutate document until it represents the content the user agent wants to render.
- ~RET %文書 ◎ Return document.
注記: 結果の`文書$は、 その`生成元$docは`不透明な生成元$になるよう確保され, ~DOMへの~accessを伴う~scriptを走らすことはないので、 この文書の存在, その~propは,~web開発者~codeからは観測-可能にならない。 このことは、 上の値のうち ほとんど — 例: `種別$doc `text/html$mt — は問われないことを意味する。 類似に, %~navi~params を成す ほとんどの~itemは、 ~~形式上のものでしかなく,観測-可能な効果を伴うことはない — なので、 既定の値に設定される。 ◎ Because we ensure the resulting Document's origin is opaque, and the resulting Document cannot run script with access to the DOM, the existence and properties of this Document are not observable to web developer code. This means that most of the above values, e.g., the text/html type, do not matter. Similarly, most of the items in navigationParams don't have any observable effect, besides preventing the Document-creation algorithm from getting confused, and so are set to default values.
~UAは、 ~pageが設定しておかれたなら,`構文解析を停止した$かのように動作するモノトスル。 ◎ Once the page has been set up, the user agent must act as if it had stopped parsing.
7.5.8. 読込ng処理nの完遂-法
各 `文書$には `完全に読込まれた時刻@ (ある時刻または ~NULL )がある — 初期~時は ~NULL とする。 ◎ A Document has a completely loaded time (a time or null), which is initially null.
所与の`文書$は、 その`完全に読込まれた時刻$ ~NEQ ~NULL ならば, `完全に読込まれた@ ものと見なされる。 ◎ A Document is considered completely loaded if its completely loaded time is non-null.
`文書$ %文書 の `読込ngを完全に終わらす@ ときは: ◎ To completely finish loading a Document document:
- ~Assert: %文書 が`属する閲覧~文脈$ ~NEQ ~NULL ◎ Assert: document's browsing context is non-null.
- %文書 の`完全に読込まれた時刻$ ~SET 現在の時刻 ◎ Set document's completely loaded time to the current time.
-
%容器 ~LET %文書 の`~node~navigable$の`容器$nav ◎ Let container be document's node navigable's container.
注記: これは、 %文書 が[ `iframe$e / `frame$e ]内の`初期~about_blank な文書$である事例では, ~NULL になる — この~algoを~callする`新たな閲覧~文脈と文書を作成する$時点では、 当の容器~関係性は,まだ確立されていないので (それが起こる段は、 `新たな子~navigableを作成する$ときである)。 ◎ This will be null in the case where document is the initial about:blank Document in a frame or iframe, since at the point of browsing context creation which calls this algorithm, the container relationship has not yet been established. (That happens in a subsequent step of create a new child navigable.)
その帰結として、 以降の手続きは,何もしなくなる — すなわち,そのような事例では、 `load$et ~eventは, %容器 に向けて非同期的には発火されなくなる。 代わりに,その~eventは、 `~iframe属性~群を処理する$ときに,ある特別な初期~挿入~事例において同期的に発火される。 ◎ The consequence of this is that the following steps do nothing, i.e., we do not fire an asynchronous load event on the container element for such cases. Instead, a synchronous load event is fired in a special initial-insertion case when processing the iframe attributes.
-
~IF[ %容器 は `iframe$e 要素である ] ⇒ `要素~taskを~queueする$( `~DOM操作~task~source$, %容器, 次の手続き )
手続きは ⇒ `~iframe~load~event手続き$( %容器 )◎ If container is an iframe element, then queue an element task on the DOM manipulation task source given container to run the iframe load event steps given container. -
~ELIF[ %容器 ~NEQ ~NULL ] ⇒ `要素~taskを~queueする$( `~DOM操作~task~source$, %容器, 次の手続き )
手続きは ⇒ `~eventを発火する$( %容器, `load$et )◎ Otherwise, if container is non-null, then queue an element task on the DOM manipulation task source given container to fire an event named load at container.
7.5.9. 文書の~unload法
各 `文書$は、 次に挙げるものを持つ:
- `回復可能か@doc ⇒ 真偽値 — 初期~時は ~T になるモノトスル。 ◎ A Document has a salvageable state, which must initially be true,\
-
`~pageを示しているか@doc ⇒ 真偽値 — 初期~時は ~F になるモノトスル。 ◎ and a page showing flag, which must initially be false.\
これは、 次を確保するために利用される ⇒ ~scriptが[ `pageshow$et, `pagehide$et ]~eventを整合的に受取る (例: `pageshow$et を間に挟むことなく 2 つの `pagehide$et ~eventを続けて受取ったり,その逆が生じることは、決してない)。 ◎ The page showing flag is used to ensure that scripts receive pageshow and pagehide events in a consistent manner (e.g. that they never receive two pagehide events in a row without an intervening pageshow, or vice versa).
- `休止~時刻@doc ⇒ `DOMHighResTimeStamp$I 値 — 初期~時は 0 とする。 ◎ A Document has a DOMHighResTimeStamp suspension time, initially 0.
- `休止された~timer~handle群@doc ⇒ `~list$ — 初期~時は空とする。 ◎ A Document has a list of suspended timer handles, initially empty.
各`~event~loop$には、 `終了n入子ng~level@ と呼ばれる~counterがある — 初期~時は 0 になるモノトスル。 ◎ Event loops have a termination nesting level counter, which must initially be 0.
各 `文書$には、 `~unload~counter@ がある — 初期~時は 0 に設定するモノトスル。 それは、 以下の各種~algoが走っている間,ある種の演算を無視するために利用される。 ◎ Document objects have an unload counter, which is used to ignore certain operations while the below algorithms run. Initially, the counter must be set to zero.
`文書を~unloadする@ ときは、 所与の ( `文書$ %旧-文書, `文書$ %新-文書(省略時は ε ) ) に対し: ◎ To unload a Document oldDocument, given an optional Document newDocument:
- ~Assert: この~algoは、[ %旧-文書 に`関連な~agent$の`~event~loop$aGに~queueされた`~task$ ]の一部として走っている。 ◎ Assert: this is running as part of a task queued on oldDocument's relevant agent's event loop.
- %~unload計時~報 ~LET 新たな`文書~unload計時~報$ ◎ Let unloadTimingInfo be a new document unload timing info.
-
~IF[ %新-文書 ~EQ ε ] ⇒ %~unload計時~報 ~SET ~NULL ◎ If newDocument is not given, then set unloadTimingInfo to null.
注記: この事例では、[ %旧-文書 を~unloadするのに,いつまでかかるか ]を知る必要がある新たな文書は無い。 ◎ In this case there is no new document that needs to know about how long it took oldDocument to unload.
-
~ELIF[ %新-文書 の`~event~loop$ ~NEQ %旧-文書 の`~event~loop$ ]:
- 任意選択で ⇒ 次を`並列的$に遂行する ⇒ `文書を~unloadする$( %旧-文書 )
- `that^en 事例においては†、 %~unload計時~報 を ~NULL に設定するベキである††。
【† [ ~unloadする場合, ~IF 条件を満たす場合 ]どちらを指しているのか、 はっきりしない(前者?)。 】【†† %~unload計時~報 が[ この~algo~instanceの中のそれ/ 上で`文書を~unloadする$中のそれ ]どちらを指すのか,はっきりしない。 】
◎ Otherwise, if newDocument's event loop is not oldDocument's event loop, then the user agent may be unloading oldDocument in parallel. In that case, the user agent should set unloadTimingInfo to null.注記: この事例では、 %新-文書 の読込ngは[ %旧-文書 を~unloadするのに,いつまでかかるか ]により影響iされないので, その計時~報を通信することも無意味になる。 ◎ In this case newDocument's loading is not impacted by how long it takes to unload oldDocument, so it would be meaningless to communicate that timing info.
-
%~BF~cache内に保つか ~LET ~IS[[ %旧-文書, および %旧-文書 のすべての子孫 ]は,どれも ~AND↓ を満たす ]:
- その`回復可能か$doc ~EQ ~T
- ~UAは、 後で`履歴~辿り用に利用できる@~HTMLnav#note-bfcache$よう, それが`~session履歴~entry$内に生存し続けることを意図する
- %~event~loop ~LET %旧-文書 に`関連な~agent$の`~event~loop$aG ◎ Let eventLoop be oldDocument's relevant agent's event loop.
- %~event~loop の`終了n入子ng~level$ ~INCBY 1 ◎ Increase eventLoop's termination nesting level by 1.
- %旧-文書 の`~unload~counter$ ~INCBY 1 ◎ Increase oldDocument's unload counter by 1.
- ~IF[ %~BF~cache内に保つか ~EQ ~F ] ⇒ %旧-文書 の`回復可能か$doc ~SET ~F ◎ If intendToKeepInBfcache is false, then set oldDocument's salvageable state to false.
-
~IF[ %旧-文書 の`~pageを示しているか$doc ~EQ ~T ]: ◎ If oldDocument's page showing is true:
- %旧-文書 の`~pageを示しているか$doc ~SET ~F ◎ Set oldDocument's page showing to false.
- `~page遷移~eventを発火する$( %旧-文書 に`関連な大域~obj$, `pagehide$et, %旧-文書 の`回復可能か$doc ) ◎ Fire a page transition event named pagehide at oldDocument's relevant global object with oldDocument's salvageable state.
- `可視性~状態を更新する$( %旧-文書, `hidden^l ) ◎ Update the visibility state of oldDocument to "hidden".
- ~IF[ %~unload計時~報 ~NEQ ~NULL ] ⇒ %~unload計時~報 の`~unload~event開始~時刻$ ~SET `時刻を粗化する$( `現在の高分解能~時刻$( %新-文書 に`関連な大域~obj$ ), %旧-文書 に`関連な設定群~obj$の`非同一-生成元~能力は隔離されるか?$enV ) ◎ If unloadTimingInfo is not null, then set unloadTimingInfo's unload event start time to the current high resolution time given newDocument's relevant global object, coarsened given oldDocument's relevant settings object's cross-origin isolated capability.
- ~IF[ %旧-文書 の`回復可能か$doc ~EQ ~F ] ⇒ `~eventを発火する$( %旧-文書 に`関連な大域~obj$, `unload$et ) — `~targetを上書きする^i 下で ◎ If oldDocument's salvageable state is false, then fire an event named unload at oldDocument's relevant global object, with legacy target override flag set.
- ~IF[ %~unload計時~報 ~NEQ ~NULL ] ⇒ %~unload計時~報 の`~unload~event終了~時刻$ ~SET `時刻を粗化する$( `現在の高分解能~時刻$( %新-文書 に`関連な大域~obj$ ), %旧-文書 に`関連な設定群~obj$の`非同一-生成元~能力は隔離されるか?$enV ) ◎ If unloadTimingInfo is not null, then set unloadTimingInfo's unload event end time to the current high resolution time given newDocument's relevant global object, coarsened given oldDocument's relevant settings object's cross-origin isolated capability.
- %~event~loop の`終了n入子ng~level$ ~DECBY 1 ◎ Decrease eventLoop's termination nesting level by 1.
- %旧-文書 の`休止~時刻$doc ~SET `現在の高分解能~時刻$( %文書【%旧-文書】 に`関連な大域~obj$ ) ◎ Set oldDocument's suspension time to the current high resolution time given document's relevant global object.
- %旧-文書 の`休止された~timer~handle群$doc ~SET 【 %旧-文書 に`関連な大域~obj$の】`作動中な~timer群が成す~map$の`~key群$map ◎ Set oldDocument's suspended timer handles to the result of getting the keys for the map of active timers.
- %旧-文書 の`利用者により~scrollされたか$doc ~SET ~F ◎ Set oldDocument's has been scrolled by the user to false.
- この仕様も含む`適用-可能な仕様$にて定義される `文書~unload時の片付け手続き$があれば、 それらの各~手続きを %旧-文書 を渡して走らす 【そのような手続きが複数ある場合に,どの順序で走らすかは、指定されていない。】 ◎ Run any unloading document cleanup steps for oldDocument that are defined by this specification and other applicable specifications.
- ~IF[ %旧-文書 の`~node~navigable$は`~top-level辿可能$である ] ⇒ `~top-level辿可能とその子孫~用に復旧されない事由~群を築く$( %旧-文書 の`~node~navigable$ ) ◎ If oldDocument's node navigable is a top-level traversable, build not restored reasons for a top-level traversable and its descendants given oldDocument's node navigable.
- ~IF[ %旧-文書 の`回復可能か$doc ~EQ ~F ] ⇒ `文書を破壊する$( %旧-文書 ) ◎ If oldDocument's salvageable state is false, then destroy oldDocument.
- %旧-文書 の`~unload~counter$ ~DECBY 1 ◎ Decrease oldDocument's unload counter by 1.
- ~IF[ %新-文書 ~NEQ ε ]~AND[ %新-文書 の`非同一-生成元~redirectを介して作成されたか$doc ~EQ ~F ]~AND[ ( %新-文書 の`生成元$doc, %旧-文書 の`生成元$doc ) は`同一-生成元$である ] ⇒ %新-文書 の`前-文書の~unload計時~報$doc ~SET %~unload計時~報 ◎ If newDocument is given, newDocument's was created via cross-origin redirects is false, and newDocument's origin is the same as oldDocument's origin, then set newDocument's previous document unload timing to unloadTimingInfo.
`文書とその子孫たちを~unloadする@ ときは、 所与の ⇒# `文書$ %文書, [ `文書$/~NULL ] %新-文書(省略時は ~NULL ), 手続き %すべて~unload後の手続き(省略時は ε ), 手続き %~pageswap_evを発火する手続き(省略時は ε ) ◎終 に対し: ◎ To unload a document and its descendants, given a Document document, an optional Document-or-null newDocument (default null), an optional set of steps afterAllUnloads, and an optional set of steps firePageSwapSteps:
- ~Assert: この~algoは、[ %文書 の`~node~navigable$の`辿可能な~navigable$navの`~session履歴~辿り~queue$nav ]の中で走っている。 ◎ Assert: this is running within document's node navigable's traversable navigable's session history traversal queue.
- %~unload済み数 ~LET 0 ◎ ↓ Let childNavigables be document's child navigables. ◎ Let numberUnloaded be 0.
-
%文書 の【`~node~navigable$の】 ~EACH( `子~navigable$ %子~navigable ) に対し 順序は どうする? ⇒ `大域~taskを~queueする$( `~naviと辿り~task~source$, %子~navigable にて`作動中な~window$nav, 次の手続き ) ◎ For each childNavigable of childNavigable's in what order?, queue a global task on the navigation and traversal task source given childNavigable's active window to perform\
手続きは: ◎ the following steps:
- %~unload済みを増加する ~LET 次を走らす~algo ⇒ %~unload済み数 ~INCBY 1 ◎ Let incrementUnloaded be an algorithm step which increments numberUnloaded.
- `文書とその子孫たちを~unloadする$( %子~navigable にて`作動中な文書$nav, ~NULL, %~unload済みを増加する ) ◎ Unload a document and its descendants given childNavigable's active document, null, and incrementUnloaded.
- 次が満たされるまで待機する ⇒ %~unload済み数 ~EQ %子~navigable の`~size$ ◎ Wait until numberUnloaded equals childNavigable's size.
-
`大域~taskを~queueする$( `~naviと辿り~task~source$, %文書 に`関連な大域~obj$, 次の手続き ) ◎ Queue a global task on the navigation and traversal task source given document's relevant global object to perform\
手続きは: ◎ the following steps:
- ~IF[ %~pageswap_evを発火する手続き ~NEQ ε ] ⇒ %~pageswap_evを発火する手続き() ◎ If firePageSwapSteps is given, then run firePageSwapSteps.
- ~IF[ %新-文書 ~EQ ~NULL ] ⇒ `文書を~unloadする$( %文書 ) ◎ ↓
- ~ELSE ⇒ `文書を~unloadする$( %文書, %新-文書 ) ◎ Unload document, passing along newDocument if it is not null.
- ~IF[ %すべて~unload後の手続き ~NEQ ε ] ⇒ %すべて~unload後の手続き() ◎ If afterAllUnloads was given, then run it.
この仕様は、 `文書~unload時の片付け手続き@ として,次を定義する — 他の仕様も,この手続きをさらに定義し得る。 それは、 所与の ( `文書$ %文書 ) に対し: ◎ This specification defines the following unloading document cleanup steps. Other specifications can define more. Given a Document document:
- %~window ~LET %文書 に`関連な大域~obj$ ◎ Let window be document's relevant global object.
- ~EACH( `WebSocket$I ~obj %O ) に対し ⇒ ~IF[ %O に`関連な大域~obj$ ~EQ %~window ] ⇒# %O を`消滅させる$; `文書を回復不能にする$( %文書, `websocket$l ) ◎ For each WebSocket object webSocket whose relevant global object is window, make disappear webSocket. ◎ If this affected any WebSocket objects, then make document unsalvageable given document and "websocket".
- ~EACH( `WebTransport$I ~obj %O ) に対し ⇒ ~IF[ %O に`関連な大域~obj$ ~EQ %~window ] ⇒ `文脈を片付ける手続き$( %O ) ◎ For each WebTransport object transport whose relevant global object is window, run the context cleanup steps given transport.
-
~IF[ %文書 の`回復可能か$doc ~EQ ~F ]: ◎ If document's salvageable state is false, then:
- ~EACH( `EventSource$I ~obj %O ) に対し ⇒ ~IF[ %O に`関連な大域~obj$ ~EQ %~window ] ⇒ %O を`強制的に~closeする$ ◎ For each EventSource object eventSource whose relevant global object is equal to window, forcibly close eventSource.
- %~window にて`作動中な~timer群が成す~map$を`~clearする$map ◎ Clear window's map of active timers.
`文書~unload時の片付け手続き$ ~hookを利用する仕様~策定者は、 代わりに,[ ここから自身の仕様の中への~callを直に追加する~pull要請 ]を送信する方が良い — そうすれば、[ 各~仕様からの~call順序がきちんと定義される ]ことが確保されるので。 これを書いた時点では、 次に挙げる仕様が`文書~unload時の片付け手続き$を利用していることが既知であり, それらは未指定な順序で走ることになる ⇒# `FULLSCREEN$r, `WEBNFC$r, `WEBDRIVERBIDI$r, `COMPUTEPRESSURE$r, `FILEAPI$r, `MEDIASTREAM$r, `PICTUREINPICTURE$r, `SCREENORIENTATION$r, `SW$r, `WEBLOCKS$r, `WEBAUDIO$r, `WEBRTC$r ◎ It would be better if specification authors sent a pull request to add calls from here into their specifications directly, instead of using the unloading document cleanup steps hook, to ensure well-defined cross-specification call order. As of the time of this writing the following specifications are known to have unloading document cleanup steps, which will be run in an unspecified order: Fullscreen API, Web NFC, WebDriver BiDi, Compute Pressure, File API, Media Capture and Streams, Picture-in-Picture, Screen Orientation, Service Workers, WebLocks API, WebAudio API, WebRTC. [FULLSCREEN] [WEBNFC] [WEBDRIVERBIDI] [COMPUTEPRESSURE] [FILEAPI] [MEDIASTREAM] [PICTUREINPICTURE] [SCREENORIENTATION] [SW] [WEBLOCKS] [WEBAUDIO] [WEBRTC]
これらの手続きの順序を明瞭にする作業は、 `課題 #8906@~HTMLissue/8906$ にて追跡されている。 ◎ Issue #8906 tracks the work to make the order of these steps clear.
7.5.10. 文書の破壊-法
`文書を破壊する@ ときは、 所与の ( `文書$ %文書 ) に対し: ◎ To destroy a Document document:
- ~Assert: この~algoは、[ %文書 に`関連な~agent$の`~event~loop$aGに~queueされた`~task$ ]の一部として走っている。 ◎ Assert: this is running as part of a task queued on document's relevant agent's event loop.
- `文書を中止する$( %文書 ) ◎ Abort document.
- %文書 の`回復可能か$doc ~SET ~F ◎ Set document's salvageable state to false.
- ~EACH( `MessagePort$I %~port ) に対し ⇒ ~IF[ %~port に`関連な大域~obj$に`結付けられた文書$ ~EQ %文書 ] ⇒ `~portの連絡を断つ$( %~port ) ◎ Let ports be the list of MessagePorts whose relevant global object's associated Document is document. ◎ For each port in ports, disentangle port.
- この仕様も含む`適用-可能な仕様$に定義される`文書~unload時の片付け手続き$があれば、 それらの各~手続きを %文書 を渡して走らす 【そのような手続きが複数ある場合に,どの順序で走らすかは、指定されていない。】 ◎ Run any unloading document cleanup steps for document that are defined by this specification and other applicable specifications.
- ~queueされた`~task$のうち[ その`文書$tK ~EQ %文書 ]を満たすものは、 (~taskを走らすことなく)除去する ◎ Remove any tasks whose document is document from any task queue (without running those tasks).
- %文書 が`属する閲覧~文脈$ ~SET ~NULL ◎ Set document's browsing context to null.
- %文書 の`~node~navigable$にて`作動中な~entry$nav の`文書~状態$shE の`文書$dS ~SET ~NULL ◎ Set document's node navigable's active session history entry's document state's document to null.
- ~EACH( `WorkerGlobalScope$I ~obj %O ) に対し ⇒ %O の`所有者~集合$wGから %文書 を`除去する$ ◎ Remove document from the owner set of each WorkerGlobalScope object whose set contains document.
- %文書 の`~worklet大域~scope~list$docを成す ~EACH( %~worklet大域~scope ) に対し ⇒ `~worklet大域~scopeを終了させる$( %~worklet大域~scope ) ◎ For each workletGlobalScope in document's worklet global scopes, terminate workletGlobalScope.
注記: `子~navigableを破壊-@~HTMLds#destroy-a-child-navigable$している事例においては、 破壊の後でも, 当の`文書$は~scriptから~access可能になるかもしれない。 ◎ Even after destruction, the Document object itself might still be accessible to script, in the case where we are destroying a child navigable.
`文書とその子孫たちを破壊する@ ときは、 所与の ( `文書$ %文書, 手続き %すべて破壊-後の手続き(省略時は ε ) ) に対し, 次の手続きを`並列的$に遂行する: ◎ To destroy a document and its descendants given a Document document and an optional set of steps afterAllDestruction, perform the following steps in parallel:
-
~IF[ %文書 は`全部的に作動中$でない ]: ◎ If document is not fully active, then:
- %事由 ~LET [ `~UAに特有な阻んでいる事由$が適用されるならば それを表現する文字列 / ~ELSE_ `masked$l ] ◎ Let reason be a string from user-agent specific blocking reasons. If none apply, then let reason be "masked".
- `文書を回復不能にする$( %文書, %事由 ) ◎ Make document unsalvageable given document and reason.
- ~IF[ %文書 の`~node~navigable$は`~top-level辿可能$である ] ⇒ `~top-level辿可能とその子孫~用に復旧されない事由~群を築く$( %文書 の`~node~navigable$ ) ◎ If document's node navigable is a top-level traversable, build not restored reasons for a top-level traversable and its descendants given document's node navigable.
- %破壊-済み数 ~LET 0 ◎ ↓ Let childNavigables be document's child navigables. ◎ Let numberDestroyed be 0.
-
%文書 の【`~node~navigable$の】 ~EACH( `子~navigable$ %子~navigable ) に対し 順序は どうする? ⇒ `大域~taskを~queueする$( `~naviと辿り~task~source$, %子~navigable にて`作動中な~window$nav, 次の手続き ) ◎ For each childNavigable of childNavigable's in what order?, queue a global task on the navigation and traversal task source given childNavigable's active window to perform\
手続きは: ◎ the following steps:
- %破壊-済みを増加する ~LET 次を遂行する手続き ⇒ %破壊-済み数 ~INCBY 1 ◎ Let incrementDestroyed be an algorithm step which increments numberDestroyed.
- `文書とその子孫たちを破壊する$( %子~navigable にて`作動中な文書$nav, %破壊-済みを増加する ) ◎ Destroy a document and its descendants given childNavigable's active document and incrementDestroyed.
- 次が満たされるまで待機する ⇒ %破壊-済み数 ~EQ %子~navigable群【!childNavigable】 の`~size$ ◎ Wait until numberDestroyed equals childNavigable's size.
-
`大域~taskを~queueする$( `~naviと辿り~task~source$, %文書 に`関連な大域~obj$, 次の手続き ) ◎ Queue a global task on the navigation and traversal task source given document's relevant global object to perform\
手続きは: ◎ the following steps:
- `文書を破壊する$( %文書 ) ◎ Destroy document.
- ~IF[ %すべて破壊-後の手続き ~NEQ ε ] ⇒ %すべて破壊-後の手続き() ◎ If afterAllDestruction was given, then run it.
7.5.11. 文書~読込nの中止-法
`文書を中止する@ ときは、 所与の ( `文書$ %文書 ) に対し: ◎ To abort a Document document:
- ~Assert: この~algoは、[ %文書 に`関連な~agent$の`~event~loop$aGに~queueされた`~task$ ]の一部として走っている。 ◎ Assert: this is running as part of a task queued on document's relevant agent's event loop.
-
~IF[ %文書 の文脈~下にある`~fetch$~algoの~instanceがある ]:
- それらの各~instanceを取消す — 以降 ⇒# それらに対し`~queueされ$る`~task$は破棄する / それらに対し~networkから受信される更なる~dataは破棄する
- `文書を回復不能にする$( %文書, `fetch$l )
-
~IF[ %文書 の`読込ng中における~WebDriver-BiDi用の~navi~ID$doc ~NEQ ~NULL ]: ◎ If document's during-loading navigation ID for WebDriver BiDi is non-null, then:
- %~navi状態s ~LET `新たな~WebDriver-BiDi~navi状態s$( %文書 の`読込ng中における~WebDriver-BiDi用の~navi~ID$doc, `取消された$wBDst, %文書 の`~URL$doc ) ◎ ↓
- `~WebDriver-BiDi~naviは中止された$( %文書 が`属する閲覧~文脈$, %~navi状態s ) ◎ Invoke WebDriver BiDi navigation aborted with document's browsing context, and a new WebDriver BiDi navigation status whose id is document's during-loading navigation ID for WebDriver BiDi, status is "canceled", and url is document's URL.
- %文書 の`読込ng中における~WebDriver-BiDi用の~navi~ID$doc ~SET ~NULL ◎ Set document's during-loading navigation ID for WebDriver BiDi to null.
-
~IF[ %文書 には`作動中な構文解析器$がある ]: ◎ If document has an active parser, then:
- %文書 の`作動中な構文解析器は中止されたか$ ~SET ~T ◎ Set document's active parser was aborted to true.
- その`構文解析器を中止する$ ◎ Abort that parser.
- `文書を回復不能にする$( %文書, `parser-aborted$l ) ◎ Set document's salvageable to false. (不要(削除漏れ? ◎ Make document unsalvageable given document and "parser-aborted".
`文書とその子孫たちを中止する@ ときは、 所与の ( `文書$ %文書 ) に対し: ◎ To abort a document and its descendants given a Document document:
- ~Assert: この~algoは、[ %文書 に`関連な~agent$の`~event~loop$aGに~queueされた`~task$ ]の一部として走っている。 ◎ Assert: this is running as part of a task queued on document's relevant agent's event loop.
- %子孫~navigable群 ~LET %文書 の`子孫~navigable群$ ◎ Let descendantNavigables be document's descendant navigables.
-
%子孫~navigable群 を成す ~EACH( %子孫~navigable ) に対し 順序は どうする? ⇒ `大域~taskを~queueする$( `~naviと辿り~task~source$, %子孫~navigable にて`作動中な~window$nav, 次の手続き ) ◎ For each descendantNavigable of descendantNavigables in what order?, queue a global task on the navigation and traversal task source given descendantNavigable's active window to perform\
手続きは: ◎ the following steps:
- `文書を中止する$( %子孫~navigable にて`作動中な文書$nav ) ◎ Abort descendantNavigable's active document.
- ~IF[ %子孫~navigable にて`作動中な文書$navの`回復可能か$doc ~EQ ~F ] ⇒ %文書 の`回復可能か$doc ~SET ~F ◎ If descendantNavigable's active document's salvageable is false, then set document's salvageable to false.
- `文書を中止する$( %文書 ) ◎ Abort document.
`読込ngを停止する@ ときは、 所与の ( `~navigable$ %~navigable ) に対し: ◎ To stop loading a navigable navigable:
- %文書 ~LET %~navigable にて`作動中な文書$nav ◎ Let document be navigable's active document.
-
~IF[ %文書 の`~unload~counter$ ~EQ 0 ]~AND[ %~navigable の`進行中な~navi$ ~EQ `~navi~ID$ ] ⇒ `進行中な~naviを設定する$( %~navigable, ~NULL ) ◎ If document's unload counter is 0, and navigable's ongoing navigation is a navigation ID, then set the ongoing navigation for navigable to null.
注記: これには %~navigable にて進行中な~naviがあれば,それを中止する効果がある — `進行中な~navi$に対する変更は、 ~naviの間ある種の箇所で,更なる作業を放棄させることになるので。 ◎ This will have the effect of aborting any ongoing navigations of navigable, since at certain points during navigation, changes to the ongoing navigation will cause further work to be abandoned.
- `文書とその子孫たちを中止する$( %文書 ) ◎ Abort a document and its descendants given document.
~UAは、 自身の`~UI@#nav-traversal-ui$を通して, 辿りを停止することも許容する — すなわち、[ `進行中な~navi$ ~EQ `traversal^l ]の事例で。 上の~algoは、 これを織り込んでいない (他方、 ~UAは, `window.stop()@~WINDOW#dom-window-stop$c により辿りを停止することは許容しないので、 上の~algoは,その~call元~用には正しくなる)。 `課題 #6905@~HTMLissue/6905$ を見よ。 ◎ Through their user interface, user agents also allow stopping traversals, i.e. cases where the ongoing navigation is "traversal". The above algorithm does not account for this. (On the other hand, user agents do not allow window.stop() to stop traversals, so the above algorithm is correct for that caller.) See issue #6905.
7.6. `X-Frame-Options^h ~header
`X-Frame-Options@h ~HTTP応答~headerは、[ `文書$は`子~navigable$の内側に どう読込まれてもよいか ]を制御する,旧来の仕方である。 それは、[ 同じ状況に対し,もっと細やかな制御を供する `frame-ancestors$dir ~CSP指令 `CSP$r ]により,廃用にされた。 それは、 元々は `HTTP Header Field X-Frame-Options^cite `RFC7034$r にて定義されたが,ここでの定義と処理~modelは、 その文書に取って代わる。 ◎ The `X-Frame-Options` HTTP response header is a legacy way of controlling whether and how a Document may be loaded inside of a child navigable. It is obsoleted by the frame-ancestors CSP directive, which provides more granular control over the same situations. It was originally defined in HTTP Header Field X-Frame-Options, but the definition and processing model here supersedes that document. [CSP] [RFC7034]
注記: 特に, `HTTP Header Field X-Frame-Options^cite は、 その~header値~用の変種として `ALLOW-FROM^bl も指定したが, それは実装されていない。 ◎ In particular, HTTP Header Field X-Frame-Options specified an `ALLOW-FROM` variant of the header, but that is not to be implemented.
注記: 下に与える処理~modelにより、 `X-Frame-Options$h ~headerは,同じ`応答$内に ~CSP `frame-ancestors$dir 指令も利用された場合には無視される。 ◎ Per the below processing model, if both a CSP frame-ancestors directive and an `X-Frame-Options` header are used in the same response, then `X-Frame-Options` is ignored.
[ ~web開発者/適合性~検査器 ]向けとして,その値の`~ABNF$は: ◎ For web developers and conformance checkers, its value ABNF is:
X-Frame-Options = "DENY" / "SAMEORIGIN"
`~navi応答の~X-Frame-Optionsに対する固守を検査する@ ときは、 所与の ( `応答$ %応答, `~navigable$ %~navigable, `~CSP~list$ %~CSP~list, `生成元$ %行先~生成元 ) に対し: ◎ To check a navigation response's adherence to `X-Frame-Options`, given a response response, a navigable navigable, a CSP list cspList, and an origin destinationOrigin:
- ~IF[ %~navigable は`子~navigable$でない ] ⇒ ~RET ~T ◎ If navigable is not a child navigable, then return true.
-
%~CSP~list を成す ~EACH( %施策 ) に対し: ◎ For each policy of cspList:
- ~IF[ %施策 の`処置先$ ~NEQ `enforce^l ] ⇒ ~CONTINUE ◎ If policy's disposition is not "enforce", then continue.
- ~IF[ `frame-ancestors$dir 指令 ~IN %施策 の`指令~集合$ ] ⇒ ~RET ~T ◎ If policy's directive set contains a frame-ancestors directive, then return true.
- %~X-Frame-Options ~LET `~header~listから値を取得して復号して分割する$( %応答 の`~header~list$rs, `X-Frame-Options$h ) ◎ Let rawXFrameOptions be the result of getting, decoding, and splitting `X-Frame-Options` from response's header list.
-
~IF[ %~X-Frame-Options ~EQ ~NULL ] ⇒ ~RET ~T
【 この段は、 この訳による補完 (応答~内に `X-Frame-Options$h は無い)。 】
- %~frame~option群 ~LET 新たな`集合$ ◎ Let xFrameOptions be a new set.
- %~X-Frame-Options を成す ~EACH( %値 ) に対し ⇒ %~frame~option群 に次の結果を`付加する$set ⇒ `~ASCII小文字~化する$( %値 ) ◎ For each value of rawXFrameOptions, append value, converted to ASCII lowercase, to xFrameOptions.
-
~IF[ %~frame~option群 の`~size$ ~GT 1 ]: ◎ ↓
-
%~frame~option群 を成す ~EACH( %値 ) に対し ⇒ ~IF[ %値 ~IN { `deny^l, `allowall^l, `sameorigin^l } ] ⇒ ~RET ~F ◎ If xFrameOptions's size is greater than 1, and xFrameOptions contains any of "deny", "allowall", or "sameorigin", then return false.
注記: ここでの意図nは、 `X-Frame-Options$h が[ 妥当な何かを行おうと試行しているが,紛らわしく現れる ]場合には,それを適用する際に 【埋込もうとする】どの試みも阻止することにある。 ◎ The intention here is to block any attempts at applying `X-Frame-Options` which were trying to do something valid, but appear confused.
注記: 旧来の `ALLOWALL^bl 値による処理~modelに対する影響iは、 ここに限られる。 ◎ This is the only impact of the legacy `ALLOWALL` value on the processing model.
-
~RET ~T ◎ If xFrameOptions's size is greater than 1, then return true.
注記: ~headerは、 複数個の妥当でない値を包含している — この場合、 ~headerが まるごと省略されていたときと同じ仕方で扱う。 ◎ This means it contains multiple invalid values, which we treat the same way as if the header was omitted entirely.
-
- ~IF[ %~frame~option群[ 0 ] ~EQ `deny^l ] ⇒ ~RET ~F ◎ If xFrameOptions[0] is "deny", then return false.
-
~IF[ %~frame~option群[ 0 ] ~EQ `sameorigin^bl ]: ◎ If xFrameOptions[0] is "sameorigin", then:
- %容器~文書 ~LET %~navigable の`容器~文書$nav ◎ Let containerDocument be navigable's container document.
-
~WHILE[ %容器~文書 ~NEQ ~NULL ]: ◎ While containerDocument is not null:
- ~IF[ ( %容器~文書 の`生成元$doc, %行先~生成元 ) は`同一-生成元$でない ] ⇒ ~RET ~F ◎ If containerDocument's origin is not same origin with destinationOrigin, then return false.
- %容器~文書 ~SET %容器~文書 の`容器~文書$doc ◎ Set containerDocument to containerDocument's container document.
-
~RET ~T ◎ Return true.
注記: ここまで達した場合、 妥当でない 1 個の値からなる(旧来の[ `ALLOWALL^bl / `ALLOW-FROM^bl ]形も該当する) — この場合、 ~headerは まるごと省略されていたかのように扱う。 ◎ If we've reached this point then we have a lone invalid value (which could potentially be one the legacy `ALLOWALL` or `ALLOW-FROM` forms). These are treated as if the header were omitted entirely.
この~header用の様々な値の処理を — 不適合tなものも含め — 次の表tに示す: ◎ The following table illustrates the processing of various values for the header, including non-conformant ones:
`X-Frame-Options$h | 妥当か? | 結果 |
---|---|---|
`DENY^bl | ✅ | 埋込みは許容されない |
`SAMEORIGIN^bl | ✅ | 同一-生成元なら埋込みは許容される |
`INVALID^bl | ❌ | 埋込みは許容される |
`ALLOWALL^bl | ❌ | 埋込みは許容される |
`ALLOW-FROM=https://example.com/^bl | ❌ | 埋込みは許容される(どこからでも) |
複数の値を孕んでいる,様々な不適合tな事例がどう処理されるかを,次の表tに示す: ◎ The following table illustrates how various non-conformant cases involving multiple values are processed:
`X-Frame-Options$h | 結果 |
---|---|
`SAMEORIGIN, SAMEORIGIN^bl | 同一-生成元なら埋込みは許容される |
`SAMEORIGIN, DENY^bl | 埋込みは許容されない |
`SAMEORIGIN,^bl | 埋込みは許容されない |
`SAMEORIGIN, ALLOWALL^bl | 埋込みは許容されない |
`SAMEORIGIN, INVALID^bl | 埋込みは許容されない |
`ALLOWALL, INVALID^bl | 埋込みは許容されない |
`ALLOWALL,^bl | 埋込みは許容されない |
`INVALID, INVALID^bl | 埋込みは許容される |
値たちが[ ~commaで区切られた値を伴う 1 個の~header, 複数個の~header ]どちらで送達されようが,得される結果は同じになる。 ◎ The same results are obtained whether the values are delivered in a single header whose value is comma-delimited, or in multiple headers.
7.7. `Refresh$h ~header
`Refresh@h ~HTTP応答~headerは、[ `meta$e 要素のうち,その `http-equiv$a 属性は `~refresh$st 状態にあるもの ]を~HTTPにおいて等価に~~表現するものである。 それは, `同じ値@~HEmetadata#conformance-attr-meta-http-equiv-refresh$をとり,ほとんど同じに働く。 その処理~modelの詳細は、 `文書を作成して初期化する$にて与えられる。 ◎ The `Refresh` HTTP response header is the HTTP-equivalent to a meta element with an http-equiv attribute in the Refresh state. It takes the same value and works largely the same. Its processing model is detailed in create and initialize a Document object.