Alloy is a UI metaframework that provides a consistent and simple API for building web applications across all three levels of the browser: structure, style and behavior.
还没来得急,仔细看,收藏先,如果你懂,告诉我:)
http://alloy.liferay.com/
Alloy is a UI metaframework that provides a consistent and simple API for building web applications across all three levels of the browser: structure, style and behavior.
类似的框架:
Bootstrap是由Twitter开发者构建的开源的前端框架。Bootstrap所涉及的范围应该多广?Bootstrap是否真的很实用?关于这两方面的问题,人们曾展开过激烈的争论。在本文我将站在服务器端开发者的角度去探索Bootstrap。我想Bootstrap对我样的人是有用的,因为我设计能力不强,也没有太多的时间去调整前端界面。
http://www.webapptrend.com/2012/03/2325.html#comment-665
http://twitter.github.com/bootstrap/examples.html
http://www.liferay.com/web/nathan.cavanaugh/blog/-/blogs/liferay-com-mobile-sites-and-responsive-layouts
2011年5月22日 由 Nate Cavanaugh
Bryan recently blogged about the new site design and how Liferay.com is displaying a mobile formatted website for different types of devices (go ahead and test it out, hop into any browser and resize the page as small as it can go). Today I want to discuss a bit how we achieved this from a technical level. This is one of the most common questions I not only got from people who attended our East Coast Symposium, but also inside of Liferay from other devs.
Because we like to keep our ear to the ground on all things front end, we’ve actually been following the discussion/debate about responsive web design sinceEthan Marcotte published his article on the subject last year. If you haven’t read the article, the tl;dr version is that using CSS media queries, it’s possible to pass a different set of CSS styles to different devices and have a design that’s customized for a specific browser/device size.
As far as mobile strategies go, it’s probably the easiest to implement, and there are a lot of quick wins with it. However,Jon Neal pointed out to me when we were first discussing this idea that there’s very little difference between using CSS media queries and just using Javascript to simulate the same thing.
I’ve since read other people bring up a similar point, and it’s a fair one. In fact, there are multiple issues with CSS media queries that make them cumbersome. For instance, let’s say we want to share some styling across two specific devices. It’s possible using the logical operators but even then, you end up with duplicate CSS (and it becomes much harder to read). And the fact that IE doesn’t support media queries was another major impediment to us using it, so we were going to need to use JavaScript anyways (either to add the CSS classnames or to parse mediaqueries).
So Jon wrote up a script that would handle this logic for us. Here’s how the script works: When the page is loaded or resized, the script checks the width of the window and it looks into an object of 4 major size specifications; 960, 720, 480, and 320.
What do those numbers mean? 960px is based on the uber-popular 960 grids which is a layout width that looks great on most desktop computers, and the iPad in landscape mode. 720px is a layout width that looks great when the iPad is in portrait mode. 480px is the width of the window of most smart phones in landscape mode. 320px is the width of the window of most smart phones in portrait mode.
The other great thing Jon came up with was to add greater-than and less-than css classes. I’ll show how this works in a second, but the idea is basically, you can not only target a specific device width, but also if it’s greater than or less than any of those above widths.
If your target device is 600x800, you can still target that device with the css classes.
With what Jon prototyped, I’ve created an Alloy module that codifies this so that it’s super easy to use (while at the same time, staying out of the way for users who don’t wish to use it).
For a quick and simple demo, open up the viewport demo (if you view it in Chrome or Safari, Firefox or Opera, you’ll see some cool CSS3 generated content/animation, but the demo works in any browser).
To get the module to run, all you need to do is call: AUI().use('aui-viewport')
in a script tag anywhere on your page.
Now you can target your site design to specific device sizes. Let’s say we want to give our navigation items to sit side by side when we view on the ipad or larger, but that we want to have them stack on smart phones:
#navigation li {
display: inline;
float: left;
}
.aui-view-lt720 #navigation li {
display: block;
float: none;
}
or let’s say we don’t want to make sure our images don’t exceed a certain width on the iPad in portrait mode
.aui-view-720 img {
max-width: 300px
}
Or perhaps we want to target just portrait mode of smartphones and tablets:
.aui-view-720 body, .aui-view-320 body {
background: #ccc;
}
You can even combine this with our other browser selectors to target very specific browsers:
.touch.aui-view-lt720 {} /* Touch based smartphones */
.webkit.aui-view-lt960 {} /* Webkit based tablets and smartphones */
.win.aui-view-720 {} /* Smaller browser views on just Windows */
Now, how is the logic applied? If the screen is equal to or between any of our defined widths, it will get this CSS class:aui-view-{WIDTH}
. And, if the screen is greater than any of our widths, it will also get:aui-view-gt{WIDTH}
. Lastly, if the screen is less than any of our widths, it will also get:aui-view-lt{WIDTH}
.
So a window size of 1900x1200 would get:
aui-view-gt320
aui-view-gt480
aui-view-gt720
aui-view-gt960
aui-view-960
whereas a window size of 800x600 would get:
aui-view-gt320
aui-view-gt480
aui-view-gt720
aui-view-720
aui-view-lt960
Notice that the classes represent the width rounded down to the nearest division. This is to guarantee that your styled layout won’t exceed the current width. Because of that the css class doesn’t exactly represent the current width, but rather enforces you to think about the layout at specified sizes and devices.
Caveats
Life is not all cheese and bananas with this system, as there are some caveats to be aware of:
You are delivering the same content to all devices.
Depending on the project, this could either seal the deal or break it. There’s an added cost to shipping down different images for the same page, and some mobile websites may wish to send only a very limited set of content to mobile devices (or perhaps very targeted content). The answer to this then is decide which of the 2 strategies you wish to use for your specific project: same content for all devices, but dimension specific designs, or redirect to a mobile/touch specific community that serves a targeted set of content and design.
Designs can require more planning for each of the design layouts
You’ll notice that the design now has to accommodate basically 4 different views: desktop, tablet(portrait), and smartphone (portrait and landscape). This of course means thinking about a different set of design compromises and layouts for how the same content should fit (or which content should be hidden) for different types of views. Of course, this caveat extends to both content strategies, but having the same content automatically in every view often requires a bit more forethought during the design process.
How can you get this module?
If you’re an Enterprise Edition customer, this module will be available in the 6.0 SP2 service pack (and the great part is, if you don’t want to use it, it will have 0 affect on your application). If you’re running Community Edition, this will be in Liferay 6.1 or if you’re running trunk of Liferay you can see it today. We’ll also be releasing another version of AlloyUI soon that will have it included.
Conclusions
Overall, the response has been great, and the design/development process was surprisingly smooth. I would recommend it as a general principle for your design, as it helps our designs fit the fluid nature of the web.
More information
Responsive Web Design by Ethan Marcotte
MediaQueri.es
The practicalities of CSS Media Queries, lessons learned.