Skip to content

[css-values] when should values inside mix() be clamped?  #8158

Closed
@graouts

Description

@graouts

CSS Values and Units Level 4 introduces the mix() function. It's not clear to me reading the spec at what point clamping should be applied for this example:

<div style="font-size: 40px; line-height: mix(0.5, 40px, calc(40px - 3em))"></div>

The spec has this to say in the Range Checking section for calc():

Parse-time range-checking of values is not performed within math functions, and therefore out-of-range values do not cause the declaration to become invalid. However, the value resulting from an expression must be clamped to the range allowed in the target context.

I'm not sure what "resulting from an expression" means here. I think the above mix() value could resolve to either:

  1. 20px where we clamp the output of the calc() expression and mix between 40px and 0px,
  2. 0px where we only clamp the output of the entire mix() expression and mix between 40px and -80px, clamping the result -20px to 0px

Assuming that "resulting from an expression" refers to any math function then it would clearly be the first result since mix() is not a math function.

This is somewhat related to #8157 where I raised the issue of what would happen when interpolating between the same two values in the context of an animation.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions