aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--files/ru/web/api/url/url/index.html75
-rw-r--r--files/ru/web/api/url/url/index.md81
2 files changed, 81 insertions, 75 deletions
diff --git a/files/ru/web/api/url/url/index.html b/files/ru/web/api/url/url/index.html
deleted file mode 100644
index 7c8566b7d0..0000000000
--- a/files/ru/web/api/url/url/index.html
+++ /dev/null
@@ -1,75 +0,0 @@
----
-title: URL()
-slug: Web/API/URL/URL
-translation_of: Web/API/URL/URL
----
-<p>{{SeeCompatTable}}{{APIRef("URL API")}}</p>
-
-<p>Конструктор <code><strong>URL()</strong></code> возвращает вновь созданный  {{domxref("URL")}} объект отражающий URL определяемый параметрами.</p>
-
-<p>If the given base URL or the resulting URL are not valid URLs, a {{domxref("DOMException")}} of type <code>SYNTAX_ERROR</code> is thrown.</p>
-
-<p>{{AvailableInWorkers}}</p>
-
-<h2 id="Синтаксис">Синтаксис</h2>
-
-<pre class="syntaxbox"><em>url</em> = new URL(<em>urlString</em>, [<em>baseURLstring</em>])
-<em>url</em> = new URL(<em>urlString</em>, <em>baseURLobject</em>)
-</pre>
-
-<h3 id="Параметры">Параметры</h3>
-
-<dl>
- <dt><em>urlString</em></dt>
- <dd>Is a {{domxref("DOMString")}} representing an absolute or relative URL. If <em>urlString</em> is a relative URL, <em>baseURLstring</em> or <em>baseURLobject</em>, whichever is present, will be used as the base URL. If <em>urlString</em> is an absolute URL, <em>baseURLstring</em> and <em>baseURLobject</em> are ignored.</dd>
- <dt><em>baseURLstring </em>{{optional_inline}}</dt>
- <dd>Is a {{domxref("DOMString")}} representing the base URL to use in case <em>urlString</em> is a relative URL. If not specified, and no <em>baseURLobject</em> is passed in parameters, it default to <code>'about:blank'</code>. If it is an invalid absolute URL, the constructor will raise a {{domxref("DOMException")}} of type <code>SYNTAX_ERROR</code></dd>
- <dt><em>baseURLobject</em></dt>
- <dd>Is a {{domxref("URL")}} object representing the base URL to use in case <em>urlString</em> is a relative URL.</dd>
-</dl>
-
-<h2 id="Примеры">Примеры</h2>
-
-<pre class="brush: js language-js">var a = new URL("/", "https://developer.mozilla.org"); // Creates a URL pointing to 'https://developer.mozilla.org/'
-var b = new URL("https://developer.mozilla.org"); // Creates a URL pointing to 'https://developer.mozilla.org/'
-var c = new URL('en-US/docs', b); // Creates a URL pointing to 'https://developer.mozilla.org/en-US/docs'
-var d = new URL('/en-US/docs', b); // Creates a URL pointing to 'https://developer.mozilla.org/en-US/docs'
-var f = new URL('/en-US/docs', d); // Creates a URL pointing to 'https://developer.mozilla.org/en-US/docs'
-var g = new URL('/en-US/docs', "https://developer.mozilla.org/fr-FR/toto");
- // Creates a URL pointing to 'https://developer.mozilla.org/en-US/docs'
-var h = new URL('/en-US/docs', a); // Creates a URL pointing to 'https://developer.mozilla.org/en-US/docs'
-var i = new URL('/en-US/docs', ''); // Raises a SYNTAX ERROR exception as '/en-US/docs' is not valid
-var j = new URL('/en-US/docs'); // Raises a SYNTAX ERROR exception as 'about:blank/en-US/docs' is not valid
-var k = new URL('http://www.example.com', 'https://developers.mozilla.com');
- // Creates a URL pointing to 'http://www.example.com/'
-var l = new URL('http://www.example.com', b); // Creates a URL pointing to 'http://www.example.com/'
-</pre>
-
-<h2 id="Specification" name="Specification">Спецификация</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('URL', '#constructors', 'URL.URL()')}}</td>
- <td>{{Spec2('URL')}}</td>
- <td>Initial definition.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Поддержка_браузерами">Поддержка браузерами</h2>
-
-<p>{{Compat("api.URL.URL")}}</p>
-
-<h2 id="Смотрите_также">Смотрите также</h2>
-
-<ul>
- <li>The interface it belongs to: {{domxref("URL")}}.</li>
-</ul>
-
-<p> </p>
diff --git a/files/ru/web/api/url/url/index.md b/files/ru/web/api/url/url/index.md
new file mode 100644
index 0000000000..8deeb1eed8
--- /dev/null
+++ b/files/ru/web/api/url/url/index.md
@@ -0,0 +1,81 @@
+---
+title: URL()
+slug: Web/API/URL/URL
+tags:
+ - API
+ - Constructor
+ - Reference
+ - URL
+ - URL API
+translation_of: Web/API/URL/URL
+---
+{{APIRef("URL API")}}
+
+Конструктор **`URL()`** возвращает вновь созданный  {{domxref("URL")}} объект, отражающий URL, определяемый параметрами.
+
+Если предоставленный базовый URL-адрес или итоговый URL-адрес не является валидным, то будет сгенерировано JavaScript исключение {{jsxref("TypeError")}}.
+
+{{AvailableInWorkers}}
+
+## Синтаксис
+
+```js
+const url = new URL(url [, base])
+```
+
+### Параметры
+
+- `url`
+ - : Строка типа {{domxref("USVString")}} или любой объект, который может быть [преобразован в строку](/en-US/docs/MDN/Contribute/Howto/Write_an_API_reference/Information_contained_in_a_WebIDL_file#stringifiers), включая, например, элементы {{htmlelement("a")}} и {{htmlelement("area")}}, представляющие абсолютный и относительный URL-адрес соответственно. Если `url` это относительный URL-адрес, то параметр `base` становится обязательным, так как он будет использован в качестве базового URL-адреса. Если же `url` — абсолютный URL-адрес, то значение параметра `base` будет проигнорировано.
+- `base` {{optional_inline}}
+ - : Строка типа {{domxref("USVString")}}. Используется в качестве базового адреса, когда `url` это относительный URL-адрес. Значение по умолчанию: `undefined`.
+
+> **Примечание:** Как и в случае с любым другим Web API,
+> которое принимает на вход строку типа {{domxref("USVString")}},
+> аргументы <code>url</code> и <code>base</code> будут преобразованы в строку
+> независимо от исходного типа переданного значения.
+> В частности, вы можете использовать существующий {{domxref("URL")}} объект в качестве аргумента
+> и он будет преобразован в строку значение которой равно значению свойства
+> {{domxref("URL.href", "href")}} переданного объекта.
+
+### Исключения
+
+| Исключение | Объяснение |
+| -------------------------------- | --------------------------------------------------------------------------------------------------------- |
+| {{jsxref("TypeError")}} | `url` (в случае с абсолютным URL-адресом) или `base` + `url` (в случае с относительным URL-адресом) является невалидным URL-адресом. |
+
+## Примеры
+
+```js
+// Базовые URL-адреса
+let m = 'https://developer.mozilla.org';
+let a = new URL("/", m); // => 'https://developer.mozilla.org/'
+let b = new URL(m); // => 'https://developer.mozilla.org/'
+
+ new URL('en-US/docs', b); // => 'https://developer.mozilla.org/en-US/docs'
+let d = new URL('/en-US/docs', b); // => 'https://developer.mozilla.org/en-US/docs'
+ new URL('/en-US/docs', d); // => 'https://developer.mozilla.org/en-US/docs'
+ new URL('/en-US/docs', a); // => 'https://developer.mozilla.org/en-US/docs'
+
+ new URL('/en-US/docs', "https://developer.mozilla.org/fr-FR/toto");
+ // => 'https://developer.mozilla.org/en-US/docs'
+
+ new URL('/en-US/docs', ''); // Генерирует TypeError исключение так как '' не является валидным URL-адресом
+ new URL('/en-US/docs'); // Генерирует TypeError исключение так как '/en-US/docs' не является валидным URL-адресом
+ new URL('http://www.example.com', ); // => 'http://www.example.com/'
+ new URL('http://www.example.com', b); // => 'http://www.example.com/'
+
+ new URL("//foo.com", "https://example.com") // => 'https://foo.com' (см. относительные URL-адреса)
+```
+
+## Спецификации
+
+{{Specifications}}
+
+## Поддержка браузерами
+
+{{Compat}}
+
+## Смотрите также
+- Полифил для `URL` доступен в [core-js](https://github.com/zloirock/core-js#url-and-urlsearchparams)
+- Этот интерфейс принадлежит: {{domxref("URL")}}.