html - 为什么背景图像在按钮中被切断

标签 html css image

<a class="button icon tag" href="#"><span>Show All Tasks</span></a>

a.button {
    background-image: -moz-linear-gradient(top, #ffffff, #dbdbdb);
    background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0, #ffffff),color-stop(1, #dbdbdb));
    filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#ffffff', EndColorStr='#dbdbdb');
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorStr='#ffffff', EndColorStr='#dbdbdb')";
    border: 1px solid #fff;
    -moz-box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.4);
    -webkit-box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.4);
    box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.4);
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    padding: 10px 20px;
    text-decoration: none;
    text-shadow: #fff 0 1px 0;
    float: left;
    display: block;
    color: #597390;
    line-height: 24px;
    font-size: 20px;
    font-weight: bold;
    width: 100%;
}

a.button:hover {
    background-image: -moz-linear-gradient(top, #ffffff, #eeeeee);
    background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0, #ffffff),color-stop(1, #eeeeee));
    filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#ffffff', EndColorStr='#eeeeee');
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorStr='#ffffff', EndColorStr='#eeeeee')";
    color: #000;
    display: block;
}

a.button:active {
    background-image: -moz-linear-gradient(top, #dbdbdb, #ffffff);
    background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0, #dbdbdb),color-stop(1, #ffffff));
    filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#dbdbdb', EndColorStr='#ffffff');
    -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorStr='#dbdbdb', EndColorStr='#ffffff')";
    text-shadow: 0px -1px 0 rgba(255, 255, 255, 0.5);
    margin-top: 1px;
}

a.button.icon {
    padding-left: 0px;
}

a.button.icon span{
    padding-left: 100px;
    background: url(icons2.png) no-repeat 0 -4px;
}

a.button.icon.tag span {
    background-position: 0px -65px;
}

图像(图标 2 40X96):

enter image description here

在浏览器中的显示方式:

enter image description here

如何显示整个图像而不被截断? 既然只有一张图片,如何消除位置的用户,而不是只显示图片?

最佳答案

只要给出跨度display:block;height:30px;:

a.button.icon span{
    padding-left: 100px;
    background: url(http://i.stack.imgur.com/fEeuO.png) no-repeat 0 -4px;
    height:30px;
    display:block;
}

为了停止切断,我稍微改变了背景位置:

a.button.icon.tag span {
    background-position: 0px -62px;
}

enter image description here

JSFiddle

关于html - 为什么背景图像在按钮中被切断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24896438/

相关文章:

html - 主动焦点悬停 : keep parent focus hover when go to sub menu

javascript - 通过单击背景区域关闭灯箱窗口?

javascript - 使用上一页的CSS并应用于当前页面

python - 使用 PIL 调整图像大小并保持方向

image - 应用了哪种类型的图像失真过滤器?

javascript - 使用 JavaScript 将二进制文件转换为文本

javascript - 在 jQuery 中悬停时处理 CSS 更改(用户选择的颜色)

java - 如何使用 Struts 2 验证 HTML 标签

jquery - 在表单中突出显示所选图像 - 使用 Jquery?

jquery - 手动背景 div 幻灯片