aboutsummaryrefslogtreecommitdiff
path: root/files/fr/web/api/history_api/example
diff options
context:
space:
mode:
authorSphinxKnight <SphinxKnight@users.noreply.github.com>2022-03-16 17:52:18 +0100
committerGitHub <noreply@github.com>2022-03-16 17:52:18 +0100
commit500f444d23a7a758da229ebe6b9691cc5d4fe731 (patch)
treeca277561f7f3c5f2c9c3e80a895ac32f30852238 /files/fr/web/api/history_api/example
parentde831e4687986c3a60b9ced69ce9faefda8df4b9 (diff)
downloadtranslated-content-500f444d23a7a758da229ebe6b9691cc5d4fe731.tar.gz
translated-content-500f444d23a7a758da229ebe6b9691cc5d4fe731.tar.bz2
translated-content-500f444d23a7a758da229ebe6b9691cc5d4fe731.zip
Fix #4269 - Removes empty/special characters (#4270)
* Remove ufeff * Remove u2064 * Remove u2062 * Replace u202f followed by : with &nbsp;: * Replace u202f next to « or » with &nbsp; and « or » * Replace u202f followed by ; with &nbsp;; * Replace u202f followed by ! with &nbsp; * Replace u202f followed by ? with &nbsp;? * Replace remaining u202f with classical space * Replace u200b surrounded by space with classical space * Replace u200b surrounded by space with classical space - again (repeated) * Remove remaining u200b * Remove u200a * Replace u2009 with &nbsp; * Remove u00ad * Replace u00a0 followed by : ! or ? with &nbsp; and punctuation * Replace u00a0 surrounded « or » with &nbsp; and punctuation * Replace u00a0 followed by whitespaces * Replace u00a0 preceded by whitespaces * Replace u00a0 followed by a newline with a newline * Replace u00a0 followed by a newline with a newline - Take2 * Replace u00a0 followed by a ; &nbsp; and punctuation * Remove u00a0 followed by , * Remove u00a0 in indentation spaces with \n([ ]*)([\u00a0])([ ]*) * Manual replacement of ([\u00a0])([ ]+) * Replace remaining ([\u00a0]+) by a space * cleaning empty elements * remove ufe0f * Remove u00a0 and u202f after merging against updated main * remove double whitespace using (\w)( )(\w)
Diffstat (limited to 'files/fr/web/api/history_api/example')
-rw-r--r--files/fr/web/api/history_api/example/index.md516
1 files changed, 258 insertions, 258 deletions
diff --git a/files/fr/web/api/history_api/example/index.md b/files/fr/web/api/history_api/example/index.md
index a218dcba37..a9473b7582 100644
--- a/files/fr/web/api/history_api/example/index.md
+++ b/files/fr/web/api/history_api/example/index.md
@@ -4,26 +4,26 @@ slug: Web/API/History_API/Example
translation_of: Web/API/History_API/Example
original_slug: Web/Guide/DOM/Manipuler_historique_du_navigateur/Example
---
-Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.php_, *page_deux.php* et *page_trois.php*). Pour tester cet exemple, merci de créer les fichiers suivants :
+Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.php_, *page_deux.php* et *page_trois.php*). Pour tester cet exemple, merci de créer les fichiers suivants :
**page_un.php**:
```php
<?php
-    $page_title = "Page un";
-
-    $as_json = false;
-    if (isset($_GET["view_as"]) && $_GET["view_as"] == "json") {
-        $as_json = true;
-        ob_start();
-    } else {
+ $page_title = "Page un";
+
+ $as_json = false;
+ if (isset($_GET["vie
+ $as_json =
+ ob_start();
+ } else {
?>
<!doctype html>
<html>
<head>
<?php
-        include "include/header.php";
-        echo "<title>" . $page_title . "</title>";
+ include "include/header.php";
+ echo "<title>" . $page_title . "</title>";
?>
</head>
@@ -36,21 +36,21 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
<div id="ajax-content">
<?php } ?>
-    <p>This is the content of <strong>first_page.php</strong>.</p>
+ <p>This is the content of <strong>first_page.php</strong>.</p>
<?php
-    if ($as_json) {
-        echo json_encode(array("page" => $page_title, "content" => ob_get_clean()));
-    } else {
+ if ($as_json) {
+ echo json_encode(array("page" => $page_title, "content" => ob_get_clean()));
+ } else {
?>
</div>
<p>This paragraph is shown only when the navigation starts from <strong>first_page.php</strong>.</p>
<?php
-        include "include/after_content.php";
-        echo "</body>\n</html>";
-    }
+ include "include/after_content.php";
+ echo "</body>\n</html>";
+ }
?>
```
@@ -58,20 +58,20 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
```php
<?php
-    $page_title = "Page deux";
-
-    $as_json = false;
-    if (isset($_GET["view_as"]) && $_GET["view_as"] == "json") {
-        $as_json = true;
-        ob_start();
-    } else {
+ $page_title = "Page deux";
+
+ $as_json = false;
+ if (isset($_GET["vie
+ $as_json =
+ ob_start();
+ } else {
?>
<!doctype html>
<html>
<head>
<?php
-        include "include/header.php";
-        echo "<title>" . $page_title . "</title>";
+ include "include/header.php";
+ echo "<title>" . $page_title . "</title>";
?>
</head>
@@ -84,21 +84,21 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
<div id="ajax-content">
<?php } ?>
-    <p>This is the content of <strong>second_page.php</strong>.</p>
+ <p>This is the content of <strong>second_page.php</strong>.</p>
<?php
-    if ($as_json) {
-        echo json_encode(array("page" => $page_title, "content" => ob_get_clean()));
-    } else {
+ if ($as_json) {
+ echo json_encode(array("page" => $page_title, "content" => ob_get_clean()));
+ } else {
?>
</div>
<p>This paragraph is shown only when the navigation starts from <strong>second_page.php</strong>.</p>
<?php
-        include "include/after_content.php";
-        echo "</body>\n</html>";
-    }
+ include "include/after_content.php";
+ echo "</body>\n</html>";
+ }
?>
```
@@ -106,19 +106,19 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
```php
<?php
-    $page_title = "Page trois";
-    $page_content = "<p>Ceci est le contenu de la <strong>page_trois.php</strong>. Ce contenu est stocké dans une variable PHP.</p>";
-
-    if (isset($_GET["view_as"]) && $_GET["view_as"] == "json") {
-        echo json_encode(array("page" => $page_title, "content" => $page_content));
-    } else {
+ $page_title = "Page trois";
+ $page_content = "<p>Ceci est le contenu de la <strong>page_trois.php</strong>. Ce contenu est stocké dans une variable PHP.</p>";
+
+ if (isset($_GET["view_as"]) && $_GET["view_as"] == "json") {
+ echo json_encode(array("page" => $page_title, "content" => $page_content));
+ } else {
?>
<!doctype html>
<html>
<head>
<?php
-        include "include/header.php";
-        echo "<title>" . $page_title . "</title>";
+ include "include/header.php";
+ echo "<title>" . $page_title . "</title>";
?>
</head>
@@ -135,9 +135,9 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
<p>This paragraph is shown only when the navigation starts from <strong>third_page.php</strong>.</p>
<?php
-        include "include/after_content.php";
-        echo "</body>\n</html>";
-    }
+ include "include/after_content.php";
+ echo "</body>\n</html>";
+ }
?>
```
@@ -145,22 +145,22 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
```css
#ajax-loader {
-    position: fixed;
-    display: table;
-    top: 0;
-    left: 0;
-    width: 100%;
-    height: 100%;
+ position: fixed;
+ display: table;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
}
#ajax-loader > div {
-    display: table-cell;
-    width: 100%;
-    height: 100%;
-    vertical-align: middle;
-    text-align: center;
-    background-color: #000000;
-    opacity: 0.65;
+ display: table-cell;
+ width: 100%;
+ height: 100%;
+ vertical-align: middle;
+ text-align: center;
+ background-color: #000000;
+ opacity: 0.65;
}
```
@@ -196,212 +196,212 @@ Voici un exemple de site web AJAX composé uniquement de trois pages (_page_un.p
var ajaxRequest = new (function () {
-    function closeReq () {
-        oLoadingBox.parentNode && document.body.removeChild(oLoadingBox);
-        bIsLoading = false;
-    }
-
-    function abortReq () {
-        if (!bIsLoading) { return; }
-        oReq.abort();
-        closeReq();
-    }
-
-    function ajaxError () {
-        alert("Unknown error.");
-    }
-
-    function ajaxLoad () {
-        var vMsg, nStatus = this.status;
-        switch (nStatus) {
-            case 200:
-                vMsg = JSON.parse(this.responseText);
-                document.title = oPageInfo.title = vMsg.page;
-                document.getElementById(sTargetId).innerHTML = vMsg.content;
-                if (bUpdateURL) {
-                    history.pushState(oPageInfo, oPageInfo.title, oPageInfo.url);
-                    bUpdateURL = false;
-                }
-                break;
-            default:
-                vMsg = nStatus + ": " + (oHTTPStatus[nStatus] || "Unknown");
-                switch (Math.floor(nStatus / 100)) {
-                    /*
-                    case 1:
-                        // Informational 1xx
-                        console.log("Information code " + vMsg);
-                        break;
-                    case 2:
-                        // Successful 2xx
-                        console.log("Successful code " + vMsg);
-                        break;
-                    case 3:
-                        // Redirection 3xx
-                        console.log("Redirection code " + vMsg);
-                        break;
-                    */
-                    case 4:
-                        /* Client Error 4xx */
-                        alert("Client Error #" + vMsg);
-                        break;
-                    case 5:
-                        /* Server Error 5xx */
-                        alert("Server Error #" + vMsg);
-                        break;
-                    default:
-                        /* Unknown status */
-                        ajaxError();
-                }
-        }
-        closeReq();
-    }
-
-    function filterURL (sURL, sViewMode) {
-        return sURL.replace(rSearch, "") + ("?" + sURL.replace(rHost, "&").replace(rView, sViewMode ? "&" + sViewKey + "=" + sViewMode : "").slice(1)).replace(rEndQstMark, "");
-    }
-
-    function getPage (sPage) {
-        if (bIsLoading) { return; }
-        oReq = new XMLHttpRequest();
-        bIsLoading = true;
-        oReq.onload = ajaxLoad;
-        oReq.onerror = ajaxError;
-        if (sPage) { oPageInfo.url = filterURL(sPage, null); }
-        oReq.open("get", filterURL(oPageInfo.url, "json"), true);
-        oReq.send();
-        oLoadingBox.parentNode || document.body.appendChild(oLoadingBox);
-    }
-
-    function requestPage (sURL) {
-        if (history.pushState) {
-            bUpdateURL = true;
-            getPage(sURL);
-        } else {
-            /* Ajax navigation is not supported */
-            location.assign(sURL);
-        }
-    }
-
-    function processLink () {
-        if (this.className === sAjaxClass) {
-            requestPage(this.href);
-            return false;
-        }
-        return true;
-    }
-
-    function init () {
-        oPageInfo.title = document.title;
-        for (var oLink, nIdx = 0, nLen = document.links.length; nIdx < nLen; document.links[nIdx++].onclick = processLink);
-    }
-
-    const
-
-        /* customizable constants */
-        sTargetId = "ajax-content", sViewKey = "view_as", sAjaxClass = "ajax-nav",
-
-        /* not customizable constants */
-        rSearch = /\?.*$/, rHost = /^[^\?]*\?*&*/, rView = new RegExp("&" + sViewKey + "\\=[^&]*|&*$", "i"), rEndQstMark = /\?$/,
-        oLoadingBox = document.createElement("div"), oCover = document.createElement("div"), oLoadingImg = new Image(),
-        oPageInfo = {
-            title: null,
-            url: location.href
-        }, oHTTPStatus = /* http://www.iana.org/assignments/http-status-codes/http-status-codes.xml */ {
-            100: "Continue",
-            101: "Switching Protocols",
-            102: "Processing",
-            200: "OK",
-            201: "Created",
-            202: "Accepted",
-            203: "Non-Authoritative Information",
-            204: "No Content",
-            205: "Reset Content",
-            206: "Partial Content",
-            207: "Multi-Status",
-            208: "Already Reported",
-            226: "IM Used",
-            300: "Multiple Choices",
-            301: "Moved Permanently",
-            302: "Found",
-            303: "See Other",
-            304: "Not Modified",
-            305: "Use Proxy",
-            306: "Reserved",
-            307: "Temporary Redirect",
-            308: "Permanent Redirect",
-            400: "Bad Request",
-            401: "Unauthorized",
-            402: "Payment Required",
-            403: "Forbidden",
-            404: "Not Found",
-            405: "Method Not Allowed",
-            406: "Not Acceptable",
-            407: "Proxy Authentication Required",
-            408: "Request Timeout",
-            409: "Conflict",
-            410: "Gone",
-            411: "Length Required",
-            412: "Precondition Failed",
-            413: "Request Entity Too Large",
-            414: "Request-URI Too Long",
-            415: "Unsupported Media Type",
-            416: "Requested Range Not Satisfiable",
-            417: "Expectation Failed",
-            422: "Unprocessable Entity",
-            423: "Locked",
-            424: "Failed Dependency",
-            425: "Unassigned",
-            426: "Upgrade Required",
-            427: "Unassigned",
-            428: "Precondition Required",
-            429: "Too Many Requests",
-            430: "Unassigned",
-            431: "Request Header Fields Too Large",
-            500: "Internal Server Error",
-            501: "Not Implemented",
-            502: "Bad Gateway",
-            503: "Service Unavailable",
-            504: "Gateway Timeout",
-            505: "HTTP Version Not Supported",
-            506: "Variant Also Negotiates (Experimental)",
-            507: "Insufficient Storage",
-            508: "Loop Detected",
-            509: "Unassigned",
-            510: "Not Extended",
-            511: "Network Authentication Required"
-        };
-
-    var
-
-        oReq, bIsLoading = false, bUpdateURL = false;
-
-    oLoadingBox.id = "ajax-loader";
-    oCover.onclick = abortReq;
-    oLoadingImg.src = "";
-    oCover.appendChild(oLoadingImg);
-    oLoadingBox.appendChild(oCover);
-
-    onpopstate = function (oEvent) {
-        bUpdateURL = false;
-        oPageInfo.title = oEvent.state.title;
-        oPageInfo.url = oEvent.state.url;
-        getPage();
-    };
-
-    window.addEventListener ? addEventListener("load", init, false) : window.attachEvent ? attachEvent("onload", init) : (onload = init);
-
-    // Public methods
-
-    this.open = requestPage;
-    this.stop = abortReq;
-    this.rebuildLinks = init;
+ function closeReq () {
+ oLoadingBox.parentNode && document.body.removeChild(oLoadingBox);
+ bIsLoading = false;
+ }
+
+ function abortReq () {
+ if (!bIsLoadi
+ oReq.abort(
+
+ }
+
+ fu
+ alert("Unknown err
+ }
+
+ function ajaxLoad
+ var vMsg, nStatus = this.status;
+ switch (nStatus) {
+ case 200:
+ vMsg = JSON.parse
+ document.title = oPageInfo.title = vMsg.page;
+ document.getElementById
+ i
+ hi
+
+ }
+ break;
+ ult:
+ vMsg = nSta
+ switch
+ /*
+ case 1:
+ //
+ consol
+ bre
+ 2:
+ //
+ consol
+
+
+
+ con
+
+ */
+ case 4:
+ /*
+ alert(
+ bre
+ 5:
+ /* S
+ alert(
+ bre
+
+
+
+
+ }
+ closeReq();
+ }
+
+ function filterURL (sURL, sView
+ return sURL.replace(rSearch,
+ }
+
+ function getPage (sPage) {
+ if (bIsLoading) { return; }
+ oReq = new XMLHttpRequest();
+ bIsLoading =
+ oReq.onload = ajaxLoad;
+
+ if (sPage) { oPageInfo.ur
+ oReq.open("get", filterU
+ oReq.send();
+ oLoadingBox.parent
+ }
+
+ function requestPage (sURL) {
+ i
+
+ getPage(sURL);
+ se {
+ /* Ajax navigation is n
+ location.assi
+ }
+ }
+
+ function processLi
+ if (this.className === sAjaxClass
+ requestPage(this.href);
+
+ }
+ return true;
+ }
+
+ function init () {
+ oPageInfo.title = document.title;
+ for (var oLin
+ }
+
+ const
+
+ /* customizable constants */
+ sTargetId = "ajax-cont
+
+ /* not customizable
+ rSearch = /\?.*$/, r
+ oLoadingBox =
+ oPageInfo = {
+ title: null,
+ url: location.href
+ HTTPStatus = /*
+ 100: "Continue"
+ 101: "Swit
+ 102: "Proc
+ 200: "OK",
+ 201: "Created
+ 202: "Accepted",
+ 203: "Non-Author
+ 204: "No Content
+ 205: "Reset Cont
+ 206: "Partial Conte
+ 207: "Multi-Sta
+ 208: "Already R
+ 226: "IM Used",
+ 300: "Multipl
+ 301: "Moved P
+ 302: "Found",
+ 303: "See Other",
+ 304: "Not Modifi
+ 305: "Use Proxy"
+ 306: "Reserv
+ 307: "Tempor
+ 308: "Perman
+ 400: "Bad Request",
+ 401: "Unauthorize
+ 402: "Payment Req
+ 403: "Forbidden",
+ 404: "Not Found",
+ 405: "Method Not Allow
+ 406: "Not Acce
+ 407: "Proxy Au
+ 408: "Reques
+ 409: "Confli
+ 410: "Gone",
+ 411: "Length Requi
+ 412: "Precondition
+ 413: "Request Enti
+ 414: "Request-URI
+ 415: "Unsupported
+ 416: "Requested Range N
+ 417: "Expectat
+ 422: "Unproces
+ 423: "Locked",
+ 424: "Failed Depen
+ 425: "Unassigned",
+ 426: "Upgrade Requ
+ 427: "Unassigned",
+ 428: "Precondition
+ 429: "Too Many Req
+ 430: "Unassigned",
+ 431: "Request Header
+
+
+
+ 503: "Service Unavailab
+ 504: "Gateway Time
+ 505: "HTTP Version
+ 506: "Variant Also Negot
+ 507: "Insufficient St
+ 508: "Loop Detecte
+ 509: "Unassigne
+ 510: "Not Exten
+ 511: "Network Authentication Requ
+ };
+
+ var
+
+ oReq, bIsLoadi
+
+ oLoadingBox.id = "aja
+ oCover.onclick = abortReq;
+ oLoadingImg.src = "";
+ oCover.appendChild(oLoadingImg);
+ oLoadingBox.appendChild(oCover);
+
+ onpopstate = function (
+ bUpdateURL = false;
+ oPageInfo.title = oEvent.state.ti
+ oPageInfo.
+
+ };
+
+ window.addEventListener
+
+ // Public methods
+
+ this.open = requestPage;
+ this.stop = abortReq;
+ this.rebuildLinks = init;
})();
```
-> **Note :** [`const`](/en/JavaScript/Reference/Statements/const) (instruction de constante) **ne fait pas partie de ECMAScript 5**. Il est supporté dans Firefox et Chrome (V8) et partiellement supporté dans Opera 9+ et Safari. **Il n'est pas supporté dans Internet Explorer 6-9, ou dans la version de prévisualisation de Internet Explorer 10**. [`const`](/en/JavaScript/Reference/Statements/const) sera défini par ECMAScript 6, mais avec une sémantique différente. Proches des variables déclarées avec l'instruction [`let`](/en/JavaScript/Reference/Statements/let), les constantes déclarées avec [`const`](/en/JavaScript/Reference/Statements/const) seront limitées en portée. **Nous ne l'avons utilisé que pour des raisons pédagogiques, si vous souhaitez une compatibilité maximale de ce code, merci de remplacer les références à** **[`const`](/en/JavaScript/Reference/Statements/const) par des instructions [`var`](/en/JavaScript/Reference/Statements/var).**
+> **Note :** [`const`](/en/JavaScript/Reference/Statements/const) (instruction de constante) **ne fait pas partie de ECMAScript 5**. Il est supporté dans Firefox et Chrome (V8) et partiellement supporté dans Opera 9+ et Safari. **Il n'est pas supporté dans Internet Explorer 6-9, ou dans la version de prévisualisation de Internet Explorer 10**. [`const`](/en/JavaScript/Reference/Statements/const) sera défini par ECMAScript 6, mais avec une sémantique différente. Proches des variables déclarées avec l'instruction [`let`](/en/JavaScript/Reference/Statements/let), les constantes déclarées avec [`const`](/en/JavaScript/Reference/Statements/const) seront limitées en portée. **Nous ne l'avons utilisé que pour des raisons pédagogiques, si vous souhaitez une compatibilité maximale de ce code, merci de remplacer les références à** **[`const`](/en/JavaScript/Reference/Statements/const) par des instructions [`var`](/en/JavaScript/Reference/Statements/var).**
-Pour plus d'informations, voyez : [Manipuler l'historique du navigateur](/fr/docs/DOM/manipuler_lhistorique_du_navigateur).
+Pour plus d'informations, voyez : [Manipuler l'historique du navigateur](/fr/docs/DOM/manipuler_lhistorique_du_navigateur).
## Lire également