- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在处理这个弹出框,当我点击一个图像时它会被触发,现在我有 8 张图像,我已经在上面应用了弹出框,我想固定弹出框并滚动背景,这样,无论图像位置如何,弹出框都将保持在屏幕上的相同位置。
(function(){
var container = document.documentElement,
popup = document.querySelector( '.avgrund-popup' ),
cover = document.querySelector( '.avgrund-cover' ),
currentState = null;
addClass( container, 'avgrund-ready' );
// Deactivate on ESC
function onDocumentKeyUp( event ) {
if( event.keyCode === 27 ) {
deactivate();
}
}
// Deactivate on click outside
function onDocumentClick( event ) {
if( event.target === cover ) {
deactivate();
}
}
function activate( state ) {
document.addEventListener( 'keyup', onDocumentKeyUp, false );
document.addEventListener( 'click', onDocumentClick, false );
removeClass( popup, currentState );
addClass( popup, 'no-transition' );
addClass( popup, state );
setTimeout( function() {
removeClass( popup, 'no-transition' );
addClass( container, 'avgrund-active' );
}, 0 );
currentState = state;
}
function deactivate() {
document.removeEventListener( 'keyup', onDocumentKeyUp, false );
document.removeEventListener( 'click', onDocumentClick, false );
removeClass( container, 'avgrund-active' );
}
function disableBlur() {
addClass( document.documentElement, 'no-blur' );
}
function addClass( element, name ) {
element.className = element.className.replace( /\s+$/gi, '' ) + ' ' + name;
}
function removeClass( element, name ) {
element.className = element.className.replace( name, '' );
}
window.avgrund = {
activate: activate,
deactivate: deactivate,
disableBlur: disableBlur
}
})();
* {
margin: 0;
padding: 0;
}
*, *:before, *:after {
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.popup_container{
height: 100%;
overflow: hidden;
max-width: 500px;
margin: 0 auto;
}
p{
margin: 10px 0 10px 0;
font-size: 16px;
line-height: 1.32;
}
.pop_img{
cursor:pointer;
}
button {
position:relative;
float:right;
padding:5px;
border: 0px;
width:35px;
height:35px;
border-radius:50%;
cursor: pointer;
color:#91cd85;
font-size:20px;
-webkit-transition: 0.15s background ease;
-moz-transition: 0.15s background ease;
-ms-transition: 0.15s background ease;
-o-transition: 0.15s background ease;
transition: 0.15s background ease;
}
button:hover{
color:#fff;
background-color:#91cd85;
}
button+button {
margin-left: 5px;
}
.popup_container{
background: #fff;
font-family: 'Lato', Helvetica, sans-serif;
font-size: 16px;
color: #222;
}
.avgrund-active body {
-webkit-transform: scale( 0.9 );
-moz-transform: scale( 0.9 );
-ms-transform: scale( 0.9 );
-o-transform: scale( 0.9 );
transform: scale( 0.9 );
}
.avgrund-active .avgrund-cover {
visibility: visible;
opacity: 1;
}
.avgrund-contents {
position: relative;
padding: 20px;
max-width: 400px;
height: 100%;
margin: auto;
}
.avgrund-active .avgrund-contents {
-webkit-filter: blur(2px);
-moz-filter: blur(2px);
-ms-filter: blur(2px);
-o-filter: blur(2px);
filter: blur(2px);
}
.no-blur.avgrund-active .avgrund-contents {
-webkit-filter: none;
-moz-filter: none;
-ms-filter: none;
-o-filter: none;
filter: none;
}
.avgrund-popup {
display: none;
position: fixed;
top: 50%;
left: 50%;
width: 400px;
height: auto;
margin-left: -200px;
margin-top: -150px;
background-color: #ffffff;
padding: 25px;
border-radius: 5px;
z-index: 10;
box-shadow: 0px 0px 20px rgba( 0, 0, 0, 0.6 );
border-radius: 3px;
-webkit-transform: scale( 0.8 );
-moz-transform: scale( 0.8 );
-ms-transform: scale( 0.8 );
-o-transform: scale( 0.8 );
transform: scale( 0.8 );
}
.pop_head{
padding-bottom:30px;
}
.inner_content{
width:100%;
max-height:250px;
overflow-y: scroll;
}
.pop_head h2{
max-height:350px;
text-align:center;
overflow:hidden;
}
.inner_content .details{
margin-top:30px;
line-height:15px;
}
.avgrund-active .avgrund-popup {
display:block;
visibility: visible;
opacity: 1;
-webkit-transform: scale( 1.1 );
-moz-transform: scale( 1.1 );
-ms-transform: scale( 1.1 );
-o-transform: scale( 1.1 );
transform: scale( 1.1 );
}
.avgrund-popup.stack {
-webkit-transform: scale( 1.5 );
-moz-transform: scale( 1.5 );
-ms-transform: scale( 1.5 );
-o-transform: scale( 1.5 );
transform: scale( 1.5 );
}
.avgrund-active .avgrund-popup.stack {
-webkit-transform: scale( 1.1 );
-moz-transform: scale( 1.1 );
-ms-transform: scale( 1.1 );
-o-transform: scale( 1.1 );
transform: scale( 1.1 );
}
.avgrund-ready body,
.avgrund-ready .avgrund-contents,
.avgrund-ready .avgrund-popup,
.avgrund-ready .avgrund-cover {
-webkit-transform-origin: 50% 50%;
-moz-transform-origin: 50% 50%;
-ms-transform-origin: 50% 50%;
-o-transform-origin: 50% 50%;
transform-origin: 50% 50%;
-webkit-transition: 0.3s all cubic-bezier(0.250, 0.460, 0.450, 0.940);
-moz-transition: 0.3s all cubic-bezier(0.250, 0.460, 0.450, 0.940);
-ms-transition: 0.3s all cubic-bezier(0.250, 0.460, 0.450, 0.940);
-o-transition: 0.3s all cubic-bezier(0.250, 0.460, 0.450, 0.940);
transition: 0.3s all cubic-bezier(0.250, 0.460, 0.450, 0.940);
}
.avgrund-ready .avgrund-popup.no-transition {
-webkit-transition: none;
-moz-transition: none;
-ms-transition: none;
-o-transition: none;
transition: none;
}
<div class="popup_container">
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-contents">
<a class="pop_img" onclick="avgrund.activate( 'stack' );"><img src="https://cdn4.iconfinder.com/data/icons/IMPRESSIONS/medical/png/256/doctor.png" /></a>
</div>
<div class="avgrund-popup">
<div class=pop_head>
<button onclick="avgrund.deactivate();">x</button>
<h2>Title</h2>
</div>
<div class=inner_content>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
<p class=details>You can hit ESC or click outside to close the modal. Give it a go to see the reverse transition.
</p>
</div>
</div>
这就是我想要达到的目标 https://codepen.io/digstheone/pen/xVNrzJ
最佳答案
我将在图像容器外生成弹出窗口,然后使用 z-index,以便图像堆叠在地下。
关于javascript - 修复弹出框并使背景滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37273776/
我连续有 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
我是一名优秀的程序员,十分优秀!