admin管理员组

文章数量:1287245

I've had a search and I couldn't find anything & also it's my first time using the site so hope it hasn't been asked.

I've run into a situation. I'm by no means an experienced website maker. I'm learning as I go. I have a CSS drop down menu that works fine on desktop browsers. When I get into the realm of mobile I encounter a problem, namely that :hoverdoesn't work (obviously).

I found this : but I can't get the ruddy thing to work.

The page in question I'm applying it to is here : .html I really can't work this out and its driving me absolutely batty. Any help would be really appreciated.

I've had a search and I couldn't find anything & also it's my first time using the site so hope it hasn't been asked.

I've run into a situation. I'm by no means an experienced website maker. I'm learning as I go. I have a CSS drop down menu that works fine on desktop browsers. When I get into the realm of mobile I encounter a problem, namely that :hoverdoesn't work (obviously).

I found this : http://osvaldas.info/drop-down-navigation-responsive-and-touch-friendly but I can't get the ruddy thing to work.

The page in question I'm applying it to is here : http://www.inkslinger.co.uk/calibre/index.html I really can't work this out and its driving me absolutely batty. Any help would be really appreciated.

Share Improve this question edited Nov 24, 2013 at 23:03 Charles 4,5389 gold badges44 silver badges82 bronze badges asked Nov 24, 2013 at 20:58 ikillbearsikillbears 711 gold badge1 silver badge4 bronze badges
Add a ment  | 

5 Answers 5

Reset to default 2

I had the same problem and found an easy workaround which I have used here hover example

The Post Natal and Ante Natal options, when hovered over, trigger the drop down, but you may notice that they are NOT links themselves. In my original model they were links, but when I realised this would not work on touch devices, I simply made them into triggers for the drop down boxes, and put the links inside the boxes too. So for you, your 'What we do' link, would not be a link, just a trigger for the dropdown menu, and then in the menu you can have your link to the 'what we do' info.

It is also worth remembering that certain touch devices, such as some iPads, do not like hover states at all, if you find that the hover state won't trigger your dropdown menu, then add 'onclick="return true"' to the list item in question. This will usually make the hover state work like a click.

Hope this helps, what I've written represents about 3 days of poring over my library of reference books.

We had this problem and changed the hover to clicks.

Instead of using hover, which is of course impossible on touch devices, using :active would likely be a good start. Selection something is still possible on touch devices, bind the menu to the active state of a toggle and you're done.

You will have to switch from hover to click event for this case. There's no workaround for that.

You should definitely consider changing your design to have a hamburger styled menu which opens from left for touch devices.

See this demo from the link that you posted. It changes to a different menu style when you open it in mobile device. http://osvaldas.info/examples/drop-down-navigation-touch-friendly-and-responsive/

Also if you want to have your top link as a direct link to other page; you can have two separate clicks on the top button for that. First click will open the menu and after the menu is opened you can assign the direct link to it as done in the above demo.

Put this line of code inside your head tag like this:

<head>
  <script>document.addEventListener("touchstart", function(){}, true);</script>
</head>

Create for your hover element an active class like this:

element:hover, element:active { Your CSS }

Voila.

本文标签: javascriptCSS Drop down menu on mobile how to get around hoverStack Overflow