首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

webkit中BFC元素临近浮动元素时的边距bug

其实以webkit为核心的浏览器,包括但不限于Safari和Chrome,也有一个关于浮动和边距的bug,同样会造成布局错误。...这个BFC元素没有指定宽度值(或者指定width:auto) 当满足触发条件时,该BFC元素的另一侧的边距将不再受css控制(在webkit核心浏览器下),而是由你所指定的与浮动元素相同的边距决定,即使你在...css中明确指定另一侧的边距为0或任意值也没用。...具体来说,可以分为两种情况: 当BFC与浮动方向相同的边距小于或等于浮动元素占据的总宽度(width+margin+padding+border)时,BFC另一侧的边距等于所设定方向上的边距(下图前两种情况...); 当BFC与浮动方向相同的边距大于浮动元素占据的总宽度时,BFC另一侧的边距等于浮动元素占据的总宽度(下图第三种情况)。

1.7K50

css中的伪类与伪元素

伪类的效果可以通过添加一个实际的类来达到,而伪元素的效果则需要通过添加一个实际的元素才能达到,这也是为什么他们一个称为伪类,一个称为伪元素的原因。...伪类的种类 伪元素的种类 区别 这里用伪类 :first-child 和伪元素 :first-letter 来进行比较。...,然后定义这个类的样式。... 总结 伪元素和伪类之所以这么容易混淆,是因为他们的效果类似而且写法相仿,但实际上 css3 为了区分两者,已经明确规定了伪类用一个冒号来表示,而伪元素则用两个冒号来表示。...:Pseudo-classes::Pseudo-elements 但因为兼容性的问题,所以现在大部分还是统一的单冒号,但是抛开兼容性的问题,我们在书写时应该尽可能养成好习惯,区分两者。

2.5K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    CSS中的伪类和伪元素

    定义 伪类 CSS 伪类 是添加到选择器的关键字,指定要选择的元素的特殊状态。 例如,:hover 可被用于在用户将鼠标悬停在按钮上时改变按钮的颜色。.../* 所有用户指针悬停的按钮 */ button:hover { color: blue; } 伪类存在的意义是为了通过选择器,格式化DOM树以外的信息以及不能被常规CSS选择器获取到的信息。...这个时候,被修饰的 元素依然处于文档树中。... p:first-letter { font-size: 5em; } 从上述例子中可以看出,伪类的操作对象是文档树中已有的元素,而伪元素则创建了一个文档数外的元素。...总结 1.伪类本质上是为了弥补常规CSS选择器的不足,以便获取到更多信息; 2.伪元素本质上是创建了一个有内容的虚拟容器; 3.CSS3中伪类和伪元素的语法不同; 4.可以同时使用多个伪类,而只能同时使用一个伪元素

    2.8K10

    盘点Arrays工具类中复制元素和填充元素的常用方法

    一、Arrays工具类 在java的util包中提供了一个Arrays工具类用来操作数组的,它提供了许多的静态方法,例如数组所有元素进行排序,按从小到大的顺序、查找元素等。...在程序开发中,经常需要在不破坏原来数组的情况下使用数组的部分元素,可以使用Arrays的copyOfRange(int[] original,int from,int to)方法把数组指定范围元素复制到一个新的数组中...三、使用Arrays的fill(Object []a,Objcet val)方法填充元素 1.在程序开发中,经常需要使用一个值替换数组中所有的值,可以使用Arrays工具类中的fill(Object [...,经常需要把数组的元素以字符串形式进行输出,在Arrays工具类提供了toString(int[] arr)方法,此方法并不是对Obejct类toString方法进行重写,它是返回数组中字符串。...: 五、总结 本文主要介绍了Arrays工具类的导包、Arrays的常用方法例如copyOfRange(int[] original,int from,int to)方法复制元素、fill(Object

    77930

    盘点Vector类、Vector类向量中添加元素常用方法、Vector类向量中删除元素对象的常用方法

    一、Vector类 1.在c和c++中的动态数组一般是用指针来实现的,Vector类是实现List接口,java提供了很多的类库来方便开发人员来使用,Vector类是其中之一。...类向量中添加元素常用方法 1.void addElement(Object obj)在集合的末尾添加一个元素,不管它是什么类型都会把它的toString()返回值加进去。...三、Vector类向量中删除元素对象的常用方法 1.void removeAllElement( )删除集合中的所有元素,并将把大小设置为0。...四、总结 本文主要介绍了Vector类、Vector类向量中添加元素常用方法、Vector类向量中删除元素对象的常用方法。 Vector类是实现动态数组的功能,介绍它的4种构造方法。...Vector类向量中删除元素对象的常用方法有removeAllElement( )删除集合中的所有元素,并将把大小设置为0、removeElement(Object obj)从向量中删除第一个出现的参数

    1.7K40

    CSS 下拉菜单与 focus

    focus 伪类 focus 伪类 :focus 表示被点击、触摸或 tab 选中的元素,笼统地说就是「获得焦点」的元素。 当初实现这个需求的时候同样考虑过采用 :hover 或者 :active。...hover 算是比较熟悉的了,在 PC 上鼠标悬停于此时 :hover 伪类生效,比如 链接 的样式正是采用 :hover 实现鼠标经过时反馈,以提示用户这是可点击的。...桌面端 移动端 focus 持续到失去焦点 松开时进入,持续到失去焦点 hover 悬停期间 按下时进入,持续到失去焦点 active 单击按下期间 触摸按下期间 综合来看,focus 是最合适的。...上面表述中的「一般」表示这其实是有例外的,比如点击其他默认可聚焦的元素(如 、button 等等)就会使新聚焦的元素顶替原聚焦的元素让先前的元素失焦。...PC iOS Android focus 持续到失去焦点 默认不可用 松开时进入,持续到失去焦点 hover 悬停期间 按下时进入,持续到失去焦点 按下时进入,持续到失去焦点 active 单击按下期间

    5.6K20

    【Java 虚拟机原理】Java 类中的类加载初始化细节 ( 只使用类中的常量时加载类不会执行到 ‘初始化‘ 阶段 )

    , 解析 ) -> 初始化 这个完整的流程 ; 如 : 如果是 public final static 修饰的常量值 , 在编译阶段 , 就会将该值放到常量池中 ; 在类加载的过程中 , 只要执行到...加载 -> 连接 ( 验证 , 准备 , 解析 ) 阶段 , 就可以完成常量池的初始化 , 即使没有执行 初始化 这个步骤 , 也不影响使用类中的常量值 ; 在 连接 的 准备 阶段 , 为 普通 的...; 二、常量加载示例 ---- 类加载时 , 如果只用到了类中的常量 , 则只进行 " 加载 -> 连接 ( 验证 , 准备 , 解析 ) " 两个过程 : public class Student...18 三、数组加载示例 ---- 对数组进行创建操作 , 如创建了一个对象数组 , 此时不会加载该对象对应的类 , 只会为其在内存分配空间 ; 创建数组时 , 触发的是 Student...[] 数组类型的 类加载初始化 , 但是不会触发 Student 类的初始化操作 ; 如果调用数组中的元素时 , 就需要初始化 Student 类 ; Student 类 : public class

    3.6K20

    :has 语法,终于可以用了

    以下是一些可能的示例: 在应用的某些页面上,你可能想要更改 body 元素的全局字体大小或背景颜色。在引入 :has 伪类之前,我们通常需要通过后端根据页面类型切换某些 HTML 类。...与其他伪类组合 当在子元素上悬停时,改变容器的样式听起来相当酷,不是吗? 我们可以将 has 与 hover 结合使用来实现这一点。...例如,如果我们希望在容器中的任何链接悬停时,都给链接元素添加边框,可以使用以下代码: .container:has(a:hover) { border: 2px solid pink; } 浏览器支持...截至 2023 年 6 月,:has 伪类仅在 Firefox 中缺失。...结论 :has 伪类是 CSS 选择器工具中的一个强大补充。它允许你根据元素内容选择元素,从而简化了许多情况,使你的代码更易于维护。通过使用组合器,你可以进一步细化选择并实现更高级的效果。

    23720

    按钮样式的正确方式

    CSS组件是一种风格或样式集合,我们可以使用类来应用,通常在几种不同类型的HTML元素之上。 您可能熟悉Bootstrap或Foundation等CSS框架中的这个概念。...悬停(hover),焦点(focus)和活动(active)样式 很酷,你的按钮看起来不错,但是...用户将与它进行交互,并且当按钮的状态改变时,他们需要视觉反馈。...处理focus样式 还有一个棘手的问题。 在多个浏览器中,当您单击链接或按钮时,将应用两个伪类: :active :focus 一旦停止按下鼠标按钮或触控板,“active”伪类就会停止应用。...Safari(11.1)似乎更聪明并避免了这个问题。 我们可以使用新的: :focus-visible伪类(草稿规范)来解决此问题。...它在整个页面上运行,并且仅在使用键盘时才将焦点可见的类设置为接收焦点的元素。

    3.7K20

    CSS 1.0~3.0选择器(上)

    星号选择器将匹配页面里的每一个元素。很多开发者使用这个技巧将外边距和内边距重置为零。虽然在快速测试时这确实很好用,但建议永远不要使用它,它会给浏览器带来大量不必要的负担。...当你想给一组元素应用样式的时候可以使用类选择符,当需要给特殊元素应用样式的时候才使用id。...最初伪类选择器只能应用于a标签,从IE7之后,其他浏览器也支持其他标签的伪类效果了。可以把伪类理解为一种标签的状态。如,a:hover表示的就是当鼠标悬停在a标签上时的效果。...上面的例子,仅每一个ul之后的第一个类名为h5course元素的文本为红色。...它会选择,我们上面例子中更在ul后面的任何div元素。

    84350

    【Java 进阶篇】JQuery 事件绑定之事件切换:让页面动起来

    使用 toggle 切换多个事件 toggle 方法不仅可以切换多个处理函数,还可以切换多个事件类型。这意味着你可以在同一个元素上,同时切换点击事件、悬停事件等多种事件。 的提示框,第二次点击弹出 “第二次点击!”,悬停时弹出 “悬停事件!”。 利用 data 存储状态 在实际项目中,有时我们需要在不同的事件处理函数之间共享一些状态。...每次点击按钮时,根据当前状态不同,会弹出不同的提示框,并修改状态值。另外,我们通过点击事件展示了如何获取当前状态。 切换 CSS 类 在页面交互中,改变样式是常见的需求之一。...> 标签中定义了一个 CSS 类 .active,并使用 toggleClass 方法在按钮点击时切换这个类。...点击 “上一张” 和 “下一张” 按钮时,通过事件切换实现了图片的切换效果。这展示了事件切换在实际项目中的强大应用。 小结 通过本文的学习,我们深入了解了 JQuery 中的事件切换。

    17620

    这30个CSS选择器,你必须熟记(中)

    但是有一种解决方案,我们可以使用自定义属性,我们可以在图片的链接标签中添加data-filetype属性,如下所示: <a href="path/to/image.jpg" data-filetype=...]:checked { border: 1px solid black; } 是不是很简单,这个伪类可以用来定义选中(checked)的元素,比如单选按钮(radio)或多选按钮(checkbox)。...浏览器兼容性: IE9+ Firefox Chrome Safari Opera 18、X::after 后置内容元素选择器 伪元素前置元素选择器::before 和 后置内容元素选择器 :: after...Opera 19 X:hover 鼠标悬停状态选择器 这个选择器,用的频率也比较高,想必大家都清楚,正是的叫法应该是用户操作交互伪类:user action pseudo class,比如想给用户鼠标悬停的元素加上样式...浏览器兼容性: IE6+ (只能用于链接标签) Firefox Chrome Safari Opera 20 X:not(selector) 否定伪类选择器 前面我们学的都是肯定选择器,如果反过来就是否定选择器

    63900
    领券