我能想到的最简单的方法(没有javascript)是让基本背景有一个渐变,然后顶部的子元素有一个透明的背景..
- 如果您只满足于具有淡入淡出效果(即渐变),那么就反其道而行之。否则,您将陷入陷阱,然后在每个滚动条上识别当前顶部的气泡,然后更改样式。很快这将成为你的噩梦。
将一个元素保持在顶部并为其赋予渐变,以便通过该元素通过透明度可以看到最顶部的气泡,从而在滚动时淡出。
最简单的方法是让你的标记是这样的:
<div class="wrap"> <!-- The outermost wrapper for entire chat -->
<div class="container"> <!-- The chat window container -->
<div class="bubble"><p>msg</p></div> <!-- individual chat bubbles -->
</div>
</div>
然后通过 CSS 在其上放置一个元素:
.wrap::after {
content: ''; position: relative; display: block;
top: -100%; left: 0;
width: calc(100% - 16px); height: 64px;
background-image: linear-gradient(rgba(0,0,0,1), rgba(0,0,0,0));
}
这会将渐变放在聊天包装窗口的顶部,并且气泡将在container
.
下面是从这个答案派生的演示:https ://stackoverflow.com/a/27486767/1355315
演示片段 1:
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }
.wrap { margin: 8px; height: 80%; width: 50%; overflow: hidden; }
.container {
background-color: #eee;
height: 100%; width: 100%;
overflow: auto;
}
.bubble { width: 100%; clear: both; } /* clear the floats here on parent */
.bubble p {
border-radius: 5px;
padding: 8px; margin: 8px 12px;
max-width: 80%; /* this will make it not exceed 80% and then wrap */
position: relative;
}
.left p { background-color: #ccc; float: left; } /* floated left */
.right p { background-color: #33c; color: #fff; float: right; } /* floated right */
/* classes below are only for arrows, not relevant */
.left p::before {
content: ''; position: absolute;
width: 0; height: 0; left: -8px; top: 8px;
border-top: 4px solid transparent;
border-right: 8px solid #ccc;
border-bottom: 4px solid transparent;
}
.right p::after {
content: ''; position: absolute;
width: 0; height: 0; right: -8px; bottom: 8px;
border-top: 4px solid transparent;
border-left: 8px solid #33c;
border-bottom: 4px solid transparent;
}
.wrap::after {
content: ''; position: relative;
top: -100%; left: 0;
display: block; width: calc(100% - 16px); height: 64px;
background-image: linear-gradient(rgba(242,242,242,1), rgba(242,242,242,0));
}
<div class="wrap">
<div class="container">
<div class="bubble left"><p>msg</p></div>
<div class="bubble left"><p>long message</p></div>
<div class="bubble right"><p>ultra long message which can wrap at eighty percent </p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>very long message</p></div>
<div class="bubble right"><p>one more message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>another message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>yet another message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
</div>
</div>
编辑
模拟 iMessage 聊天气泡,它在您滚动时具有淡入淡出效果,即顶部气泡比底部气泡略浅的蓝色阴影。
- 如果您希望准确地模拟 iMessage 的行为,那么您必须记住没有淡入淡出效果。顶部气泡的颜色与其余气泡不同(接近青色)。没有阴影或褪色。
为了做到这一点,您将不得不求助于 Javascript,因为 CSS 无法根据滚动来确定当前哪个气泡位于顶部。只需连接scroll
容器的事件,并检查气泡的位置并相应地更改颜色。
下面是基于上述演示的纯 Javascript 示例(无 jQuery )。
演示小提琴:http: //jsfiddle.net/abhitalks/oop2dazy/1/
演示片段 2:
var cw = document.getElementById('chatWindow'),
threshold = 64;
cw.addEventListener('scroll', function(e) {
var bubbles = cw.getElementsByClassName('right');
[].forEach.call(bubbles, function(elem) {
var top = elem.getBoundingClientRect().top
if (top < threshold) { elem.classList.add('faded'); }
else { elem.classList.remove('faded');}
});
});
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }
.wrap { margin: 8px; height: 80%; width: 50%; overflow: hidden; }
.container {
background-color: #eee;
height: 100%; width: 100%;
overflow: auto;
}
.bubble { width: 100%; clear: both; } /* clear the floats here on parent */
.bubble p {
border-radius: 5px;
padding: 8px; margin: 8px 12px;
max-width: 80%; /* this will make it not exceed 80% and then wrap */
position: relative; transition: background-color 0.5s;
}
.left p { background-color: #ccc; float: left; } /* floated left */
.right p { background-color: #33c; color: #fff; float: right; } /* floated right */
/* classes below are only for arrows, not relevant */
.left p::before {
content: ''; position: absolute;
width: 0; height: 0; left: -8px; top: 8px;
border-top: 4px solid transparent;
border-right: 8px solid #ccc;
border-bottom: 4px solid transparent;
}
.right p::after {
content: ''; position: absolute;
width: 0; height: 0; right: -8px; bottom: 8px;
border-top: 4px solid transparent;
border-left: 8px solid #33c;
border-bottom: 4px solid transparent;
}
.bubble.faded p { background-color: #39c; }
.bubble.faded p::after { border-left: 8px solid #39c; }
<div class="wrap">
<div id="chatWindow" class="container">
<div class="bubble left"><p>msg</p></div>
<div class="bubble left"><p>long message</p></div>
<div class="bubble right"><p>ultra long message which can wrap at eighty percent </p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>very long message</p></div>
<div class="bubble right"><p>one more message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>another message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
<div class="bubble right"><p>yet another message</p></div>
<div class="bubble left"><p>lorem ipsum</p></div>
</div>
</div>
这将解决您的聊天窗口顶部模糊的问题。这将允许从顶部进行触摸滚动,并且不会阻碍气泡上的交互。