I’m relatively new to Web dev. The question is generic, but I’ll pose specific user-cases.
Use-case 1:
I have a div element on a web page. When the page loads the first time, this div runs a small 5 sec animation. What I wish to do is, when this animation ends, I want the same div to contain some other element – it could be an image, a link, another animation etc.
That is, one container – the div – hosting multiple elements on a time-scale. First 5 secs animation , followed by an image or a link.
What Javascript methods will allow me to do so?
Use-case 2:
Again, I have a div element in a page. Now this div element is like a tabbed browser – you click on a different tab to view a different web page. Similarly, I wish to make this a “tabbed” div. As in, when the user hovers the mouse on tab 1, the div would show a video, when hovered over tab 2, it would show another video in the same div – that is, replacing the old video. The tabs can be considered as a fancy looking link.
Or, in the first place, is there an alternative to ‘div’ to do the things mentioned above?
Thanks,
SMK.
Solution for use case 2 –
This is a slightly lengthy solution but its extremely flexible and can be scaled up to any number of tabs very easily
We will divide the solution into 3 parts – The CSS, HTML and JQuery.
Lets take a look at the CSS part first
Let us now take a look at the HTML part of this solution
You can see that each tab is represented by a div which is using the “tabs” class from the CSS section. If you need to add a new tab, all you have to do is add a new div and give is a new id. For example to add a forth tab, you can say –
It is as simple as that.
Now the thing I like about this approach is that you can place the content to be displayed also in div’s, rather that nesting it under jquery. In this case we use the div’s with the id content1 content2 content3
This gives you the flexibility to expand as you enter content into the div and use normal markup without getting confused and at ease.
These div’s are not visible as we have set their visibility to hidden is CSS.
If you add a new tab div you must also add a new content div.
Now we move onto the JQuery part –
The above JQuery function is extremely straight forward. Each tab is attached a action listener which is fired by a mousover event. So if you add another tab with the id=tab4 and its respective content div with the id=content4 then all you have to add in the jQuery is:
So it becomes very easy to expand the code.
You can find a working demo of this on my website demo section
Tips –