uniapp使用伪元素实现气泡

uniapp使用伪元素实现气泡

背景

气泡效果在开发中使用是非常常见的,使用场景有提示框,对话框等等,今天我们使用css来实现气泡效果。老规矩,先看下效果图:

实现思路

其实实现这个气泡框的难点就是三角形怎么去绘制,canvas倒是提供了绘制三角形的API,但是我们这个不用搞那么复杂,主要用css中的伪元素来实现,然后通过实现对伪元素的绝对定位来决定三角形的位置。

代码实现

我们先实现第一种效果,气泡主体是一个带圆角的矩形,这个没啥难度,然后在矩形的左边设置一个伪元素,为了使三角形更明显,要给伪元素设置一个较大的宽度和背景颜色。看代码:

模板界面代码

javascript 复制代码
<template>
	<view>
		<view class="pop">
		    <view class="view">气泡对话框</view>
		</view>
	</view>
</template>

css代码

css 复制代码
.pop {
    margin: 30px;
    width: 200px;
    height: 100px;
    padding: 10px;
    background: #00aa00;
    border-radius: 8px;
    position: relative;
}
.pop::after {
    content:"";
    width: 0;
    height: 0;
    border: 12px solid;
    border-color: #00aa00;
    position: absolute;
    top: 45px;
    left: -24px;
}

这里通过设置合适的top和left可以让三角形处于你想要的位置,看下效果:

左边目前显示矩形,那怎么显示出一个三角形了?答案就再border-color身上,它其实后面有四个值可以设置,分别是上右下左,那我们只要把最右边设置成我们想要的颜色,其他设置透明就能出现一个如文章开头所示的三角形。改下代码:

css 复制代码
.pop::after {
    content:"";
    width: 0;
    height: 0;
    border: 12px solid;
    border-color: transparent #00aa00 transparent transparent;//上右下左
    position: absolute;
    top: 45px;
    left: -24px;
}

再看效果图已达到预期效果

其实第二种效果思路类似,先放置一个带边框的圆角矩形,然后按照上面的思路显示一个底部三角,设置底部三角的背景来覆盖原来矩形边框,最后在伪元素中设置底部三角的背景为边框颜色,并通过设置top超出边框宽度的像素来达到三角形边框效果。这里就直接上代码了:

模板代码

javascript 复制代码
<template>
	<view>
		<view class="pop-with-border">
		  <view class="border-view">带边框气泡框</view>
		</view>
	</view>
</template>

css代码

css 复制代码
.pop-with-border {
    margin: 30px;
    width: 200px;
    height: 100px;
    padding: 10px;
    background: #fff;
    border-radius: 8px;
    position: relative; 
    border: 1px solid #ddd;
}
.pop-with-border:before,
.pop-with-border:after {
  top: -8px;
  border: 8px solid transparent;
  border-top: 0;//上边框的宽度
  border-bottom-color: #fff;//下边框颜色这里跟大矩形背景一样
  content: "";
  display: block;
  width: 0;
  height: 0;
  left: 32px;
  overflow: hidden;
  position: absolute;
  z-index: 101;
}
.pop-with-border:before {
  top: -9px;//这里超出边框一个像素显示出底部三角形背景
  border-bottom-color: #ddd;//这里跟大矩形边框颜色一样
  z-index: 99;
}
.border-view {
    padding: 10px 20px;
}

效果图如下

你可以调整after伪元素中的left来调整三角形的位置,注意不要超过矩形的范围。

尾巴

今天实现了一个简单的效果,下次遇到这种类似需求的就不用找UI切图了。

这篇就到这里了,希望能给大家帮助,如果喜欢我的文章,欢迎给我点赞,评论,关注,谢谢大家!

相关推荐
米奇妙妙wuu1 天前
css实现文字和边框同样的渐变色效果
css·html·css3
EEEzhenliang1 天前
CSS样式所有使用方式(书写位置)
前端·css
Yan.love1 天前
【CSS-核心属性】“高频词”速查清单
前端·css
云上凯歌1 天前
01_AI工具平台项目概述.md
人工智能·python·uni-app
Yan.love1 天前
【CSS-动画与过渡】丝滑的艺术,从简单位移到贝塞尔曲线
前端·css
郑州光合科技余经理1 天前
O2O上门预约小程序:全栈解决方案
java·大数据·开发语言·人工智能·小程序·uni-app·php
2501_916008891 天前
在不越狱前提下导出 iOS 应用文件的过程,访问应用沙盒目录,获取真实数据
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_915106321 天前
Android和IOS 移动应用App图标生成与使用 Assets.car生成
android·ios·小程序·https·uni-app·iphone·webview
木子啊1 天前
UNIAPP移动端瀑布流列表,支持APP、微信小程序、H5
uni-app·瀑布流·两列排序
Rattenking1 天前
【CSS】---- 根据【张鑫旭-高宽不等图片固定比例布局的三重进化】的思考
前端·css