- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个只支持现代浏览器的网站。
我喜欢 bootstrap popover 的美学,但真的不喜欢它如何依赖 jquery 小部件和 javascript 来定位箭头。我理解为什么它曾经是必需的,但实际上不再需要了。
我想看看能不能得到看起来像 bootstrap popover with a side arrow 的东西使用各种受支持的 css3 技术创建(因此 flexbox 等都在发挥作用)。
这是我的 (jade) html。我会有一个包含一些内容的段落,然后是一个输入,该输入在右侧有一个弹出窗口,箭头指向它,然后是更多内容。
p some content.
.popout-container
input
aside.popout
.flex-container
i.arrow
.container
p Here is a popout
p It contains some text
p some more content.
这是我用来非常接近的样式表(较少)(当然实际上我会有一个 svg 图像作为箭头而不是使用 :after content
.popout-container {
white-space: nowrap;
&>* {
display: inline-block;
}
}
.popout {
.flex-container {
display: flex;
.container {
border: 1px solid blue;
border-radius: 5px;
background-color: white;
box-shadow: 5px 5px #ccc;
padding: .5em;
}
.arrow {
display: flex;
flex-direction: column;
&:after {
content: "<";
margin: auto;
background-color: white;
margin-right: -1px;
z-index: 100;
}
}
}
}
我遇到的大问题是我正在使用 white-space: nowrap
将弹出窗口定位到输入的一侧。这正确对齐了箭头,但增加了 .popout-container
,在上面的内容和输入之间创建了空间。此外,在 html 文档中跟在与弹出窗口相同位置的任何元素都出现在它的顶部(因为它不是绝对定位的)。
I can instead use flexbox to position弹出窗口到输入的一侧。使用 margin: auto
箭头正确对齐,但现在 popover 完全包含在与内容相同的框中。
popover 确实需要 position: absolute
但即使使用 flexbox this breaks the popover out of it container and no longer aligns the arrow .
有没有办法得到这种效果?我怀疑解决方案是使用 css calc
函数和 position: absolute
但我不太明白。
例如using flexbox, position absolute and repositioning popover with margin-top: calc(-50% + 8px)
在特定窗口大小的 chrome 上看起来相当不错,但在 firefox 和不同的窗口大小下需要不同的值(为什么!?),并且在 IE 11 上根本不对齐箭头(同样,为什么?IE11 支持 display : flex
和 margin: auto
就好了)。
最佳答案
视觉部分非常简单,无需求助于 SVG。这是not too hard使用 CSS :before 来制作一个好看的箭头。例如:
&:before {
content: '';
position: absolute;
width: 14px;
height: 14px;
background: inherit;
bottom: -8px;
left: calc(unquote('50% - 7px'));
transform: rotate(45deg);
}
如您所说,更难的部分是定位,尤其是垂直定位。我怀疑这是引导脚本所涉及的大部分内容。
我发现 calc() 是两个方向定位的最佳工具,尽管与 SASS 或 LESS 一起使用有点痛苦,因为 calc() 也是内置的,你必须然后包装使用 unquote('')
的等式。
关于css - 在没有 javascript 的情况下模拟 Bootstrap 侧弹出窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23420617/
我连续有 11 个图像,如果鼠标悬停在其中一个图像上,我希望弹出一个弹出窗口。所以每 11 个图像都有不同的弹出窗口。我已经有一些代码可以执行此操作,但它仅适用于第一张图像。 代码:index.htm
是否可以从 NSColorWell 制作一个 NSColorPanel“弹出”,几乎像一个弹出菜单? 我不喜欢它作为调色板的实现方式,因为有时它与哪个 NSColorWell 关联并不明显。 谢谢!
我正在考虑一个想法,基本上我想要一个带有 NSPopoverController 的 NSStatusItem 。我读到了人们遇到的所有问题,但我只是想尝试一下。现在有干净的方法吗?我见过的所有版本都
如何获取 JS 打开的弹出窗口的 url。这是我的代码: var _url = 'someurlhere'; var popupwindow = window.open(_url, "Popu
我正在设计一个网页,我希望当用户单击链接时,弹出窗口(新窗口)将打开一个链接网页。我的代码如下所示 function win(add,w,h) { window.open(add,"","widt
我正在寻找 C 中的简单堆栈实现,并找到了类似的东西: void pop(struct stack **top) { struct stack *temp; temp = malloc(s
我正在尝试使用 paypal 实现登录,我有 2 个不同的主机域 1- www.example.com 2- www.example.de 对于 paypal,我需要为此目的选择一个返回 URL,我选
我正在尝试找出如何复制此处显示的“弹出式” View 动画:https://imgur.com/a/irFqdiP .我正在使用当前代码来显示我的 viewController,但目前只有一个淡入淡出
有谁知道在 Windows 2000 或更高版本上以编程方式关闭 CD 托盘的方法?打开 CD 托盘存在,但我似乎无法关闭它,尤其是在 W2k 下。 如果可能的话,我特别想从批处理文件中寻找一种方法来
当您访问http://www.daniweb.com时你得到一个弹出窗口,这叫什么 + 知道怎么做吗? 感谢您的回复,只有模态加载动画的最简单方法是什么,即页面加载时动画显示以及动画何时完成? ASP
我正在为 Unity 引擎中的音频过滤器创建一个 C# 脚本。 我的问题是,在通过我的过滤器运行后,生成的音频具有一致且频繁的“咔哒声”、“砰砰声”或“跳过声”。听起来有点像旧 radio 。 我不确
我必须隐藏浏览器的地址栏。我正在使用这段代码: var winFeature = 'location=no,toolbar=no,menubar=no,scrollbars=yes,r
推荐一个button 弹起pickerview的源码,也可以作为工具类使用。 利用inputview 做键盘弹起动画。该如何做呢? 1.继承uiview 2.重写属性&方法
我在这里有一个问题,我已经工作了几个小时。 我正在导入一个 Excel 文件,并使用此代码来执行此操作: Dim objExcel As Excel.Application Di
我基本上是从 UITableViewController 推送 UIView,它包含的只是 UIWebView。但是,当我删除 UIView 以返回到 UITableView 时,应用程序崩溃了。 -
我有几个由导航 Controller 控制的 View Controller 。 例如,viewController A 和 viewController B 都可以将 viewController
我使用新的Gmail API为用户创建草稿。 API响应提供了新创建的消息ID。 然后,我可以使用URL https://mail.google.com/mail/#drafts?compose=[m
Redis列表实现了哪种内部数据结构以实现这一目的?链表将需要O(n)索引,而数组将需要O(n)左/右推/弹出。 最佳答案 根据official documentation,它们被实现为linked
我正在使用 WPF Popup 控件,它显示背景为黑色。我在其中放置了一个 StackPanel 并设置了 Background="Transparent",但这没有帮助。
我希望页面内的容器在事件时占据页面的整个宽度并覆盖在其他所有内容上。这是我目前所拥有的,但它没有按我想要的方式工作: $(function() { $('.main a').click( fu
我是一名优秀的程序员,十分优秀!