Thuộc tính bộ lọc CSS
Ví dụ
Chuyển toàn bộ ảnh sang đen trắng (xám 100%):
img {
filter: grayscale(100%);
}
Hãy tự mình thử »Mẹo: Thêm ví dụ "Tự mình thử" bên dưới.
Định nghĩa và cách sử dụng
Thuộc tính filter
xác định hiệu ứng hình ảnh (như độ mờ và độ bão hòa) cho một phần tử (thường là <img>).
Giá trị mặc định: | không có |
---|---|
Thừa hưởng: | KHÔNG |
Hoạt hình: | Đúng. Đọc về hoạt hình Hãy thử nó |
Phiên bản: | CSS3 |
Cú pháp JavaScript: | object .style.filter="grayscale(100%)" Hãy dùng thử |
Hỗ trợ trình duyệt
Các số trong bảng chỉ định phiên bản trình duyệt đầu tiên hỗ trợ đầy đủ thuộc tính.
Các số theo sau -webkit- chỉ định phiên bản đầu tiên hoạt động với tiền tố.
Property | |||||
---|---|---|---|---|---|
filter | 53.0 18.0 -webkit- |
13.0 | 35.0 | 9.1 6.0 -webkit- |
40.0 15.0 -webkit- |
Cú pháp CSS
filter: none | blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url();
Mẹo: Để sử dụng nhiều bộ lọc, hãy phân tách mỗi bộ lọc bằng dấu cách (Xem phần "Ví dụ khác" bên dưới).
Chức năng lọc
Lưu ý: Các bộ lọc sử dụng giá trị phần trăm (tức là 75%), cũng chấp nhận giá trị dưới dạng thập phân (tức là 0,75).
Filter | Description | Demo |
---|---|---|
none | Default value. Specifies no effects | Demo ❯ |
blur( px ) | Applies a blur effect to the image. A larger value will create more blur. If no value is specified, 0 is used. |
Demo ❯ |
brightness( % ) | Adjusts the brightness of the image. 0% will make the image completely black. 100% (1) is default and represents the original image. Values over 100% will provide brighter results. |
Demo ❯ |
contrast( % ) | Adjusts the contrast of the image. 0% will make the image completely black. 100% (1) is default, and represents the original image. Values over 100% will provide results with more contrast. |
Demo ❯ |
drop-shadow( h-shadow v-shadow blur spread color ) | Applies a drop shadow effect to the image. Possible values: h-shadow - Required. Specifies a pixel value for the horizontal shadow. Negative values place the shadow to the left of the image. v-shadow - Required. Specifies a pixel value for the vertical shadow. Negative values place the shadow above the image. blur - Optional. This is the third value, and must be in pixels. Adds a blur effect to the shadow. A larger value will create more blur (the shadow becomes bigger and lighter). Negative values are not allowed. If no value is specified, 0 is used (the shadow's edge is sharp). spread - Optional. This is the fourth value, and must be in pixels. Positive values will cause the shadow to expand and grow bigger, and negative values will cause the shadow to shrink. If not specified, it will be 0 (the shadow will be the same size as the element). Note: Chrome, Safari and Opera, and maybe other browsers, do not support this 4th length; it will not render if added. color - Optional. Adds a color to the shadow. If not specified, the color depends on the browser (often black). An example of creating a red shadow, which is 8px big both horizontally and vertically, with a blur effect of 10px: filter: drop-shadow(8px 8px 10px red); Tip: This filter is similar to the box-shadow property. |
Demo ❯ |
grayscale( % ) | Converts the image to grayscale. 0% (0) is default and represents the original image. 100% will make the image completely gray (used for black and white images). Note: Negative values are not allowed. |
Demo ❯ |
hue-rotate( deg ) | Applies a hue rotation on the image. The value defines the number of degrees around the color circle the image samples will be adjusted. 0deg is default, and represents the original image. Note: Maximum value is 360deg. |
Demo ❯ |
invert( % ) | Inverts the samples in the image. 0% (0) is default and represents the original image. 100% will make the image completely inverted. Note: Negative values are not allowed. |
Demo ❯ |
opacity( % ) | Sets the opacity level for the image. The opacity-level describes the transparency-level, where: 0% is completely transparent. 100% (1) is default and represents the original image (no transparency). Note: Negative values are not allowed. Tip: This filter is similar to the opacity property. |
Demo ❯ |
saturate( % ) | Saturates the image. 0% (0) will make the image completely un-saturated. 100% is default and represents the original image. Values over 100% provides super-saturated results. Note: Negative values are not allowed. |
Demo ❯ |
sepia( % ) | Converts the image to sepia. 0% (0) is default and represents the original image. 100% will make the image completely sepia. Note: Negative values are not allowed. |
Demo ❯ |
url() | The url() function takes the location of an XML file that specifies an SVG filter, and may include an anchor to a specific filter element. Example: filter: url(svg-url#element-id) |
|
initial | Sets this property to its default value. Read about initial | |
inherit | Inherits this property from its parent element. Read about inherit |
Thêm ví dụ
Ví dụ về độ sáng
Điều chỉnh độ sáng của hình ảnh:
img {
filter: brightness(200%);
}
Hãy tự mình thử »Ví dụ tương phản
Điều chỉnh độ tương phản của hình ảnh:
img {
filter: contrast(200%);
}
Hãy tự mình thử »Ví dụ về bóng đổ
Áp dụng hiệu ứng đổ bóng cho ảnh:
img {
filter: drop-shadow(8px 8px 10px
gray);
}
Hãy tự mình thử »Ví dụ thang độ xám
Chuyển đổi hình ảnh sang thang độ xám:
img {
filter: grayscale(50%);
}
Hãy tự mình thử »Ví dụ về xoay Huế
Áp dụng xoay màu sắc trên hình ảnh:
img {
filter: hue-rotate(90deg);
}
Hãy tự mình thử »Ví dụ về màu nâu đỏ
Chuyển đổi hình ảnh sang màu nâu đỏ:
img {
filter: sepia(100%);
}
Hãy tự mình thử »Sử dụng nhiều bộ lọc
Để sử dụng nhiều bộ lọc, hãy tách mỗi bộ lọc bằng một khoảng trắng. Lưu ý rằng thứ tự rất quan trọng (tức là sử dụng thang độ xám() sau màu nâu đỏ() sẽ dẫn đến hình ảnh hoàn toàn màu xám):
img {
filter: contrast(200%) brightness(150%);
}
Hãy tự mình thử »Tất cả bộ lọc
Trình diễn tất cả các chức năng lọc:
.blur {
filter: blur(4px);
}
.brightness {
filter: brightness(0.30);
}
.contrast {
filter: contrast(180%);
}
.grayscale {
filter: grayscale(100%);
}
.huerotate {
filter: hue-rotate(180deg);
}
.invert {
filter: invert(100%);
}
.opacity {
filter: opacity(50%);
}
.saturate {
filter: saturate(7);
}
.sepia {
filter: sepia(100%);
}
.shadow {
filter: drop-shadow(8px 8px 10px green);
}
Hãy tự mình thử »Trang liên quan
Hướng dẫn CSS: Hình ảnh CSS
Tham chiếu DOM HTML: thuộc tính bộ lọc