CSS Align depending on Screen Resolution

Hello All;

This should be a quick one.
The following code is used to align my element, however, the screen resolution differ's for all, so the element is mis-placed depending on on what size the screen is.
How can I adjust, depending on the screen resolution?

<div id="Login" style="display:none; position:absolute; right:200px; top:61px; z-index:100;">

Open in new window

Thanks All;
LVL 31
Wayne BarronAuthor, Web DeveloperAsked:
Who is Participating?
COBOLdinosaurConnect With a Mentor Commented:
That is a 20th century table layout that is static and rigid. Using a design like that removes any possibility of fluidity or dynamic repositioning.

A different resolution does not do anything except add or remove scrollbars.

The login div is in a table cell and you cannot move a table cell; and you cannot modify it in this case without changing the whole table; and probably other stuff on the page.

Mark GilbertSenior Performance EngineerCommented:
Screen resolution is variable so use a variable size measurement instead of px such as em or a specific percentile. em would probably be the best way to go. Then it wouldn't matter what size screen it was it would look the same across them all as it would be relative.
Wayne BarronAuthor, Web DeveloperAuthor Commented:
I tried as you suggested, and with the smaller browsers, it is still shifted badly.

<div id="Login" style="display:none; position:absolute; right:12.000em; top:3.305em; z-index:100;">

Open in new window

I am using the following site, to convert over PX to EM

Could you provide a good working conversion?
Cloud Class® Course: MCSA MCSE Windows Server 2012

This course teaches how to install and configure Windows Server 2012 R2.  It is the first step on your path to becoming a Microsoft Certified Solutions Expert (MCSE).

As long as you are absolute positioning on a page that does not have ever single position and dimension fixed, you are going to get a shift.  The only solutions are to either make the whole page rigid and non-responsive, or use scripting to detect resolution and then set the position and that will not work if the user has javascript disabled.

If you post a link to the site we might be able to help further.

Wayne BarronAuthor, Web DeveloperAuthor Commented:
This is one of the sites that is using it this same technique.
You will see it in the Upper Left, for the Login and Register link.
Wayne BarronAuthor, Web DeveloperAuthor Commented:
Yep, I figured as much.
Having to convert everything over to DIV, at this people, is not an option.
However, in the future it will be.

Thanks for the info Cd&
I will close this one out with your response, as it is about as good as I am going to get at this time.

Can you provide a good site for demonstrating converting from <table> to <div> layout?

Wayne BarronAuthor, Web DeveloperAuthor Commented:
It is not so much about converting as it is about looking at it differently.  The basic idea is to make markup and design support content and the meaning of the content (semantic web). The old approach is to develop a design and structure and then make the content fit into the design.  The modern approach is to build structure around the content and present the content as the most important thing, not the design.  

Three other thing come ahead of design. Usability, accessibility, and respect for the user.

Perhaps these links will help you get going in the right direction:


At first it takes a little discipline to force yourself to follow standards and develop a "best practices" approach; but you start seeing the benefit when you have to do maintenance, and it is way easier working with code that was built using modern approaches.  You quickly build a bag of tricks that let's you develop quickly because you know exactly how every element is going to behave.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.