jarrod
jarrod

I’d really prefer for my header menu to not have this weird in-between phase where the items make a second row.

Narrow window with 6 menu items on two rows.

If the window is too narrow for them to be on one row, I just want it to collapse into this hamburger dropdown. Any CSS magicians out there who can help me out?

Narrow window with 6 items in a dropdown menu.

|
Embed
Progress spinner
jarrod
jarrod

@kq That's what I thought, and tried to do, but I haven't been able to track down the right place or incantation to make it so. 😓 I'm using the Hello theme that I've lightly tweaked.

|
Embed
Progress spinner
jarrod
jarrod

@kq I want to say at around 684 pixels wide. But you have to tap on the menu icon to see them displayed.

|
Embed
Progress spinner
jarrod
jarrod

@kq Here's an example: share.heydingus.net/QRg1dQcz Below 684 pixels wide, it shrinks to the dropdown menu. Between 684px and 730px, the menu items are hidden behind a click on the button, but they do not live in the dropdown menu. Above 730px, they correctly live in the top nav bar.

|
Embed
Progress spinner
jarrod
jarrod

@kq That’s super kind of you! 🙂

|
Embed
Progress spinner
In reply to
jarrod
jarrod

@kq Fair enough, thanks for taking a look. I had a feeling it had to do with all the cruft. I'll have to see if I can find some time to pull it apart and simplify.

Thanks again!

|
Embed
Progress spinner
pimoore
pimoore

@kq @jarrod As someone who’s about to dive back in to theme customization, I’m quickly reminded of a key fact:

Media queries and breakpoints are a pain in the ass.

|
Embed
Progress spinner
Mtt
Mtt

@pimoore @kq @jarrod Agreed 100%. Any design/theme I make for any reason avoids media queries and breakpoints (and any scripts that go along with those) as much as possible. With relative sizing and such, it’s possible to achieve the same results much more elegantly.

|
Embed
Progress spinner
jarrod
jarrod

@Mtt Relative sizing without media queries? You have my attention!

|
Embed
Progress spinner
Mtt
Mtt

@jarrod Well, my personal favorite example is Tiny Theme. 😬 It has only 1 media query (for dark mode only), no breakpoints, no scripts, etc. You can manipulate the entire size of almost everything simply by adjusting one font size.

|
Embed
Progress spinner
pimoore
pimoore

@Mtt @kq @jarrod I’m actively trying to learn CSS as we speak. My understanding is media queries are still necessary if you want to (for example) decrease font size on small screens, in order to maintain a longer line length. Do I have that correct, or is there a way to do this without them? I struggled with this issue greatly on my two themes, and I’d like to know more should I decide to build something from scratch.

|
Embed
Progress spinner
Mtt
Mtt

@pimoore There are definitely ways of doing it. You can use things like vw and clamp, for example. I would consider those quite advanced though. They often require lots of math and calc usage.

Having said that, there is nothing inherently wrong with media queries. The issues, in my opinion, are:

  1. They are often over used. When one design has multiple breakpoints for different things, it gets to be a mess fast.

  2. It makes things like themes hard to customize. In many cases, you are required to make the same change across every media query.

  3. There are no hard and fast sizes for proper media queries. There will always be one more screen size that doesn’t quite work exactly right.

When used right, they’re great. They don’t slow down load times or anything like that. Use them if you need, just be judicious about them.

|
Embed
Progress spinner
pimoore
pimoore

@Mtt I encountered all of those issues with my themes, and found them very confusing once you go any higher than two breakpoints. I’ve also learned that display zoom won’t work with strictly vw-controlled font size—only if it’s part of a clamp element. Both Tufte and Hitchens had more queries than I would’ve liked, thus also triggered my wanting to learn more about this stuff.

|
Embed
Progress spinner
amit
amit

@pimoore @Mtt I keep the breakpoints to minimum, but can never get rid of them. I mainly use it to hide some elements on smaller displays. As Pete said, even I want to understand this better. I generally want to improve my CSS skills.

|
Embed
Progress spinner
Mtt
Mtt

@pimoore And sometimes they are the best possible tool. For example, I’ve got a gallery plugin coming this week that makes use of them. Still no scripts though!

|
Embed
Progress spinner
Mtt
Mtt

@amit @pimoore Often times that’s the best you can do. And if you’re developing a theme, you could make the argument that media queries are actually easier on customizers than the complicated math centric alternatives.

|
Embed
Progress spinner
pimoore
pimoore

@Mtt @amit In that case you both might be interested in this:

Utopia Fluid Type Scale Calculator

It’s a gem for working with font sizing, and offers root code using clamps that you can plug into your CSS.

|
Embed
Progress spinner
jaheppler
jaheppler

@pimoore Nice, filing this away for future projects. @Mtt @amit

|
Embed
Progress spinner
pimoore
pimoore

@Mtt Anything that doesn’t require scripts is A+ in my mind. Looking forward to seeing your new plugin!

|
Embed
Progress spinner
jarrod
jarrod

@Mtt 👀😉

|
Embed
Progress spinner
pimoore
pimoore

@kq @mtt @jarrod What breakpoint measurement are you using for this, Kev?

|
Embed
Progress spinner