aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/css/media_queries
diff options
context:
space:
mode:
Diffstat (limited to 'files/zh-cn/web/css/media_queries')
-rw-r--r--files/zh-cn/web/css/media_queries/index.html109
-rw-r--r--files/zh-cn/web/css/media_queries/testing_media_queries/index.html90
-rw-r--r--files/zh-cn/web/css/media_queries/using_media_queries/index.html412
3 files changed, 611 insertions, 0 deletions
diff --git a/files/zh-cn/web/css/media_queries/index.html b/files/zh-cn/web/css/media_queries/index.html
new file mode 100644
index 0000000000..9936c531f1
--- /dev/null
+++ b/files/zh-cn/web/css/media_queries/index.html
@@ -0,0 +1,109 @@
+---
+title: 媒体查询
+slug: Web/CSS/媒体查询
+tags:
+ - CSS
+ - 参考
+ - 响应式设计
+ - 媒体查询
+ - 总览
+translation_of: Web/CSS/Media_Queries
+---
+<div>{{CSSRef}}</div>
+
+<p>通过<strong>媒体查询</strong>(<strong>Media queries</strong>),您可以根据各种设备特征和参数的值或者是否存在来调整您的网站或应用。</p>
+
+<p>它们是<a href="/zh-CN/docs/Web/Apps/Progressive/Responsive">响应式设计</a>的关键组成部分。 例如,媒体查询可以缩小小型设备上的字体大小,在纵向模式下查看页面时增加段落之间的填充,或者增加触摸屏上按钮的大小。</p>
+
+<p>在 CSS 中,使用 {{cssxref("@media")}} <a href="/zh-CN/docs/Web/CSS/At-rule">at-rule</a> 根据媒体查询的结果有条件地应用样式表的一部分。 使用 {{cssxref("@import")}} 有条件地应用整个样式表。</p>
+
+<h3 id="在_HTML_中使用媒体查询">在 HTML 中使用媒体查询</h3>
+
+<p>在 <a href="/zh-CN/docs/Web/HTML">HTML </a>中,媒体查询可以应用于各种元素:</p>
+
+<ul>
+ <li>在{{HTMLElement("link")}}元素的{{htmlattrxref("media", "link")}}属性中,它们定义了待应用链接资源(通常是CSS)的媒体。</li>
+ <li>在{{HTMLElement("source")}}元素的{{htmlattrxref("media", "source")}}属性中,它们定义待应用源的媒体。 (这仅在{{HTMLElement("picture")}}元素内有效。)</li>
+ <li>在{{HTMLElement("style")}}元素的{{htmlattrxref("media", "style")}}属性中,它们定义待应用样式的媒体。</li>
+</ul>
+
+<h3 id="在_JavaScript_中使用媒体查询">在 JavaScript 中使用媒体查询</h3>
+
+<p>在<a href="/zh-CN/docs/Web/JavaScript">JavaScript</a>中,您可以使用 {{domxref("Window.matchMedia()")}} 方法根据媒体查询测试窗口。 您还可以使用{{domxref("MediaQueryList.addListener()")}}在查询状态发生变化时收到通知。 借助此功能,您的站点或应用可以响应设备配置,方向或状态的更改。</p>
+
+<p>您可以学习更多以编程方式使用媒体查询在<a href="/zh-CN/docs/Web/CSS/Media_Queries/Testing_media_queries">测试媒体查询</a>中。</p>
+
+<h2 id="参考">参考</h2>
+
+<h3 id="At-rules">At-rules</h3>
+
+<div class="index">
+<ul>
+ <li>{{cssxref("@import")}}</li>
+ <li>{{cssxref("@media")}}</li>
+</ul>
+</div>
+
+<h2 id="指南">指南</h2>
+
+<dl>
+ <dt><a href="/zh-CN/docs/Web/CSS/Media_Queries/Using_media_queries">使用媒体查询</a></dt>
+ <dd>介绍媒体查询和媒体查询的的语法以及用于构造媒体查询表达式的运算符和媒体功能。</dd>
+ <dt><a href="/zh-CN/docs/Web/CSS/Media_Queries/Testing_media_queries">编程方式使用媒体查询</a></dt>
+ <dd>描述如何在 JavaScript 代码中使用媒体查询来确定设备的状态,以及设置在媒体查询结果发生更改时(例如,当用户旋转屏幕或调整浏览器大小时)通知代码的监听器。</dd>
+ <dt><a href="/zh-CN/docs/Web/CSS/Media_Queries/Using_Media_Queries_for_Accessibility">使用媒体查询增强网站的可访问性</a></dt>
+ <dd>了解媒体查询如何帮助用户更好地了解您的网站。</dd>
+</dl>
+
+<h2 id="规范">规范</h2>
+
+<table class="standard-table">
+ <thead>
+ <tr>
+ <th scope="col">规范</th>
+ <th scope="col">状态</th>
+ <th scope="col">备注</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{SpecName('CSS5 Media Queries')}}</td>
+ <td>{{Spec2('CSS5 Media Queries')}}</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{SpecName('CSS3 Conditional')}}</td>
+ <td>{{Spec2('CSS3 Conditional')}}</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{SpecName('CSS4 Media Queries')}}</td>
+ <td>{{Spec2('CSS4 Media Queries')}}</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{SpecName('CSS3 Media Queries')}}</td>
+ <td>{{Spec2('CSS3 Media Queries')}}</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{SpecName('CSS2.1', 'media.html')}}</td>
+ <td>{{Spec2('CSS2.1')}}</td>
+ <td>Initial definition</td>
+ </tr>
+ </tbody>
+</table>
+
+<h2 id="浏览器兼容性">浏览器兼容性</h2>
+
+<h3 id="media_rule">@media rule</h3>
+
+
+
+<p>{{Compat("css.at-rules.media")}}</p>
+
+<h2 id="参见">参见</h2>
+
+<ul>
+ <li>Use {{cssxref("@supports")}} to apply styles that depend on browser support for various CSS technologies.</li>
+</ul>
diff --git a/files/zh-cn/web/css/media_queries/testing_media_queries/index.html b/files/zh-cn/web/css/media_queries/testing_media_queries/index.html
new file mode 100644
index 0000000000..0d33436410
--- /dev/null
+++ b/files/zh-cn/web/css/media_queries/testing_media_queries/index.html
@@ -0,0 +1,90 @@
+---
+title: 使用编程方法测试媒体查询
+slug: Web/Guide/CSS/Testing_media_queries
+tags:
+ - CSS
+ - DOM
+ - Event
+ - Media Queries
+ - Web
+translation_of: Web/CSS/Media_Queries/Testing_media_queries
+---
+<div>{{cssref}}</div>
+
+<p>{{Glossary("DOM")}} 提供了通过编程方法来获得<a href="/zh-CN/docs/Web/CSS/Media_Queries">媒体查询</a>结果的特性。这是通过 {{domxref("MediaQueryList")}} 接口和它的方法来实现的。创建了 <code>MediaQueryList</code> 对象之后,就可以通过它来检查查询结果,或者设置事件监听器,在查询结果发生变化时自动接收到通知。</p>
+
+<h2 id="创建媒体查询列表">创建媒体查询列表</h2>
+
+<p>在获取查询结果前,首先要创建查询列表,也就是 <code>MediaQueryList</code> 对象来存放媒体查询。为了实现这个目的,可以使用 {{domxref("window.matchMedia")}} 方法。</p>
+
+<p>举个例子,设置一个用来判断设备的旋转方向(横屏还是竖屏)的查询列表:</p>
+
+<pre class="brush: js">var mediaQueryList = window.matchMedia("(orientation: portrait)");
+</pre>
+
+<h2 id="检查查询结果">检查查询结果</h2>
+
+<p>一旦创建了媒体查询列表,你就可以通过检查它的 <code>matches</code> 属性来获取相应的查询结果,上述属性会直接返回查询结果:</p>
+
+<pre class="brush: js">if (mediaQueryList.matches) {
+ /* 设备的旋转方向为纵向 portrait */
+} else {
+ /* 设备的旋转方向不是纵向,也就是横向 landscape */
+}
+</pre>
+
+<h2 id="接收查询提醒">接收查询提醒</h2>
+
+<p>如果你需要持续观察查询结果值的变化情况,那么,注册一个<a href="/zh-CN/docs/Web/API/EventTarget/addEventListener">监听器</a>比手动检查查询结果要高效很多。要注册监听器,只要在 {{domxref("MediaQueryList")}} 对象上使用 <code>addListener()</code> 方法,并使用一个回调函数作为其参数。这样,就通过实现 {{domxref("MediaQueryListListener")}} 接口指定了一个监听器。每当查询结果发生变化,比如从 <code>true</code> 变为 <code>false</code> 时,就会调用一遍传入的回调函数。</p>
+
+<pre class="brush: js">// 创建查询列表
+const mediaQueryList = window.matchMedia("(orientation: portrait)");
+
+// 定义回调函数
+function handleOrientationChange(mql) {
+ // ...
+}
+
+// 先运行一次回调函数
+handleOrientationChange(mediaQueryList);
+
+// 为查询列表注册监听器,同时将回调函数传给监听器
+mediaQueryList.addListener(handleOrientationChange);
+</pre>
+
+<p>上述代码创建了一个屏幕方向的测试查询列表 <code>mediaQueryList</code>,并且添加了事件监听器。需要注意的是,当我们添加监听后,我们其实直接调用了一次监听。这会让我们的监听器以目前设备的屏幕方向来初始化判定代码。换句话说,如果我们代码中设定设备处于竖屏模式,而实际上它在启动时处于横屏模式,那么我们在后面的判定就会出现矛盾。</p>
+
+<p>然后,我们就能在 <code>handleOrientationChange()</code> 方法中检查查询结果,比如,可以设置屏幕方向变化后的逻辑处理代码:</p>
+
+<pre class="brush: js">function handleOrientationChange(evt) {
+ if (evt.matches) {
+ /* The viewport is currently in portrait orientation */
+ } else {
+ /* The viewport is currently in landscape orientation */
+ }
+}
+</pre>
+
+<h2 id="终止查询通知">终止查询通知</h2>
+
+<p>如果不再需要再接收媒体查询值变化的相关通知,那么,只要调用 <code>MediaQueryList</code> 的 <code>removeListener()</code> 方法,就可以方便地移除监听:</p>
+
+<pre class="brush: js">mediaQueryList.removeListener(handleOrientationChange);
+</pre>
+
+<h2 id="浏览器兼容性">浏览器兼容性</h2>
+
+<h3 id="MediaQueryList_接口"><code>MediaQueryList</code> 接口</h3>
+
+
+
+<p>{{Compat("api.MediaQueryList")}}</p>
+
+<h2 id="另见">另见</h2>
+
+<ul>
+ <li><a href="/zh-CN/docs/CSS/Media_queries">Media queries</a></li>
+ <li>{{domxref("window.matchMedia()") }}</li>
+ <li>{{domxref("MediaQueryList") }}</li>
+ <li>{{domxref("MediaQueryListListener") }}</li>
+</ul>
diff --git a/files/zh-cn/web/css/media_queries/using_media_queries/index.html b/files/zh-cn/web/css/media_queries/using_media_queries/index.html
new file mode 100644
index 0000000000..bfb15efa67
--- /dev/null
+++ b/files/zh-cn/web/css/media_queries/using_media_queries/index.html
@@ -0,0 +1,412 @@
+---
+title: 使用媒体查询
+slug: Web/Guide/CSS/Media_queries
+tags:
+ - CSS
+ - CSS媒体查询
+ - Media
+ - Web
+ - 媒体
+ - 媒体查询
+ - 指南
+translation_of: Web/CSS/Media_Queries/Using_media_queries
+---
+<div>{{cssref}}</div>
+
+<p><strong>媒体查询</strong>(<strong>Media queries</strong>)非常实用,尤其是当你想要根据设备的大致类型(如打印设备与带屏幕的设备)或者特定的特征和设备参数(例如屏幕分辨率和浏览器{{glossary("viewport", "视窗")}}宽度)来修改网站或应用程序时。</p>
+
+<p>媒体查询常被用于以下目的:</p>
+
+<ul>
+ <li>有条件的通过 {{cssxref("@media")}} 和 {{cssxref("@import")}} <a href="/zh-CN/docs/Web/CSS/At-rule">at-rules</a> 用<a href="/en-US/docs/Web/CSS">CSS</a> 装饰样式。</li>
+ <li>用<code>media=</code> 属性为{{HTMLElement("style")}}, {{HTMLElement("link")}}, {{HTMLElement("source")}}和其他<a href="/zh-CN/docs/Web/HTML">HTML</a>元素指定特定的媒体类型。如:</li>
+</ul>
+
+<pre><code>&lt;link rel="stylesheet" src="styles.css" media="screen" /&gt;
+&lt;link rel="stylesheet" src="styles.css" media="print" /&gt;</code>
+</pre>
+
+<ul>
+ <li>使用{{domxref("Window.matchMedia()")}} 和{{domxref("MediaQueryList.addListener()")}} 方法来<a href="https://developer.mozilla.org/en-US/docs/Web/CSS/Media_Queries/Testing_media_queries">测试和监控媒体状态</a>。</li>
+</ul>
+
+<div class="note">
+<p><strong>注意:</strong>本页的例子使用CSS <code>@media</code> 的方式来说明目的,但是对于所有类型的媒体查询,基本语法均相同。</p>
+</div>
+
+<h2 id="语法">语法</h2>
+
+<p>每条媒体查询语句都由一个可选的<em>媒体类型</em>和任意数量的<em>媒体特性</em>表达式构成。可以使用多种<em>逻辑操作符</em>合并多条媒体查询语句。媒体查询语句不区分大小写。</p>
+
+<p>当媒体类型(如果指定)与在其上显示文档的设备匹配并且所有媒体功能表达式都计算为true时,媒体查询将计算为true。 涉及未知媒体类型的查询始终为false。</p>
+
+<div class="note">
+<p><strong>注意:</strong> 即使媒体查询返回false,带有媒体查询附加到其{{HTMLElement("link")}}标记的样式表<a href="http://scottjehl.github.com/CSS-Download-Tests/">仍将下载</a>。 但是,除非查询结果变为true,否则其内容将不适用。</p>
+</div>
+
+<h3 id="媒体类型">媒体类型</h3>
+
+<p><em>媒体类型</em>(<em>Media types</em>)描述设备的一般类别。除非使用 <code>not</code> 或 <code>only</code> 逻辑操作符,媒体类型是可选的,并且会(隐式地)应用 <code>all</code> 类型。</p>
+
+<dl>
+ <dt><code id="all">all</code></dt>
+ <dd>适用于所有设备。</dd>
+ <dt><code id="print">print</code></dt>
+ <dd>适用于在打印预览模式下在屏幕上查看的分页材料和文档。 (有关特定于这些格式的格式问题的信息,请参阅<a href="/zh-CN/docs/Web/CSS/Paged_Media">分页媒体</a>。)</dd>
+ <dt><code id="screen">screen</code></dt>
+ <dd>主要用于屏幕。</dd>
+ <dt><code id="speech">speech</code></dt>
+ <dd>主要用于语音合成器。</dd>
+</dl>
+
+<div class="note"><strong>被废弃的媒体类型:</strong> CSS2.1 和  <a href="https://drafts.csswg.org/mediaqueries-3/#background">Media Queries 3</a> 定义了一些额外的媒体类型(<code>tty</code>, <code>tv</code>, <code>projection</code>, <code>handheld</code>, <code>braille</code>, <code>embossed</code>, 以及 <code>aural</code>),但是他们在<a href="http://dev.w3.org/csswg/mediaqueries/#media-types">Media Queries 4</a> 中已经被废弃,并且不应该被使用。<code>aural</code>类型被替换为具有相似效果的<code>speech</code>。</div>
+
+<h3 id="媒体特性">媒体特性</h3>
+
+<p><em>媒体特性</em>(<em>Media features</em>)描述了 {{glossary("user agent")}}、输出设备,或是浏览环境的具体特征。媒体特性表达式是完全可选的,它负责测试这些特性或特征是否存在、值为多少。每条媒体特性表达式都必须用括号括起来。</p>
+
+<table>
+ <thead>
+ <tr>
+ <th>名称</th>
+ <th>简介</th>
+ <th>备注</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>{{cssxref("@media/any-hover", "any-hover")}}</td>
+ <td>是否有任何可用的输入机制允许用户(将鼠标等)悬停在元素上?</td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/any-pointer", "any-pointer")}}</td>
+ <td>可用的输入机制中是否有任何指针设备,如果有,它的精度如何?</td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/aspect-ratio", "aspect-ratio")}}</td>
+ <td>视窗(viewport)的宽高比</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/color", "color")}}</td>
+ <td>输出设备每个像素的比特值,常见的有 8、16、32 位。如果设备不支持输出彩色,则该值为 0</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/color-gamut", "color-gamut")}}</td>
+ <td>用户代理和输出设备大致程度上支持的色域</td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/color-index", "color-index")}}</td>
+ <td>输出设备的颜色查询表(color lookup table)中的条目数量,如果设备不使用颜色查询表,则该值为 0</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/device-aspect-ratio", "device-aspect-ratio")}} {{obsolete_inline}}</td>
+ <td>输出设备的宽高比</td>
+ <td>已在 Media Queries Level 4 中被弃用。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/device-height", "device-height")}} {{obsolete_inline}}</td>
+ <td>输出设备渲染表面(如屏幕)的高度</td>
+ <td>已在 Media Queries Level 4 中被弃用。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/device-width", "device-width")}} {{obsolete_inline}}</td>
+ <td>输出设备渲染表面(如屏幕)的宽度</td>
+ <td>已在 Media Queries Level 4 中被弃用。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/display-mode", "display-mode")}}</td>
+ <td>
+ <p>应用程序的显示模式,如web app的manifest中的<a href="/zh-CN/docs/Web/Manifest#display"><code>display</code></a> 成员所指定</p>
+ </td>
+ <td>在 <a href="http://w3c.github.io/manifest/#the-display-mode-media-feature">Web App Manifest spec</a>被定义.</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/forced-colors", "forced-colors")}}</td>
+ <td>检测是user agent否限制调色板</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/grid", "grid")}}</td>
+ <td>输出设备使用网格屏幕还是点阵屏幕?</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/height", "height")}}</td>
+ <td>视窗(viewport)的高度</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/hover", "hover")}}</td>
+ <td>
+ <p>主要输入模式是否允许用户在元素上悬停</p>
+ </td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/inverted-colors", "inverted-colors")}}</td>
+ <td>user agent或者底层操作系统是否反转了颜色</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/light-level", "light-level")}}</td>
+ <td>环境光亮度</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/monochrome", "monochrome")}}</td>
+ <td>
+ <p>输出设备单色帧缓冲区中每个像素的位深度。如果设备并非黑白屏幕,则该值为 0</p>
+ </td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/orientation", "orientation")}}</td>
+ <td>视窗(viewport)的旋转方向</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/overflow-block", "overflow-block")}}</td>
+ <td>
+ <p>输出设备如何处理沿块轴溢出视窗(viewport)的内容</p>
+ </td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/overflow-inline", "overflow-inline")}}</td>
+ <td>
+ <p>沿内联轴溢出视窗(viewport)的内容是否可以滚动?</p>
+ </td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/pointer", "pointer")}}</td>
+ <td>
+ <p>主要输入机制是一个指针设备吗?如果是,它的精度如何?</p>
+ </td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/prefers-color-scheme", "prefers-color-scheme")}}</td>
+ <td>探测用户倾向于选择亮色还是暗色的配色方案</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/prefers-contrast", "prefers-contrast")}}</td>
+ <td>探测用户是否有向系统要求提高或降低相近颜色之间的对比度</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/prefers-reduced-motion", "prefers-reduced-motion")}}</td>
+ <td>用户是否希望页面上出现更少的动态效果</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/prefers-reduced-transparency", "prefers-reduced-transparency")}}</td>
+ <td>用户是否倾向于选择更低的透明度</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/resolution", "resolution")}}</td>
+ <td>输出设备的像素密度(分辨率)</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/scan", "scan")}}</td>
+ <td>输出设备的扫描过程(适用于电视等)</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/scripting", "scripting")}}</td>
+ <td>探测脚本(例如 JavaScript)是否可用</td>
+ <td>在 Media Queries Level 5 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/update-frequency", "update")}}</td>
+ <td>输出设备更新内容的渲染结果的频率</td>
+ <td>在 Media Queries Level 4 中被添加。</td>
+ </tr>
+ <tr>
+ <td>{{cssxref("@media/width", "width")}}</td>
+ <td>视窗(viewport)的宽度,包括纵向滚动条的宽度</td>
+ <td></td>
+ </tr>
+ </tbody>
+</table>
+
+<h3 id="逻辑操作符">逻辑操作符</h3>
+
+<p><em>逻辑操作符</em>(<em>logical operators</em>) <code>not</code>, <code>and</code>, 和 <code>only</code> 可用于联合构造复杂的媒体查询,您还可以通过用逗号分隔多个媒体查询,将它们组合为一个规则。</p>
+
+<h4 id="and"><code>and</code></h4>
+
+<p> <code>and</code> 操作符用于将多个媒体查询规则组合成单条媒体查询,当每个查询规则都为真时则该条媒体查询为真,它还用于将媒体功能与媒体类型结合在一起。</p>
+
+<h4 id="not"><code>not</code></h4>
+
+<p><code>not</code>运算符用于否定媒体查询,如果不满足这个条件则返回true,否则返回false。 如果出现在以逗号分隔的查询列表中,它将仅否定应用了该查询的特定查询。 如果使用not运算符,则还必须指定媒体类型。</p>
+
+<div class="note">
+<p><strong>注意:</strong>在Level 3中,<code>not</code>关键字不能用于否定单个媒体功能表达式,而只能用于否定整个媒体查询。</p>
+</div>
+
+<h4 id="only"><code>only</code></h4>
+
+<p><code>only</code>运算符仅在整个查询匹配时才用于应用样式,并且对于防止较早的浏览器应用所选样式很有用。 当不使用<code>only</code>时,旧版本的浏览器会将<code>screen and (max-width: 500px)</code>简单地解释为<code>screen</code>,忽略查询的其余部分,并将其样式应用于所有屏幕。 如果使用<code>only</code>运算符,则<em>还必须指定</em>媒体类型。</p>
+
+<h4 id="逗号"><code>,</code> (逗号)</h4>
+
+<p>逗号用于将多个媒体查询合并为一个规则。 逗号分隔列表中的每个查询都与其他查询分开处理。 因此,如果列表中的任何查询为true,则整个media语句均返回true。 换句话说,列表的行为类似于逻辑或<code>or</code>运算符。</p>
+
+<h2 id="定位媒体类型">定位媒体类型</h2>
+
+<p>媒体类型描述了给定设备的一般类别。 尽管通常在设计网站时会考虑屏幕,但您可能希望创建针对特殊设备(例如打印机或基于音频的屏幕阅读器)的样式。 例如,此CSS针对打印机:</p>
+
+<pre class="brush: css">@media print { ... }
+</pre>
+
+<p>您还可以定位多个设备。 例如,此<code>@media</code>规则使用两个媒体查询来同时定位屏幕和打印设备</p>
+
+<pre class="brush: css">@media screen, print { ... }
+</pre>
+
+<p>有关所有媒体类型的列表,请参见<a class="internal" href="#Media_types">Media types</a>。 由于它们仅以非常广泛的术语描述设备,因此只有少数几种可用。 要定位更具体的属性,请改用<em>媒体功能</em>。</p>
+
+<h2 id="定位媒体特性">定位媒体特性</h2>
+
+<p>媒体功能描述了给定的{{glossary("user agent")}}的输出设备或环境的特定特征。 例如,您可以将特定样式应用于宽屏显示器,使用鼠标的计算机,或应用于在弱光条件下使用的设备。 当用户的主要输入机制(例如鼠标)可以悬停在元素上时,如下为一个示例:</p>
+
+<pre class="brush: css">@media (hover: hover) { ... }
+</pre>
+
+<p>许多媒体功能都是<em>范围功能</em>,这意味着可以在它们前面加上“最小”或“最大”来表示“最小条件”或“最大条件”约束。 例如,仅当您的浏览器的{{glossary("viewport")}}宽度等于或小于12450px时,此CSS才会应用样式:</p>
+
+<pre class="brush: css">@media (max-width: 12450px) { ... }
+</pre>
+
+<p>如果您在未指定值的情况下创建媒体功能查询,则该样式将全部被应用,只要该查询的值不为零(或在Level 4中为<code>none</code>)即可。 例如,此CSS将适用于任何带有彩色屏幕的设备:</p>
+
+<pre class="brush: css">@media (color) { ... }
+</pre>
+
+<p>如果某个功能不适用于运行浏览器的设备,则涉及该媒体功能的表达式始终为false。 例如,将不会使用嵌套在以下查询中的样式,因为没有语音专用设备具有屏幕长宽比:</p>
+
+<pre class="brush: css">@media speech and (aspect-ratio: 11/5) { ... }
+</pre>
+
+<p>有关更多媒体功能<a href="#Media_features">media feature</a>示例,请参阅每个特定功能的参考页。</p>
+
+<h2 id="创建复杂查询">创建复杂查询</h2>
+
+<p>有时您可能想创建一个取决于多个条件的媒体查询。 这就是<em>逻辑运算符</em>使用的场景:<code>not</code>,<code>and</code>,和 <code>only</code>。 此外,您可以将多个媒体查询合并到一个<em>逗号分隔的列表</em>中。 这使您可以在不同情况下应用相同的样式。</p>
+
+<p>在前面的示例中,我们已经看到<code>and</code>运算符用于将媒体类型与媒体功能分组。 and运算符还可以将多个媒体功能组合到单个媒体查询中。 同时,<code>not</code>运算符会否定媒体查询,从而基本上颠倒了它的正常含义。 唯一的运算符可防止较早的浏览器应用样式。</p>
+
+<div class="note">
+<p><strong>注意:</strong> 在大多数情况下,默认情况下,如果未指定其他类型,则使用<code>all</code>媒体类型。 但是,如果使用<code>not</code>或<code>only</code>运算符,则必须显式指定媒体类型。</p>
+</div>
+
+<h3 id="结合多种类型和特性">结合多种类型和特性</h3>
+
+<p><code>and</code>关键字将媒体功能与媒体类型或其他媒体功能组合在一起。 此示例结合了两种媒体功能,以将样式限制为宽度至少为30 em的横向的设备:</p>
+
+<pre class="brush: css">@media (min-width: 30em) and (orientation: landscape) { ... }
+</pre>
+
+<p>要将样式限制为带有屏幕的设备,可以将媒体功能链接到<code>screen</code>媒体类型:</p>
+
+<pre class="brush: css">@media screen and (min-width: 30em) and (orientation: landscape) { ... }</pre>
+
+<h3 id="测试多重查询">测试多重查询</h3>
+
+<p>当用户的设备与各种媒体类型,功能或状态中的任何一种匹配时,可以使用逗号分隔的列表来应用样式。 例如,如果用户设备的最小高度为680px或为纵向模式的屏幕设备,则以下规则将应用其样式:</p>
+
+<pre class="brush: css">@media (min-height: 680px), screen and (orientation: portrait) { ... }
+</pre>
+
+<p>以上面的示例为例,如果用户使用的打印机的页面高度为800像素,则media语句将返回true,因为将应用第一个查询。 同样,如果用户使用的是纵向模式的智能手机,并且视口高度为480px,则将应用第二个查询,并且media语句仍将返回true。</p>
+
+<h3 id="反转查询的含义">反转查询的含义</h3>
+
+<p><code>not</code>关键字会反转整个媒体查询的含义。 它只会否定要应用的特定媒体查询。 (因此,它不会应用于以逗号分隔的媒体查询列表中的每个媒体查询。)<code>not</code>关键字不能用于否定单个功能查询,只能用于否定整个媒体查询。 看看以下<code>not</code>关键字的例子:</p>
+
+<pre class="brush: css">@media not all and (monochrome) { ... }
+</pre>
+
+<p>所以上述查询等价于:</p>
+
+<pre class="brush: css">@media not (all and (monochrome)) { ... }
+</pre>
+
+<p>而不是:</p>
+
+<pre class="brush: css example-bad">@media (not all) and (monochrome) { ... }</pre>
+
+<p>再看另一个例子,如下媒体查询:</p>
+
+<pre class="brush: css">@media not screen and (color), print and (color) { ... }
+</pre>
+
+<p>等价于:</p>
+
+<pre class="brush: css">@media (not (screen and (color))), print and (color) { ... }</pre>
+
+<h3 id="提升老版本浏览器兼容性">提升老版本浏览器兼容性</h3>
+
+<p><code>only</code>关键字可防止不支持带有媒体功能的媒体查询的旧版浏览器应用给定的样式。 <em>它对现代浏览器没有影响。</em></p>
+
+<pre class="brush: css">@media only screen and (color) { ... }
+</pre>
+
+<h2 id="版本_4_中的语法改进">版本 4 中的语法改进</h2>
+
+<p>媒体查询4级规范对语法进行了一些改进,以使用具有“范围”类型(例如宽度或高度,减少冗余)的功能进行媒体查询。 级别4添加了用于编写此类的查询范围上下文。 例如,使用最大宽度<code>max-</code> 功能,我们可以编写以下代码:</p>
+
+<div class="blockIndicator note">
+<p><strong>Note:</strong> 媒体查询4级规范在现代浏览器中具有合理的支持,但某些媒体功能并未得到很好的支持。 有关更多详细信息,请参见 <a href="https://wiki.developer.mozilla.org/en-US/docs/Web/CSS/@media#Browser_compatibility"><code>@media</code> browser compatibility table</a>。</p>
+</div>
+
+<pre class="brush: css">@media (max-width: 30em) { ... }</pre>
+
+<p>在媒体查询4级规范可以这样写:</p>
+
+<pre class="brush: css">@media (width &lt;= 30em) { ... }
+</pre>
+
+<p>使用<code>min-</code>和<code>max-</code>可以测试一个在两个值之间的宽度</p>
+
+<pre class="brush: css">@media (min-width: 30em) and (max-width: 50em) { ... }</pre>
+
+<p>用4级语法书写如下</p>
+
+<pre class="brush: css">@media (30em &lt;= width &lt;= 50em ) { ... }
+
+</pre>
+
+<p>媒体查询4级规范还添加了用<strong>and</strong>, <strong>not</strong>, 和 <strong>or</strong>实现的完整的布尔运算来合并媒体查询的方法。</p>
+
+<h3 id="使用_not否定一个特性">使用 <code>not</code>否定一个特性</h3>
+
+<p>在媒体功能周围使用<code>not()</code>会否定查询中的该特性。 例如,如果设备没有悬停功能,则<code>not(hover)</code>将被匹配:</p>
+
+<pre class="brush: css">@media (not(hover)) { ... }</pre>
+
+<h3 id="用_or测试多个特性">用 <code>or</code>测试多个特性</h3>
+
+<p>您可以使用<code>or</code>测试多个功能之间的匹配,如果任何功能为true,则解析为true。 例如,以下查询测试具有单色显示或悬停功能的设备:</p>
+
+<pre class="brush: css">@media (not (color)) or (hover) { ... }</pre>
+
+<h2 id="参见">参见</h2>
+
+<ul>
+ <li><a href="/zh-CN/docs/Web/CSS/Media_Queries/Testing_media_queries">使用编程方法测试媒体查询</a></li>
+ <li><a href="http://davidwalsh.name/animate-media-queries">CSS Animations Between Media Queries</a></li>
+ <li><a href="/zh-CN/docs/Web/CSS/Mozilla_Extensions#Media_features">Extended Mozilla media features</a></li>
+ <li><a href="/zh-CN/docs/Web/CSS/Webkit_Extensions#Media_features">Extended WebKit media features</a></li>
+</ul>