`
wyzxzws
  • 浏览: 393337 次
  • 性别: Icon_minigender_1
  • 来自: dazhou
社区版块
存档分类
最新评论

JavaScript 清理浮动

阅读更多

转自:http://www.chinaz.com/design/2009/0527/77381.shtml

问题:JavaScript 清理浮动

解决方案:

      早段时间特别的忙,忙到站点一直没有更新;但是这段时间也是偷偷的做了一些的工作,比如对站点的JS进行了压缩,构思labs分站以及聚合分站。

而此段时间最烦的是森林群里面的一群人每天上班都在吵,然后我就每次都装嫩的在里面问:“各位高手,劳烦请问一下;清除浮动怎么弄?”

清除浮动一个凡是做页面的人都会遇到的一个东西,但是是否大家都能够清楚的知道,全方位的了解呢?于是一闲下来了马上写了这样的一篇文章,不能讲面面俱到,然而基本能将我所知道的倾囊相授了。

我们粗略的一起来看看清除浮动的办法一共有多少个。对应的DEMO

1. 采用伪类:after进行后续空制的高度位零的伪类层清除

2. 采用CSS overflow:auto的方式撑高

3. 采用CSS overflow:hidden的方式产生怪异适应

4. 采用display:table将对象变成table形式

5. 采用div标签,以及css的clear属性

6. 采用br标签,以及css的clear属性

7. 采用br标签,以及其自身HTML的clear属性

粗略的看,他们都能将问题解决;然而他们另外一方面又有着各自的利弊。(一一对应)

1. 优点结构语义化完全正确,不会产生其余的怪异问题。

缺点复用方式不当容易造成代码量急剧增大。

建议最外层轻浮动时使用,或清晰模块化复用方式的人使用。

2. 优点结构语义化完全正确,代码量极少。

缺点多个嵌套后,点击最外层的轻浮动框会遭成最外层至最内层内容全选(FF);或者在mouseover造成宽度改变时会出现最外层模块有滚动条(IE)。

建议内个模块使用,请勿嵌套。

3. 优点结构语义化完全正确,代码量极少。

缺点内容增多时候极易不会自动换行而内容被隐藏掉。

建议宽度固定时使用,请勿嵌套。

4. 优点结构语义化完全正确,代码量极少。

缺点盒模型属性已经改变,可想而知奇异事件自然多得你数都数不到。

建议如果你不想改Bug改死你的话,最好不要使用;不过可以作为alpha版本当中临时性的忽悠下测试。

5. 优点代码量极少,复用性极高。

缺点完全不能完美的适应语义化,不利于改版以及需求变更。

建议初学者使用,可以让你快速的解决浮动问题。

6. 优点语义化程度比第5种情况要更优;代码量极少,复用性极高。

缺点语义化依旧不完美,不利于改版以及需求变更。

建议初学者使用,可以让你快速的解决浮动问题。

7. 优点语义化程度比第5、6种情况要更优;代码量最少,复用性极高。

缺点语义化依旧不完美,不利于改版以及需求变更。

建议引导初学者思维升级时使用,让其明白与其用classname来控制一种表现,倒不如回归到WEB1.0的时代的网页直接用html属性来控制表现,毕竟后者的代码量更少。

分享到:
评论

相关推荐

    Js浮动页面顶部或鼠标点击处弹出提示层

    总之,"Js浮动页面顶部或鼠标点击处弹出提示层"涉及到了JavaScript的基本操作、DOM操作、事件处理、CSS样式以及动画效果。掌握这些知识点,不仅可以创建出用户友好的提示层,还能为其他复杂的Web交互打下坚实的基础...

    JavaScript,HTML制作简易图形化界面计算器

    例如,可以使用Flexbox或Grid布局来实现按钮的网格布局,或者通过浮动元素来实现传统的横向排列。 3. **JavaScript**: JavaScript是实现计算器功能的核心,它负责处理用户与界面的交互,执行计算逻辑。以下是一些...

    js div浮动层拖拽效果代码.zip

    可能还会有一些清理工作,例如取消事件监听以防止不必要的行为。 6. **优化用户体验**:可能还包括了防止默认文本选中、阻止冒泡等优化措施,确保拖拽过程顺畅。 这个代码实例对于学习JavaScript事件处理和DOM操作...

    使用angularjs实现浮动表单效果.zip

    4. **实现浮动效果**:浮动表单效果通常通过CSS和JavaScript配合实现。我们可以使用AngularJS的`ng-class`指令根据滚动位置动态添加或移除CSS类。这里我们将使用一个名为`fixed-form`的CSS类来实现浮动效果。 ```...

    jQuery右下角浮动意见反馈表.zip

    jQuery右下角浮动意见反馈表是一种常见的用户交互设计,它利用JavaScript库jQuery实现了一种便捷的用户反馈机制。这种设计通常出现在网页的右下角,当用户点击浮动图标时,会弹出一个反馈表单,允许用户即时提交他们...

    javascript实现仿百度图片的瀑布流加载效果_.docx

    这种结构允许图片以浮动的方式排列,形成多列布局。CSS 样式定义了 `.pin` 和 `.box` 的边界、内边距和阴影效果,以提供美观的视觉感受。图片的宽度固定,高度自适应,确保了图片保持正确的宽高比。 接下来,我们来...

    弹出登录框的JQuery弹出浮动层

    在网页设计中,用户交互是至关重要的,而弹出登录框是常见的用户界面元素之一,特别是在需要用户验证身份或...在实际开发中,还应注意安全性,例如对用户输入进行适当的清理和验证,以及使用HTTPS保护传输的敏感信息。

    CSS兼容IE和Firefox的技巧集合

    #### 技巧8:清理浮动和自适应高度 对于包含浮动元素的容器,如果不进行适当的清理,可能导致容器高度计算不准确,影响页面布局。可以使用以下方法清理浮动: - **使用`clear: both;`**:在需要重新开始新的一行的...

    js实现的dialog

    同时,可能需要利用 CSS 盒模型理解元素的布局和定位,例如使用 `position: absolute` 或 `position: fixed` 来实现对话框的浮动效果。 4. **事件处理** Dialog 通常需要响应用户的点击、关闭按钮等交互事件。因此...

    web前端面试指南和高频考题解析,大厂员工整理,pdf和md版本都

    - 清理浮动 - 定位`position` - 文档流概念 - 定位分类 - fixed 定位特点 - 绝对定位计算方式 - `flex`布局 - 如何实现居中对齐? - 理解语义化 - CSS3 动画 - 重绘和回流,变量类型 - JS 的数据类型分类和...

    javascript实现简单的页面右下角提示信息框

    9. 清理和关闭逻辑 定义了一个函数_notice()用于关闭提示信息框,并清除定时器,以避免内存泄漏。 10. 多文件组织 尽管文档示例中包含了HTML和JavaScript代码在同一个文件中,但在实际项目中,通常会将HTML、CSS和...

    前端标准在各浏览器中的差异

    不过,在IE8的标准文档模式下,触发了`hasLayout`的元素不再具有清理浮动的功能,这使得其行为更接近于其他浏览器的标准`BFC`行为。 2. **元素间的位置关系** - 触发`hasLayout`的元素和创建了`BFC`的元素都不会与...

    基于JavaScript的三维地图程序(仿e都市gis)

    2.清理建筑信息显示页和公交信息页多余数据 2009-10-22 1.增加小沙盘拖动类(鹰眼视图) BirdEye.js 完成小沙盘到地图的同步,同步方法:检测mouseup事件触发->修改url->request->计算坐标->同步行为 2.增加小沙盘...

    photofloat:通过静态 JSON 和动态 JavaScript 完成的照片库。 更新供个人使用和视频支持

    照片浮动 20200312 从导入 个人使用修改如下 2020 年 12 月 20 日 对于扫描仪 - 减少由扫描仪生成的拇指大小的数量,忽略 iPhone AAE 文件,使用媒体信息作为视频元数据,如果元数据显示,则旋转图像,不要将拇指...

    瀑布流 jQuery html

    浮动布局简单但可能需要清理浮动;定位布局更灵活,可以精确控制元素的位置。 6. **插件应用**:jQuery有许多现成的瀑布流插件,如masonry.js、isotope.js等,它们已经实现了复杂的计算和布局逻辑,可以直接应用于...

    JavaScript实现星星等级评价功能

    4. CSS样式设计中,通过设置的样式来确定星星显示的位置和大小,例如使用浮动属性(float:left)和宽度(width:100px)来控制布局。隐藏提示文本时,将对应的元素的display属性设置为none。当鼠标悬停在星星上或点击...

    fck配置文件详细解释与翻译

    - **作用**:启用后编辑器能够自动检测是否从Word中复制的内容,并进行相应的格式清理。 - **建议**:保持为`true`。 28. **ShowDropDialog** ```javascript FCKConfig.ShowDropDialog = true; ``` - **...

    CKEDITOR配置

    2. **浮动元素层级**:设置编辑器浮动工具栏的z-index值。 ```javascript config.baseFloatZIndex = 10000; ``` 3. **基础链接**:设置编辑器内元素的基本href属性。 ```javascript config.baseHref = ''; ```...

    js实现弹出div任意拖拽

    // 可能需要清除一些临时变量或执行其他清理操作 }); ``` 5. **显示和隐藏div**: 为了实现“弹出”效果,你可以添加一个按钮,点击时显示div,再次点击时隐藏。 ```javascript var button = document....

    糟糕的css用法 1

    5. **浮动布局**:在现代布局方法(如Flexbox和Grid)出现后,过度依赖浮动可能导致布局问题和清理浮动的额外代码。 6. **使用!important**:频繁使用`!important`强制应用样式会破坏层叠规则,使得代码难以管理。...

Global site tag (gtag.js) - Google Analytics