转载:CSS — background-clip vs. background-origin properties | by Tsz | Level Up Coding
When I was learning these 2 CSS properties, I felt confused since both of them have the same set of property values and their demonstration effect looks similar. After research and investigation, here’s how I understood the 2 properties right now.
In all the below examples, I will use a div with a 20px dashed border and 15px padding, with background-repeat. (The orange, green, and blue color below represents the border, padding, and content area respectively)
data:image/s3,"s3://crabby-images/3bb05/3bb054793a3a967d7d447c3b8fdce24fd4f648d9" alt="The div to be used in below examples"
data:image/s3,"s3://crabby-images/8260f/8260f9ff5a988a81597fcc64c05350a7d49bb1cb" alt="The background image to be used in the below examples"
# background-origin
It defines where the starting position of the background. (from the upper left corner)
# border-box
When we set the value to “border-box”, the background begins at the upper-left corner of the border area
data:image/s3,"s3://crabby-images/7fdc7/7fdc72251a3373b4966fc133d989cfb6f23e37b6" alt=""
# padding-box
The background begins at the upper-left corner of the padding area
data:image/s3,"s3://crabby-images/c4925/c4925d15a3a7a441c4434aa740dfbd4e7a3c61b8" alt=""
# content-box
The background begins at the upper-left corner of the content area
data:image/s3,"s3://crabby-images/32331/32331626798ba66f8923844fa076af308ce82298" alt=""
# background-clip
After understanding what the “background-origin” does, it’s easier to understand what is “background-clip”.
# Differences between the 2 properties
“background-clip” — let you define in which area the background should be displayed, background outside the area will be “clipped”.
“background-origin” — defines only the starting position of the background, we don’t have the power to define anything else (e.g.: where does it end) using this property on its own.
# content-box
We will start from “content-box” this time as it shows the most obvious effect. We can see that the background only fills up within the content area, but not the padding nor border area.
data:image/s3,"s3://crabby-images/32b5b/32b5b4121f325ae7eaf8ae78f8b409c5f5699799" alt=""
# padding-box
The background extended to the padding area this time.
data:image/s3,"s3://crabby-images/96465/96465494e5f0a4f7fc373fe1a1e0f79dd060ce5e" alt=""
# border-box
The background extends to the complete div, including its border area.
data:image/s3,"s3://crabby-images/bf634/bf6349d6f5258ac2e4558486146bdabae70eea13" alt=""
# More use cases
After understanding what each property does, we can use them independently or together for different use cases!
# Applying multiple values
Apart from the above single value examples, both properties support giving multiple values (separated by comma), to define the multiple background behavior.
In the coming examples, I set 2 background image URLs in the “background-image” property.
Then in the “background-clip” demo, I can define image A to be extended to the content box area; while image B can extend to the border-box area.
data:image/s3,"s3://crabby-images/5698a/5698a0d2dbe9dacae54299276d5dfadd9c4e7c09" alt=""
In the “background-origin” demo, the starting point of background A & background B can be different. (A begins at the content box, B begins at the border-box).
data:image/s3,"s3://crabby-images/c2bce/c2bce21872b2d240bc86d4bbc08e9c3780446f80" alt=""
# Apply the 2 properties together
The 2 properties can be used together. In the below examples, I used “background-origin” to set the background image’s position; and used “background-clip” to decide what area of background images should be shown.
data:image/s3,"s3://crabby-images/170ef/170ef2a6680e037bb3af54b39074e6909aab1ae6" alt=""
the starting points of the 2 background images are different!