开发网站时如何处理不同的屏幕分辨率/屏幕尺寸?

发布于 2024-09-03 18:38:47 字数 160 浏览 6 评论 0 原文

我想使用 jQuery 开发一个适用于所有主要浏览器的网站。我想从基本布局开始(一个页眉、几个包含内容的选项卡和页脚)。我想知道应该如何创建这个布局来支持不同的屏幕分辨率、屏幕尺寸或窗口尺寸。在定义组件的宽度和高度时,我应该使用像素/点/百分比吗?有没有 jQuery 插件可以帮助我完成这项任务?谢谢 !

I would like to develop a site using jQuery that will work with all major browsers. I thought to start with a basic layout (a header, a couple of tabs with content, and footer). I wonder how should I create this layout to support different screen resolution, screen size, or window size. Should I work in pixels / points / percents when defining width and height of the components ? Are there any jQuery plugins that can help me with this task ? Thanks !

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

讽刺将军 2024-09-10 18:38:47

此问题有多种解决方案,但它们主要取决于您想要通过网站共享的内容类型(即大小可能有限的嵌入式视频或图像)以及您想要的外观和感觉。

对于在多种浏览器和各种窗口尺寸中都能正常工作的网页布局,您应该查看“液体布局”。以下是有关这些布局的教程的一些链接。

您还可以使用 Javascript(包括 jQuery)根据窗口分辨率调整样式/内容(例如,针对较小的屏幕(例如手机)从多列布局更改为单列布局)。这称为“自适应内容”。

There are a number of solutions to this problem, but they are primarily dependent on what kind of content you are wanting to share through the site (ie embedded videos or images which may have a finite size) and the look and feel you are going for.

For web layouts which work well in multiple browsers and across a wide range of window sizes, you should be looking at "Liquid Layouts". Below are a few links to tutorials about these layouts.

You can also use Javascript (including jQuery) to tweak the styling/content based on the window resolution (for instance, changing from a multi-column layout to a single-column layout for smaller screens, such as mobile phones). This is called "Adaptive Content".

不一样的天空 2024-09-10 18:38:47

这是我过去使用过的一些简单脚本(使用 jQuery):

$(document).ready(function(){
 $('body').append('<div id="screencss"></div>');
 adjustCSS();
 $(window).resize(function(){ adjustCSS() });
})
function adjustCSS(){
 var pageWidth = $(window).width();
 var sizeSelected = "css/blue-800.css";
 if (pageWidth > 900) { sizeSelected = "css/blue-1024.css"; }
 if (pageWidth > 1010) { sizeSelected = "css/blue-1280.css"; }
 if (pageWidth > 1420) { sizeSelected = "css/blue-1600.css"; }
 $("#screencss").html('<link href="' + sizeSelected + '" media="screen" rel="Stylesheet" type="text/css" />');
}

代码中使用的页面宽度值是任意的,并且经过调整以适用于特定站点,因此请随意根据需要调整它们。

此外,每个 CSS 文件中都只有最少量的 CSS,用于设置主要容器/包装器甚至背景图像的宽度。


更新#2:如果您试图维护有效的 HTML。然后,您可以将所有 CSS 样式表添加到页面的头部(每个样式表中都包含一个标题属性):

<link title="blue1" href="blue-320.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue2" href="blue-640.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue3" href="blue-800.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue4" href="blue-1024.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue5" href="blue-1280.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue6" href="blue-1600.css" media="screen" rel="Stylesheet" type="text/css" />

然后使用此脚本。如果您在 CSS 中包含背景图像,您可能会看到白色闪光,因此请确保设置基本 CSS 样式。

$(document).ready(function(){
 $('body').append('<div id="screencss"></div>');
 adjustCSS();
 $(window).resize(function(){ adjustCSS() });
})
function adjustCSS(){
 var pageWidth = $(window).width();
 var sizeSelected = "blue1";
 if (pageWidth > 510) { sizeSelected = "blue2"; }
 if (pageWidth > 580) { sizeSelected = "blue3"; }
 if (pageWidth > 900) { sizeSelected = "blue4"; }
 if (pageWidth > 1010) { sizeSelected = "blue5"; }
 if (pageWidth > 1420) { sizeSelected = "blue6"; }
 var lnk = $('head').find('link[title=' + sizeSelected + ']').removeAttr('disabled');
 $('head').find('link[title]').not(lnk).attr('disabled', 'disabled');
}

This is some simple scripting I've used in the past (using jQuery):

$(document).ready(function(){
 $('body').append('<div id="screencss"></div>');
 adjustCSS();
 $(window).resize(function(){ adjustCSS() });
})
function adjustCSS(){
 var pageWidth = $(window).width();
 var sizeSelected = "css/blue-800.css";
 if (pageWidth > 900) { sizeSelected = "css/blue-1024.css"; }
 if (pageWidth > 1010) { sizeSelected = "css/blue-1280.css"; }
 if (pageWidth > 1420) { sizeSelected = "css/blue-1600.css"; }
 $("#screencss").html('<link href="' + sizeSelected + '" media="screen" rel="Stylesheet" type="text/css" />');
}

The page width values used in the code are arbitrary and were tweaked to work with a specific site, so feel free to adjust them as desired.

Also, inside of each of those CSS files is just a minimal amount of CSS that sets the width of major containers/wrappers and even the background image.


Update #2: If you are trying to maintain valid HTML. Then you can add all of the CSS stylesheets into the head of your page (include a title attribute in each one):

<link title="blue1" href="blue-320.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue2" href="blue-640.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue3" href="blue-800.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue4" href="blue-1024.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue5" href="blue-1280.css" media="screen" rel="Stylesheet" type="text/css" />
<link title="blue6" href="blue-1600.css" media="screen" rel="Stylesheet" type="text/css" />

Then use this script. You may get a flash of white if you have included background images in your CSS, so make sure to set a base CSS style.

$(document).ready(function(){
 $('body').append('<div id="screencss"></div>');
 adjustCSS();
 $(window).resize(function(){ adjustCSS() });
})
function adjustCSS(){
 var pageWidth = $(window).width();
 var sizeSelected = "blue1";
 if (pageWidth > 510) { sizeSelected = "blue2"; }
 if (pageWidth > 580) { sizeSelected = "blue3"; }
 if (pageWidth > 900) { sizeSelected = "blue4"; }
 if (pageWidth > 1010) { sizeSelected = "blue5"; }
 if (pageWidth > 1420) { sizeSelected = "blue6"; }
 var lnk = $('head').find('link[title=' + sizeSelected + ']').removeAttr('disabled');
 $('head').find('link[title]').not(lnk).attr('disabled', 'disabled');
}
那一片橙海, 2024-09-10 18:38:47

jQuery 本身无法帮助你做到这一点。您必须掌握基本的 HTML 和 CSS 的窍门。如果需要就使用 Javascript 和 jQuery,不要只是为了使用而使用。当涉及到网络尺寸时,您应该使用像素或百分比。积分用于打印。字体大小应以 EM 或像素为单位设置。

固定布局对于普通网页来说是最常见的,通过使用像 960gs 这样的网格框架,您可以轻松实现使比例看起来不错,同时仍然支持绝大多数屏幕分辨率。将图形适应固定宽度布局也非常容易,同时使页面易于使用。

请记住,当/如果使用百分比时,长度超过 600-800 像素的文本行会难以阅读或阅读缓慢。也就是说,对于 1000 像素宽的视口来说,内容区域为 80% 可能是一个好主意,但如果您的视口为 1900 像素,则该网站将变得几乎无法使用。

而且人们通常不会明确设置物体的高度,因为高度会随着容器内容的增加而自动增加。当然,您可以设置某些东西的高度,但这实际上取决于什么。

因此,使用动态或固定宽度完全取决于您的内容。

jQuery itself cant help you do this. You have to get the hang of basic HTML and CSS. Use Javascript and jQuery if you need it, don't use it just to use it. You should work with pixels or percents when it comes to dimensions on the web. Points are for printing. Font sizes should be set in EMs or pixels.

A fixed layout is the most common for normal web pages, and by using grid frameworks like 960gs, you have an easy way making gthe proportions look decent while still supporting the vast majority of screen resolutions. It's also far, far easier adapting graphics to a fixed width layout, and at the same time make the page easy to use.

Keep in mind when/if using percentages that text lines longer than about 600-800 pixels is difficult or slow to read. Aka having a content area of 80% could be a nice idea for a viewport that's 1000px wide, but if you have a viewport of 1900px, the site becomes mostly unusable.

And one usually does not explicitly set a height on things, as the height will automatically increase as the content of the container increases. Of course, you can set the height on certain things, but it all depends on what, really.

So, using a dynamic or fixed width all depends on your content.

自我难过 2024-09-10 18:38:47

根据您所描述的需求,我强烈建议您查看雅虎用户界面 (YUI) 库中的“Grids”css 文件,您可以在此处找到该文件和文档:http://developer.yahoo.com/yui/grids/

grids 包的基本设置包括页眉、正文和页脚。如果需要,您可以删除页眉和/或页脚。可以使用嵌套网格模型来划分主体,并且包含各种模板。

就我个人而言,我使用 YUI 中的组合“reset-fonts-grids”文件开始制作所有 HTML/CSS 页面。它为您提供了跨浏览器的 CSS 重置文件、网格文件和一些标准化的字体类。

Based on your described needs, I would highly recommend checking out the "Grids" css file from the Yahoo User Interface (YUI) library, you can find the file plus documentation here: http://developer.yahoo.com/yui/grids/.

The grids package's basic setup includes a header, body, and footer. You can remove the header and/or footer if desired. The body can be divided up using a nested grid model and a variety of templates are included.

Personally, I start off all HTML/CSS pages I make with the combined "reset-fonts-grids" file from YUI. It provides you with a cross-browser css reset file, the grids file, and some standardized classes for fonts.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文