【发布时间】:2013-09-14 23:26:24
【问题描述】:
我有一个响应式网页,针对不同的屏幕尺寸采用不同的设计,我正在使用 @mediaquery 来更改我的设计。我想让用户能够更改设计以适应更小或更大的屏幕尺寸,即使屏幕尺寸没有改变。
是否可以在不改变屏幕大小的情况下使用 js 触发 @mediaquery ?
【问题讨论】:
标签: javascript css responsive-design media-queries
我有一个响应式网页,针对不同的屏幕尺寸采用不同的设计,我正在使用 @mediaquery 来更改我的设计。我想让用户能够更改设计以适应更小或更大的屏幕尺寸,即使屏幕尺寸没有改变。
是否可以在不改变屏幕大小的情况下使用 js 触发 @mediaquery ?
【问题讨论】:
标签: javascript css responsive-design media-queries
看看Enquire.js,一个用于响应 CSS 媒体查询的轻量级纯 JavaScript 库。
有了它,您可以根据屏幕的宽度将class 添加到body。然后,如果您根据主体是否具有某个类来组织您的 CSS。您可以使用 JS 根据用户的选择动态地将这些类添加到正文中。
你可以用另一个 JS 库做同样的事情:MediaClass,下面的 JS 行:
MediaClass("small-screen", "body(this-max-width: 480px)");
如果body 的宽度低于480px,则将small-screen 类添加到body 标签。现在你可以在你的网站上添加一些按钮来改变body的宽度,并且如果你以这种方式设置你的CSS类,你的页面布局将会改变,而不是“仅”基于屏幕大小。因此,对于这两种方法,您都需要稍微重构一下 CSS。
【讨论】: