3

我有一个宽度可变的文本菜单,例如:

Home
Services
About Us
Contact

如何在css中悬停时将图像放置在不同宽度文本的右侧?是否可以不使用固定宽度?

Home
Services •
About Us
Contact

或者

Home
Services
About Us
Contact •
4

3 回答 3

1

现场演示http://tinkerbin.com/RrRtqfVf

做这个

HTML

<ul>
  <li>Hello</li>
  <li>Hello</li>
  <li>Hello</li>
  <li>Hello</li>
  <li>Hello</li>
  <li>Hello</li>
  <li>Hello</li>

</ul>

CSS

    ul{
list-style:none;

}
li{
position:relative;
  float:left;
  clear:left;
  margin-top:10px;
}
li:hover:after{
content:'';
  background:red;
  position:absolute;
  right:-20px;
  top:5px;
  width:10px;
  height:10px;
}

演示

于 2012-10-11T11:52:19.080 回答
0

尝试这个

HTML

<ul>
    <li>Home</li>
<li>Services</li>
<li>About Us</li>
   <li> Contact</li>
</ul>

​CSS

ul{width:80px}
ul li:hover{background:url(http://hotels.online.com.sg/DB/icon/star_icon2.gif) right no-repeat}​

演示

于 2012-10-11T11:52:05.403 回答
0

我的建议,使用background-image..

让我们假设这是您的 html:

<ul>
    <li>Home</li>
    <li>Services</li>
    <li>About Us</li>
    <li>Contact</li>
</ul>

现在,使用这个 CSS 来实现你想要的:

ul{list-style-type:none;}
ul li{width:120px;}
ul li:hover{background:url(your/image/path) no-repeat top right;}

如果您希望菜单中的每个项目都有不同的图像/图标,请使用attributes或其他类的:

<ul>
    <li data="home">Home</li>
    <li data="services">Services</li>
    <li data="about">About Us</li>
    <li data="contact">Contact</li>
</ul>

你的 CSS 应该是这样的:

ul{list-style-type:none;}
ul li{width:120px;}
ul li[data="home"]:hover{background:url(your/image/path1) no-repeat top right;}
ul li[data="services"]:hover{background:url(your/image/path2) no-repeat top right;}
ul li[data="about"]:hover{background:url(your/image/path3) no-repeat top right;}
ul li[data="contact"]:hover{background:url(your/image/path4) no-repeat top right;}
于 2012-10-11T11:53:22.750 回答