什么时候清除浮动,什么时候使用浮动,那首先就要明白浮动的作用:
CSS基础必学列表
CSS width宽度
CSS height高度
CSS border边框
CSS background背景
CSS sprites背景拼合
CSS float浮动
CSS margin外边距
CSS padding内边距
CSS color字体颜色
CSS font-size字体大小
CSS font-family字体
CSS font-weight字体加粗
CSS display显示与隐藏
CSS overflow隐藏与滚动条
CSS position定位
CSS text-align内容水平位置
CSS text-indent缩进
CSS text-decoration下划线
CSS clear清除浮动
CSS cursor鼠标手势光标
CSS font文本
CSS font-style文本斜体
CSS font-variant缩小大写字母
CSS id CSS class
left right top bottom
css letter-spacing字间距
CSS line-height行高
css min-width最小宽度
css max-width最大宽度
CSS min-height最小高度
css max-height最大高度
CSS text-transform英文大小写
css text-overflow省略号
CSS white-space不换行
css z-index重叠顺序
CSS 前花括号星号*
CSS 缩写
div与span区别及用法
CSS是什么
DIV+CSS是什么
CSS 注释
CSS 指针
CSS 文本排版
div css float浮动用法(left right)
div+css中float认识及css float用法,DIV CSS float浮动知识用法与float浮动教程篇
Css样式的float浮动属性,用于设置标签对象(如:<div>标签盒子、<span>标签、<a>标签、<em>标签等html标签)的浮动布局,浮动也就是我们所说标签对象浮动居左靠左(float:left)和浮动居右靠右(float:right)。
float是什么意思?
float是浮动,翻译成中文也是浮动意思。进入对应css手册中float手册了解float基本信息。
float的作用
通过css定义float(浮动)让div样式层块,向左或向右(靠)浮动。
float浮动教程目录
float语法
float应用与用法
float浮动案例
css浮动其他应用
css浮动总结
一、float语法 - TOP
Float常跟属性值left、right、none
Float:none 不使用浮动
Float:left 靠左浮动
Float:right 靠右浮动
float语法:
float : none | left |right
参数值:
none : 对象不浮动
left : 对象浮在左边
right : 对象浮在右边
Float浮动结构分析图
接下来我们来通过一个div+css实例讲解float使用技巧。
二、float应用与用法 - TOP
Float浮动用于设置对象靠左与靠右浮动样式,可以实现我们所需要的让DIV、SPAN等标签居左居右浮动。
简单使用语法
div{float:left} /* css注释:设置div对象浮动靠左(left) */ div{float:right} /* css注释:设置div对象浮动靠右(right) */三、css float浮动案例 - TOP
我们设置一个盒子里,一个靠右、一个靠左浮动2个盒子,为了直观看到css浮动布局效果,我们对两个盒子设置一定宽度、高度和边框。
1、主要的html代码片段:
<div class="divcss5"> <div class="divcss5_left">布局靠左浮动</div> <div class="divcss5_right">布局靠右浮动</div> <div class="clear"></div><!-- html注释:清除float产生浮动 --> </div>2、css代码片段:
.divcss5{ width:400pxpadding:10pxborder:1px solid #F00} .divcss5_left{ float:leftwidth:150pxborder:1px solid #00Fheight:50px} .divcss5_right{ float:rightwidth:150pxborder:1px solid #00Fheight:50px} .clear{ clear:both}3、效果截图
.这只是一个案例,使用与否,视情况而定
早期 Web 开发时有一种说法 请求太多会影响页面性能 如果您知道有什么技巧可以减少网页所触发的 HTTP 请求数 尽可能使用这些方法吧 随着网页中越来越多地填充了丰富的视觉内容 下载 CSS 脚本和图像等相关资源所需的成本显著攀升 毫无疑问 在大多数情况下 这些资源可由浏览器缓存到本地 但保持最初占用的空间会是非常困难的 此外 减少请求的数量和大小也有助于确保低带宽占用 降低延迟以及延长电池寿命 在移动浏览中 这些都是关键因素 解决这些问题最普遍接受的方法包含了两个操作的结合 捆绑和缩小
在本文中 我将从 ASP NET MVC 提供的软件工具的独有角度出发 介绍 CSS 文件的捆绑和缩小 这一话题延续了我之前的专栏 在 ASP NET MVC 中创建为移动设备优化的视图 第 部分 使用 WURFL (msd/magazine/dn )
捆绑和缩小的基础知识捆绑是将多个不同资源汇总成为单个可下载资源的过程 例如 一个捆绑中可能包括多个 JavaScript 或 CSS 文件 您可以通过向某个特定端点发送单个 HTTP 请求 将这些内容下载到本地计算机 另一方面 缩小是对资源应用的转换 具体而言 缩小是从基于文本的资源中删除所有不必要字符的过程 这一过程不会改变预期功能 这意味着缩短标识符 对函数使用别名以及删除注释 空格字符和新行 一般来说 添加这些所删除字符通常是为了提升可读性 但是会占用空间并且实际不起到任何功能用途
捆绑和缩小可同时应用 但过程彼此独立 根据需要 您可以决定只创建捆绑或者只缩小单独文件 不过 通常在生产站点上 没有理由不捆绑和缩小所有 CSS 及 JavaScript 文件 当然也有一些例外 诸如 jQuery 等公共资源可能会位于众所周知的内容交付网络 (CDN) 上 但是 在调试时这就是完全不同的情况 经过缩小或者捆绑的资源非常难于阅读和单步执行 因此您可能不希望启用捆绑和调试
许多框架提供了捆绑和缩小服务 其可扩展性水平略有差别 并且采用了不同的功能集 大多数情况下 它们提供了相同的功能 因此选择哪一种纯属个人偏好 如果您正在编写 ASP NET MVC 应用程序 则捆绑和缩小的选择自然就是 Microsoft ASP NET Web Optimization Framework 该框架在 NuGet 程序包 (bit ly/ bS u B) 中提供 如 图 中所示
图 安装 Microsoft ASP NET Web Optimization Framework
使用 CSS 捆绑就我认为 了解 CSS 捆绑机制的最佳方法是从一个真正的空 ASP NET MVC 项目开始着手 这意味着使用空项目模板来创建新项目并删除未使用的引用和文件 接下来 假定您添加链接多个 CSS 文件的布局文件
<link rel="stylesheet" href="@Url Content("~/content/styles/site css")"/>
如果使用 Fiddler 或 Internet Explorer 开发者工具显示页面并监视其网络活动 您会发现有两个并行下载 这是默认行为
请注意 在 ASP NET MVC 中 您可以使用新的 Styles Render 工具 以紧凑得多的方式重写以前的标记
@Styles Render( "~/content/styles/site css" "~/content/styles/site more css")
位于 System Web Optimization 下的 Styles 类的功能远比第一眼看到的要强大 Styles Render 方法也支持捆绑 这意味着该方法有多个重载 其中一个接受 CSS URL 数组 不过 另一个重载接受以前创建的捆绑的名称(稍后将进一步介绍) 在本例中 它发出单个 <link>元素并使其指向自动生成的 URL 该 URL 返回经过捆绑或缩小的所有样式表 创建 CSS 捆绑
通常在 global asax 中以编程方式创建捆绑 按照配置代码的 ASP NET MVC 模式 您可能需要在 App_Start 文件夹下创建 BundleConfig 类 并在其外部公开静态初始化方法
BundleConfig RegisterBundles(BundleTable Bundles)
一个 CSS 捆绑只是一个样式表集合 此处是将上述两个 CSS 文件分组到单个下载中的代码
public class BundleConfig { public static void RegisterBundles(BundleCollection bundles) { // Register bundles first bundles Add(new Bundle("~/mycss") Include( "~/content/styles/site css" "~/content/styles/site more css")) BundleTable EnableOptimizations = true } }
创建新 Bundle 类 将用于从视图或网页中引用捆绑的虚拟路径传递到构造函数中 也可以在以后通过 Path 属性来设置虚拟路径 要将 CSS 文件与捆绑关联 需要使用 Include 方法 此方法接受表示虚拟路径的字符串数组 您可以按上例中所示明确指示 CSS 文件 也可以按此处所示指示模式字符串
bundles Add(new Bundle("~/mycss") Include("~/content/styles/* css")
Bundle 类还有 IncludeDirectory 方法 该方法可用于指示给定虚拟目录的路径 还可使用模式匹配字符串和布尔标志来启用对子目录的搜索
在之前代码片段中看到的在 BundleTable 类上设置的 EnableOptimization 布尔属性 表示需要显式启用捆绑 如果未以编程方式启用 则捆绑无法正常工作 如前所述 捆绑是一种优化方式 因此当站点是生产站点时通常很有意义 EnableOptimization 属性是一种设置捆绑的简便方法 应在生产中使用 不过以调试模式编译站点时应该禁用它 您甚至可以使用以下代码
if (!DEBUG) { BundleTable EnableOptimizations = true }
更多高级捆绑功能
就 CSS 捆绑而言 除了缩小之外 没有多少其他相关内容 不过 BundleCollection 类是一个通用类 也可用于捆绑脚本文件 特别是 BundleCollection 类有几个功能值得注意 虽然它们在捆绑脚本文件而非 CSS 文件时最有用
第一个功能是排序 BundleCollection 类有一个名为 Orderer 的属性 其类型为 IBundleOrderer 正如您所见 orderer 是一个负责确定您希望在捆绑文件以供下载时使用的实际顺序的组件 默认 orderer 是 DefaultBundleOrderer 类 此类按照 BundleCollection 属性 FileSetOrderLis 的设置所得到的顺序来捆绑文件 FileSetOrderList 设计作为 BundleFileSetOrdering 类的集合 这些类中的每一个都定义文件的模式(例如 jquery *) BundleFileSetOrdering 类添加到 FileSetOrderList 的顺序确定了文件的实际顺序 例如 在使用默认配置时 所有 jQuery 文件始终捆绑在 Modernizr 文件之前
DefaultBundleOrderer 类对 CSS 文件的影响则有限得多 如果您的网站中有名为 reset css 或 normalize css 的文件 则这些文件将自动捆绑在您的任意 CSS 文件之前 并且 reset css 始终要优先于 normalize css 如果您不熟悉重置/规范化样式表 那么这些样式表可以为所有 HTML 元素提供标准样式属性集 这样您的页面不会继承特定于浏览器的设置 例如字体 字号和边距 虽然这两种类型的 CSS 文件都有一些推荐的内容 但实际内容取决于您 如果您的项目中有这些名称的文件 则 ASP NET MVC 会通过额外方式确保这些文件捆绑在所有其他内容之前 如果您希望覆盖默认 orderer 并忽略预定义的捆绑文件集排序 可以使用两个选项 首先 可以针对每次捆绑创建自定义 orderer 下面是一个简单地忽略预定义排序的示例
public class PoorManOrderer : IBundleOrderer { public IEnumerable<FileInfo>OrderFiles( BundleContext context IEnumerable<FileInfo>files) { return files } }
您可以按下面所示的方式使用
var bundle = new Bundle("~/mycss") bundle Orderer = new PoorManOrderer()
此外 可以使用下列代码重置所有排序
bundles ResetAll()
在本例中 使用默认 orderer 的效果与之前穷人 orderer 的效果相同 不过请注意 ResetAll 还将重置脚本排序
另一个更高级的功能是忽略列表 它通过 BundleCollection 类的 IgnoreList 属性 针对已选中包含的文件(但实际上应该忽略)定义模式匹配字符串 在 ASP NET MVC 中实现捆绑的主要优势是可以在单次调用中获取文件夹中的所有 JavaScript 文件 (* js) 但是 有可能 * js 还会匹配您不希望下载的文件 例如 vsdoc js 文件 IgnoreList 的默认配置考虑到了大多数常见情况 同时也允许自定义 运行中的 CSS 捆绑
CSS 捆绑是一种强大的优化功能 但是 在实际过程中是如何工作的? 请考虑使用以下代码
var bundle = new Bundle("~/mycss") bundle Include("~/content/styles/* css") bundles Add(bundle)
图 中显示了对应的 HTTP 通信
图 第二个请求是有多个 CSS 文件的捆绑
第一个请求针对是主页 第二个请求不指向特定 CSS 文件 而是引用了包含 content/styles 文件夹中所有 CSS 文件的捆绑(请参阅 图 )
图 捆绑 CSS 示例
添加缩小功能只有在将多个资源打包到一起以便通过单个下载捕获并进行缓存时 才需要使用 Bundle 类
正如 图 中的代码所示 下载的内容中添加了空白和新行字符以便于阅读 不过 浏览器并不关心可读性 对于浏览器来说 图 中的 CSS 代码完全等同于以下缩小代码中的字符串
body{font family:&# segoe ui&# font size: emmargin: px} body{background color:# color:# d cc}
对于我在此例中使用的简单 CSS 缩小功能可能并没有起到多大作用 但是 对于具有大量样式表的商务站点 缩小 CSS 就非常有意义
如何添加缩小功能? 非常简单 就像使用 StyleBundle 替换 Bundle 类一样 StyleBundle 出奇的简单 它继承自 Bundle 仅由不同的构造函数组成
public StyleBundle(string virtualPath) : base(virtualPath new IBundleTransform[] { new CssMinify() }) { }
Bundle 类具有可接受 IBundleTransform 对象列表的构造函数 这些转换将逐个应用于内容 StyleBundle 类仅添加 CssMinify 转换器 CssMinify 是 ASP NET MVC (和更高版本)的默认缩小器 基于 WebGrease 优化工具 (webgreas) 无需赘言 如果您希望切换到不同缩小器 则需要做的就是获取类(IBundleTransform 的实现)并通过类 Bundle 的构造函数进行传递 再也不用找托辞
随 ASP NET MVC 捆绑的 Web Optimization Framework 添加了少量功能 不过 这些都是非常有用的功能 这就没有任何理由不去缩小和捆绑资源 到目前为止 可能的托辞都是 ASP NET 平台中缺少原生支持 ASP NET MVC 和更高的版本中不再是这种情况
lishixinzhi/Article/program/Web/201405/30992