gpt4 book ai didi

html - 渐变创建伪按钮的问题

转载 作者:行者123 更新时间:2023-11-28 01:05:45 25 4
gpt4 key购买 nike

我需要制作一个在任何现代浏览器和任何操作系统中看起来都一样的按钮(appearance: button - 这不是我的解决方案!)。 These are the 4 stages (without disabled stage) of the button I want to recreate.

我做了一个包装器,但是有一个 problem with the gradient .这可以通过复制原始按钮的图像并将其作为背景插入来解决,但我认为这是一个错误的决定。我的观点是渐变是比临时版本更好的缩放解决方案:background-image: url('https://i.imgur.com/lmEjKKe.png') .

//
function setBtnHover(element, value) {
//
element.dataset.hover = value;
}

//
var lastBtnMouseDown = null;

//
function setBtnMouseDown(element, value, e) {
//
if (element !== null) {
//
element.dataset.mouseDown = value;
//
if (value) {
//
if (lastBtnMouseDown !== null)
//
lastBtnMouseDown.dataset.click = false;

//
element.dataset.click = true;
//
lastBtnMouseDown = element;
}

//
e.stopPropagation();
//
} else if (!value) {
//
if (lastBtnMouseDown !== null) {
//
lastBtnMouseDown.dataset.mouseDown = value;
}
} else {
//
lastBtnMouseDown.dataset.click = false;
//
lastBtnMouseDown = null;
}
}
.button {
box-shadow: -1px -1px 0 0 rgba(0,0,0,0.05);
padding-left: 10px;
padding-right: 10px;
height: 22px;
box-sizing: border-box;
border: 1px solid #003c74;
display: inline-block;
color: #000000;
cursor: default;
text-align: center;
font: 13.3333px MS Shell Dlg \32;
padding-top: 2px;
border-radius: 3px;
background-image: url('https://i.imgur.com/3Jwqiw1.png');
-moz-user-select: none;
user-select: none;
}

.button[data-hover=false][data-click=true] {
background: radial-gradient(white 60%, blue 100%);
}

.button[data-hover=true][data-mouse-down=true] {
padding-left: 1px;
background-image: url('https://i.imgur.com/lmEjKKe.png');
}

.button[data-hover=true][data-mouse-down=false] {
background: radial-gradient(white 60%, orange 100%);
}
<body onmousedown="setBtnMouseDown(null, true)" onmouseup="setBtnMouseDown(null, false)">

<p style="padding-left: 1px;"><span class="button" data-hover="false" data-mouse-down="false" data-click="false" onmouseover="setBtnHover(this, true)" onmouseout="setBtnHover(this, false)" onmousedown="setBtnMouseDown(this, true, event)" onmouseup="setBtnMouseDown(this, false, event)">BUTTON</span></p>

<p><button>BUTTON</button></p>

</body>

JSFiddle:https://jsfiddle.net/0wd4m6qg/5/

最佳答案

除了伪类或伪元素,您可以使用类来应用 CSS(我认为这是更简单和更清晰的代码),而不是径向渐变背景,您可以在“插图”中使用框阴影创建粗内边框的模式(加上纯色背景或线性渐变):

.my-button.over {
/* background: radial-gradient(white 60%, orange 100%); */
box-shadow: 0 0 0 0.25em orange inset;
}

您还可以通过向要定位的选择器添加事件监听器来简化逻辑,如下所示:

var mybutton = document.querySelector('.my-button'); // single element
var buttons = document.querySelectorAll('.my-button'); // many elements

然后创建一些向目标元素添加/删除类的函数:

function overButton() {
this.classList.add('over')
}

使用正确的事件监听器将函数附加到元素。 (您还可以添加条件逻辑来检查某个类是否已添加到特定按钮。)

mybutton.addEventListener('mouseout', outButton); // single element
// see my JS Bin for attaching to multiple elements.

这是我的 JS Bin:

http://jsbin.com/sehucak/edit?html,css,js,console,output

关于html - 渐变创建伪按钮的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52374640/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com