H5移动web页面触摸按钮效果实现-模拟按钮hover效果实现

本文探讨了如何在H5移动web页面上实现触摸按钮效果,以提供更好的用户体验。由于移动设备缺少鼠标指针,传统的CSS hover效果不适用。作者提出利用CSS的active伪类来替代,以此达到类似的效果。
摘要由CSDN通过智能技术生成

        移动端触摸按钮的效果,可明示用户有些事情正要发生,是一个比较好体验,但是移动设备中并没有鼠标指针,使用css的hover并不能满足我们的需求,还好国外有个激活css的active效果,代码如下:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
		<style>
		 .btn{
		 	display: block;
		 	position: relative;
		 	top: 100px;
		 	margin: 20px;
		 	width: 200px; 
		 	height: 50px;
		 	line-height: 50px;
		 	text-align: center;
		 	border-radius: 5px;
		 	font-size: 18px;
		 	color: salmon;
		 	background-color:
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过以下步骤实现 H5 可拖动悬浮按钮效果: 1. 在 HTML 文件中添加一个按钮元素,并为其设置 id 和 class: ```html <button id="drag-btn" class="drag-btn">拖动我</button> ``` 2. 在 CSS 文件中为按钮元素设置样式,使其成为一个圆形的悬浮按钮: ```css .drag-btn { position: fixed; bottom: 20px; right: 20px; width: 50px; height: 50px; border-radius: 50%; background-color: #007bff; color: #fff; font-size: 20px; font-weight: bold; text-align: center; line-height: 50px; cursor: move; } ``` 3. 在 JavaScript 文件中为按钮元素添加拖动事件: ```js var dragBtn = document.getElementById('drag-btn'); // 记录鼠标按下时的坐标和按钮的初始位置 var startX, startY, initialPos; // 鼠标按下事件 dragBtn.addEventListener('mousedown', function(e) { startX = e.clientX; startY = e.clientY; initialPos = getPosition(dragBtn); // 添加鼠标移动和松开事件 document.addEventListener('mousemove', dragBtnMouseMove); document.addEventListener('mouseup', dragBtnMouseUp); }); // 鼠标移动事件 function dragBtnMouseMove(e) { var dx = e.clientX - startX; var dy = e.clientY - startY; dragBtn.style.left = initialPos.x + dx + 'px'; dragBtn.style.top = initialPos.y + dy + 'px'; } // 鼠标松开事件 function dragBtnMouseUp(e) { document.removeEventListener('mousemove', dragBtnMouseMove); document.removeEventListener('mouseup', dragBtnMouseUp); } // 获取元素的坐标 function getPosition(element) { var rect = element.getBoundingClientRect(); return { x: rect.left, y: rect.top }; } ``` 这样就可以实现一个可拖动的悬浮按钮了。通过记录鼠标按下时的坐标和按钮的初始位置,然后在鼠标移动事件中计算偏移量并改变按钮的位置,最后在鼠标松开事件中移除事件监听器,就能实现拖动功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值