Css 简明教程

CSS - Zoom

CSS 的 zoom 属性可用于控制元素的放大级别。

zoom 是 CSS 的非标准属性,建议对相同输出使用 transform: scale() 函数。

Possible Values

  1. normal :指定元素应按其正常大小渲染。

  2. reset :指定元素应不放大,除非用户应用基于非捏合缩放。相反, Not recommended 使用 unset 值。

  3. <percentage> :任意称为缩放因子的百分比值。等于 100% 的值为 normal 。大于 100% 的值意味着元素应 zoom-in 。小于 100% 的值意味着元素应 zoom-out

  4. <number> : 对应于百分比值的任何数值。例如:1.0 = 100% = 正常。等于 1.0 的值是 normal 。大于 1.0 的值表示元素应 zoom-in 。小于 1.0 的值表示元素应 zoom-out

Applies to

所有 HTML 元素。

DOM Syntax

object.style.zoom = "normal | reset | <number> | <percentage>";

CSS zoom - normal Value

这是一个示例:

<html>
<style>
   p.normal {
      zoom: normal;
   }
   p.percent {
      zoom: 170%;
   }
   p.number {
      zoom: 4;
   }
   p.unset {
      zoom: unset;
   }
</style>
<head>
</head>
<body>
   <p class="normal">Normal size</p>
   <p class="percent">Zoom in percentage</p>
   <p class="number">Zoom in number</p>
   <p class="unset">Zoom settings reverted.</p>
</body>
</html>

CSS zoom - <percentage> Value

以下提供另一个示例:

<html>
<head>
<style>
   div.box {
      height: 50px;
      width: 50px;
      display: inline-block;
      padding: 5px;
      border: 1px solid black;
   }
   div#m {
      background-color: orange;
      zoom: 200%;
   }
   div#n {
      background-color: lavender;
      zoom: 1.5;
   }
   div#o {
      background-color: palevioletred;
      zoom: normal;
   }
</style>
</head>
<body>
   <div id="m" class="box"></div>
   <div id="n" class="box"></div>
   <div id="o" class="box"></div>
</body>
</html>

CSS zoom - With number Value

这是一个示例,其中在经过时会放大小号 h1 元素:

<html>
<head>
<style>
   p {
      border: 1px solid red;
   }
   p.percent {
      zoom: 170%;
   }
   p.number {
      zoom: 4;
   }
   h1:hover {
      zoom: 250%;
      text-decoration-line: underline;
   }
</style>
</head>
<body>
   <h1>Hover to Zoom</h1>
   <p class="percent">Zoom in percentage</p>
   <p class="number">Zoom in number</p>
</body>
</html>

CSS zoom - With Animation

这是一个示例,其中在经过时会添加动画以及缩放:

<html>
<head>
<style>
   div.box {
      width: 25px;
      height: 25px;
      vertical-align: middle;
      display: inline-block;
      transition: transform .5s;
      padding: 10px;
   }
   div#a {
      background-color: rgb(58, 220, 22);
      zoom: normal;
   }
   div#b {
      background-color: rgb(239, 86, 137);
      zoom: 200%;
   }
   div#c {
      background-color: rgb(223, 217, 44);
      zoom: 2.9;
   }
   div.box:hover {
      transform: scale(1.5);
   }
</style>
</head>
<body>
   <h1>Animation added on hover</h1>
   <div id="a" class="box"></div>
   <div id="b" class="box"></div>
   <div id="c" class="box"></div>
</body>
</html>