- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
我们都知道我们应该将我们的 CSS 合并到一个文件中,但是是按站点还是按页面?我发现了两者的优缺点。
场景如下:
最好的部分是,在第一次点击后,一个文件将被缓存在每个页面上!不利之处在于,随着命名空间冲突机会的增加,选择器(类和 ID)的命名约定变得更加重要。您还需要一个系统,用于在不同的页面上对同一模块进行不同的样式设置。这会导致你的 CSS 中有额外的选择器,这对浏览器来说更有效。这可能会在 iPad 等没有那么多内存和处理能力的移动设备上引起问题。如果您将媒体查询用于响应式设计,那么在添加额外样式时,问题会更加复杂。
(我所说的页面模板是指一种布局,但有许多不同的页面,例如文章页面)在这种情况下,您失去了上述选择的大部分问题,但也失去了一些缓存优势。这种技术最糟糕的部分是,如果您在 2 个不同的页面模板上有相同的样式,那么它们将被下载两次,每个页面一次!例如,您的所有全局文件都会发生这种情况。 :(
因此,正如编程中常见的那样,这两种解决方案都不是完美的,但如果有人遇到过这个问题并找到了答案,我很乐意听到!特别是,如果您知道任何有助于解决解决方案 A 的选择器问题的技术。
最佳答案
当然,合并并缩小所有全局样式,例如您的站点模板、排版、表单等。我还会考虑将最重要和最常用的模块样式合并到全局样式表中,当然是您计划的样式表在主页或入口点上使用。
解决方案 B 不是一个好的解决方案:用户最终会为每个独特的布局/页面下载相同的内容,而您本可以从最后一个页面的缓存中加载部分内容。这种方法没有任何优势。
对于其余部分,我会将它们分开(并缩小)并根据需要单独加载它们。您可以使用任何 preloading Yahoo! 上描述的技术开发者网络的“加速网站的最佳实践”指南,用于预先加载用户的缓存:
Preload Components
By preloading components you can take advantageof the time the browser is idle and request components (like images,styles and scripts) you'll need in the future. This way when the uservisits the next page, you could have most of the components already inthe cache and your page will load much faster for the user. There are actually several types of preloading:
Unconditional preload - as soon as onload fires, you go ahead and fetch some extra components. Check google.com for an example of how asprite image is requested onload. This sprite image is not needed onthe google.com homepage, but it is needed on the consecutive searchresult page.
Conditional preload - based on a user action you make an educated guess where the user is headed next and preload accordingly. Onsearch.yahoo.com you can see how some extra components are requestedafter you start typing in the input box.
就冲突的选择器而言:合并所有文件并以任何其他方式执行应该不会有什么不同,这是您设计的问题。如果可能,让所有模块以某种方式“命名空间”,也许通过为特定于模块的类使用通用前缀,如 blog-header
或 storefront-title
。有一个概念叫"Object-oriented CSS"这可能会减少对大量冗余 CSS 和特定于模块的类名的需求,但这通常是在设计阶段完成的,而不是您可以“添加”到现有元素中的。
HTTP 请求越少越好,但您必须考虑文件大小以及用户行为和事件。入口页面的初始下载时间是最重要的,因此您不想因为以后不会用到的东西而陷入困境。如果您真的想处理这些数字,请尝试一些不同的方法并使用 Firebug 或 Chrome 的开发者工具分析您的网站。
关于css - 合并 CSS 文件 : per site or per page template?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11515154/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!