我在我的一个非常老的项目中使用AJAX 控制工具包自动完成。我对鼠标悬停突出显示有一些问题。
在有效的示例中,生成的<li>
标签会获得一个 mouseover 事件,该事件使用内联 css 更改其背景颜色。效果很好。但是,当我从以下位置更改标记时:
<li>
Hello world
</li>
至
<li>
<div>Hello</div>
<div>world</div>
</li>
只有当我悬停其中一个 div 未覆盖的一部分时,该<li>
元素才会更改背景颜色。
由于我无法修改生成的(和缩小的)javasacript,我正在寻找一个快速而肮脏的修复程序。
我试图更改元素的 z-index,但没有成功。我还尝试找到 li 的事件并将其添加到 div 中。但是我找不到将 jquery 未添加的事件复制到另一个元素的方法。
非常感谢这里的任何想法。
下面如果还原的缩小 javascript 有任何帮助:
_highlightItem: function(item) {
/// <summary>
/// Highlights the specified item
/// </summary>
/// <param name="item" type="Sys.UI.DomElement" DomElement="true" mayBeNull="false" />
/// <returns />
var children = this._completionListElement.childNodes;
// Unselect any previously highlighted item
for (var i = 0; i < children.length; i++) {
var child = children[i];
if (child._highlighted) {
if (this._completionListItemCssClass) {
Sys.UI.DomElement.removeCssClass(child, this._highlightedItemCssClass);
Sys.UI.DomElement.addCssClass(child, this._completionListItemCssClass);
} else {
if (Sys.Browser.agent === Sys.Browser.Safari) {
child.style.backgroundColor = 'white';
child.style.color = 'black';
} else {
child.style.backgroundColor = this._textBackground;
child.style.color = this._textColor;
}
}
this.raiseItemOut(new AjaxControlToolkit.AutoCompleteItemEventArgs(child, child.firstChild.nodeValue, child._value));
}
}
// Highlight the new item
if(this._highlightedItemCssClass) {
Sys.UI.DomElement.removeCssClass(item, this._completionListItemCssClass);
Sys.UI.DomElement.addCssClass(item, this._highlightedItemCssClass);
} else {
if (Sys.Browser.agent === Sys.Browser.Safari) {
item.style.backgroundColor = 'lemonchiffon';
} else {
item.style.backgroundColor = 'highlight';
item.style.color = 'highlighttext';
}
}
item._highlighted = true;
this.raiseItemOver(new AjaxControlToolkit.AutoCompleteItemEventArgs(item, item.firstChild.nodeValue, item._value));
},