2017-06-20 98 views
3

嗨,我只想问我的程序有什么问题。我正在做这个程序,我必须选择一个文件。但该按钮是一个图像,我想添加一个工具提示,该图像用于选择一个文件。这块代码完全适用于Chrome。但是当我在IE11中运行它时,标题“选择文件”在IE11中没有显示。我不知道IE有很多限制。不像在铬。标题属性在IE11中不工作

.image-upload>input { 
 
    visibility: hidden; 
 
    width: 0px; 
 
    height: 0px; 
 
    margin: -10%; 
 
} 
 

 
div.item { 
 
    vertical-align: top; 
 
    display: inline-block; 
 
    text-align: center; 
 
    width: 250px; 
 
    img { 
 
    width: 90px; 
 
    height: 50px; 
 
    } 
 
    .caption { 
 
    display: block; 
 
    color: white; 
 
    } 
 
    div.space { 
 
    margin-top: -15px; 
 
    }
<div class="image-upload"> 
 
    <label for="file-input"> 
 
    <p align="left"><font face="Arial" color="black" size = "5"><b>&nbsp&nbsp&nbspSelect File&nbsp&nbsp&nbsp </b><span style="cursor:pointer" alt="Select File" title="Select File"> 
 
    <img src="http://icons.veryicon.com/ico/Folder/Black%20glamour/Files.ico" style="pointer-events: none" id="img" title="Select File"/></span></font></p></label> 
 
    </label> 
 
    <input id="file-input" type="file" name="file" onchange="onFileSelected(event)" onclick=getName() required> 
 
</div>

+0

是https://stackoverflow.com/questions/36606868/tooltip-using-title-attribute-in-ie-11适用? – apokryfos

+0

我的程序是关于执行python脚本,这就是为什么我使用php –

+0

代码中没有任何与python或PHP相关的代码 – mplungjan

回答

1

你需要,如果你希望能够盘旋它从图像标签去除pointer-events:none内联样式。

通过将其设置为无,这意味着您的鼠标无法与该元素进行交互,因此无法将其悬停以显示标题。

试试这个:

<img src="http://icons.veryicon.com/ico/Folder/Black%20glamour/Files.ico" id="img" title="Select File"/> 

Example fiddle showing with and without pointer events

More information about pointer events

同时请注意,你的代码以下错误:

  • 字体标签已过时,不应该使用 - 使用css代替
  • & NBSP应该有一个冒号:&nbsp;
  • 有一个多余的结束标签,我不认为你被允许内部p标签 - 使用验证器来检查你的代码

<div class="image-upload"> 
 
    <p align="left"><label for="file-input"><b>&nbsp;&nbsp;&nbsp;Select File&nbsp;&nbsp;&nbsp; </b> 
 
    </label></p> 
 
    <span style="cursor:pointer; display:inline-block;" alt="Select File" title="Select File"><label for="file-input"><img src="http://icons.veryicon.com/ico/Folder/Black%20glamour/Files.ico" id="img" title="Select File"/> 
 
    </label></span> 
 
    <input id="file-input" type="file" name="file" onchange="onFileSelected(event)" onclick=getName() required> 
 
</div>

0

您可以添加另一个span(例如),给它的位置绝对,并悬停在图像上,显示它。

你也可以让你的javascript(jquery)在你的光标所在的位置显示它,但这有点复杂。

下面看看这是你想要的

.title { 
 
    transition: 0.3s ease-out; 
 
    opacity: 0; 
 
    position: absolute; 
 
    top: 50%; 
 
    left: 0%; 
 
    transform: translateY(-50%); 
 
    font-size: 15px; 
 
    background: #fff; 
 
} 
 

 
.wrapper { 
 
    display: inline-block; 
 
    position: relative; 
 
} 
 

 
.wrapper:hover .title { 
 
    opacity: 1; 
 
}
<div class="image-upload"> 
 
    <label for="file-input"> 
 
    <p align="left"><font face="Arial" color="black" size="5"><b>&nbsp&nbsp&nbspSelect File&nbsp&nbsp&nbsp </b>  <span class="wrapper" style="cursor:pointer" alt="Select File" title="Select File"> 
 
\t \t <span class="title">Select File</span> 
 
    <img src="http://icons.veryicon.com/ico/Folder/Black%20glamour/Files.ico" style="pointer-events: none" id="img" title="Select File"/></span></font></p> 
 

 
    </label> 
 
    </label> 
 
    <input id="file-input" type="file" name="file" onchange="onFileSelected(event)" onclick=getName() required> 
 
</div>