今天帮别人写个小东西(搜索时智能提示),最后发现添加上的li无法触发click事件(FillData()方法),其他的mouseover mouseout等,都可以,我想,可能是我哪儿的ID重名了,但就是找不到,拿出来,希望大家能帮我看看错在哪儿!先谢了!<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<style type="text/css">
#parent{position:relative;}
#ulPop{margin:0px;padding:0px;list-style-type:none;z-index:1;width:180px;display:none;border:1px solid #000;font-family:@微软雅黑;overflow:hidden;font-size:14px;}
#ulPop li{}
#ulPop li a{display:block;}
#ulPop li a:hover{background:#326bc5;color:#fff;}
.schoolItem{display:block;text-decoration:none;padding:0.2em 0.4em;line-height:15px;}
.itemOnSelected{background:#326bc5;color:#fff;line-height:24px;}
</style>
</head>
<body>
<div id="parent">
<input type="text" id="txtSuggest" />
<ul id="ulPop"></ul>
</div>
</body>
</html>
<script language="javascript" type="text/javascript">
var upKeyCode = 38, downKeyCode = 40, enterKeyCode = 13;
var xhr;
var input = $("txtSuggest");
input.onblur = function () { $("ulPop").style.display = "none"; }
input.options = $("ulPop").getElementsByTagName("li");
function CreateXMLHttpRequest() {
if (window.ActiveXObject) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
return new XMLHttpRequest();
}
}
function GetDataByKey(key) {
var url = "Handler.ashx?keyword=" + escape(key);
xhr = CreateXMLHttpRequest();
xhr.onreadystatechange = function () {
if (xhr.readystate == 4) {
if (xhr.status == 200) {
var data = xhr.responseText.split(",");
if (data.length >= 1) FillData(data);
}
}
}
xhr.open("GET", url, true);
xhr.send(null);
}
input.selectedIndex = 0;
input.onkeyup = function (e) {
e = e == undefined ? window.event : e;
switch (e.keyCode) {
case upKeyCode:
clearSytleOnSelected(this);
this.selectedIndex--;
if (this.selectedIndex < 0)
this.selectedIndex = this.options.length - 1;
setSytleOnSelected(this);
break;
case downKeyCode:
clearSytleOnSelected(this);
this.selectedIndex++;
if (this.selectedIndex >= this.options.length) {
this.selectedIndex = 0;
}
setSytleOnSelected(this);
break;
case enterKeyCode:
input.value = this.options[this.selectedIndex].childNodes[0].innerHTML;
$("ulPop").style.display = "none";
break;
default:
if (this.value.length >= 1)
GetDataByKey(this.value);
else $("ulPop").style.display = "none";
break;
}
}
function $(id) {
return document.getElementById(id);
}
function FillData(data) {
$("ulPop").innerHTML = "";
for (var i = 0; i < data.length; i = i + 2) {
var item = document.createElement("li");
item.onclick = function () { alert(this.childNodes[0].title); }
var itemText = document.createElement("a");
itemText.setAttribute("class", "schoolItem");
itemText.innerHTML = data[i];
itemText.setAttribute("title", data[i + 1]);
item.appendChild(itemText);
$("ulPop").appendChild(item);
}
$("ulPop").style.display = "block";
}
function clearSytleOnSelected(sender) {
if (sender.selectedIndex >= 0) {
sender.options[sender.selectedIndex].className = "";
}
}
function setSytleOnSelected(sender) {
sender.options[sender.selectedIndex].className = "itemOnSelected";
}
</script>
<head>
<title></title>
<style type="text/css">
#parent{position:relative;}
#ulPop{margin:0px;padding:0px;list-style-type:none;z-index:1;width:180px;display:none;border:1px solid #000;font-family:@微软雅黑;overflow:hidden;font-size:14px;}
#ulPop li{}
#ulPop li a{display:block;}
#ulPop li a:hover{background:#326bc5;color:#fff;}
.schoolItem{display:block;text-decoration:none;padding:0.2em 0.4em;line-height:15px;}
.itemOnSelected{background:#326bc5;color:#fff;line-height:24px;}
</style>
</head>
<body>
<div id="parent">
<input type="text" id="txtSuggest" />
<ul id="ulPop"></ul>
</div>
</body>
</html>
<script language="javascript" type="text/javascript">
var upKeyCode = 38, downKeyCode = 40, enterKeyCode = 13;
var xhr;
var input = $("txtSuggest");
input.onblur = function () { $("ulPop").style.display = "none"; }
input.options = $("ulPop").getElementsByTagName("li");
function CreateXMLHttpRequest() {
if (window.ActiveXObject) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
return new XMLHttpRequest();
}
}
function GetDataByKey(key) {
var url = "Handler.ashx?keyword=" + escape(key);
xhr = CreateXMLHttpRequest();
xhr.onreadystatechange = function () {
if (xhr.readystate == 4) {
if (xhr.status == 200) {
var data = xhr.responseText.split(",");
if (data.length >= 1) FillData(data);
}
}
}
xhr.open("GET", url, true);
xhr.send(null);
}
input.selectedIndex = 0;
input.onkeyup = function (e) {
e = e == undefined ? window.event : e;
switch (e.keyCode) {
case upKeyCode:
clearSytleOnSelected(this);
this.selectedIndex--;
if (this.selectedIndex < 0)
this.selectedIndex = this.options.length - 1;
setSytleOnSelected(this);
break;
case downKeyCode:
clearSytleOnSelected(this);
this.selectedIndex++;
if (this.selectedIndex >= this.options.length) {
this.selectedIndex = 0;
}
setSytleOnSelected(this);
break;
case enterKeyCode:
input.value = this.options[this.selectedIndex].childNodes[0].innerHTML;
$("ulPop").style.display = "none";
break;
default:
if (this.value.length >= 1)
GetDataByKey(this.value);
else $("ulPop").style.display = "none";
break;
}
}
function $(id) {
return document.getElementById(id);
}
function FillData(data) {
$("ulPop").innerHTML = "";
for (var i = 0; i < data.length; i = i + 2) {
var item = document.createElement("li");
item.onclick = function () { alert(this.childNodes[0].title); }
var itemText = document.createElement("a");
itemText.setAttribute("class", "schoolItem");
itemText.innerHTML = data[i];
itemText.setAttribute("title", data[i + 1]);
item.appendChild(itemText);
$("ulPop").appendChild(item);
}
$("ulPop").style.display = "block";
}
function clearSytleOnSelected(sender) {
if (sender.selectedIndex >= 0) {
sender.options[sender.selectedIndex].className = "";
}
}
function setSytleOnSelected(sender) {
sender.options[sender.selectedIndex].className = "itemOnSelected";
}
</script>
解决方案 »
- 关于js传参(数据类型)的问题,请高手帮助!
- 100分,非常复杂的checkbox选择
- firefox 如何设置控件位置
- 请教高手:利用ActiveXObject在word文档在插入图片
- 如何用js得到url转发前的url(非js的实现方式也可以)
- ScriptX打印组件能实现 联机打印吗
- 请问如何用javascript判断来自html文本框中的数据是整型并且在0和24之间。否则提示错误
- 没分了,但是还得问,请大家帮忙:怎样自动检测如果当前页没有被设置为首页,则在关闭ie的时候自动弹出提示窗口,怎么作?
- ★★★请问各位老师如何在页面中使用脚本得到该页面所有的CheckBox集合★★★
- 屏蔽IE工具栏等的高难度问题?????路过的高手都都看看吧;-)
- 如何分析JavaScript函数的调用关系?
- 如何优化JS隐藏页面图片功能
itemText.setAttribute("class", "schoolItem");
itemText.innerHTML = data[i];
itemText.setAttribute("title", data[i + 1]);
item.appendChild(itemText);
就这句没反应 ?
这么写 应该是没问题的 。
建议你写成字符串形式,写成属性这种方式很容易失效,我也遇到过
<head>
<title></title>
<style type="text/css">
#parent{position:relative;}
#ulPop{margin:0px;padding:0px;list-style-type:none;z-index:1;width:180px;display:none;border:1px solid #000;font-family:@微软雅黑;overflow:hidden;font-size:14px;}
#ulPop li{}
#ulPop li a{display:block; border:solid 1px red; width:100%;}
#ulPop li a:hover{background:#326bc5;color:#fff;}
.schoolItem{display:block;text-decoration:none;padding:0.2em 0.4em;line-height:15px;}
.itemOnSelected{background:#326bc5;color:#fff;line-height:24px;}
</style>
</head>
<body>
<div id="parent">
<input type="text" id="txtSuggest" />
<ul id="ulPop"></ul>
</div>
</body>
</html>
<script language="javascript" type="text/javascript">
var upKeyCode = 38, downKeyCode = 40, enterKeyCode = 13;
var xhr;
var input = $("txtSuggest"); var nowclick=false; //当前是否在点击li
//input.onblur = function () { $("ulPop").style.display = "none"; }
input.onblur = function () {
var nowclick=false; //清空点击状态
setTimeout(function(){
if(!nowclick){
//alert(nowclick);
$("ulPop").style.display = "none";
}
},300);
}
input.onfocus=function(){
if (this.value.length >= 1){
GetDataByKey(this.value);
}
}
input.options = $("ulPop").getElementsByTagName("li");
function CreateXMLHttpRequest() {
if (window.ActiveXObject) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
return new XMLHttpRequest();
}
}
function GetDataByKey(key) {
var a=[1,2,3,4,5,6];
FillData(a);
return;
var url = "Handler.ashx?keyword=" + escape(key);
xhr = CreateXMLHttpRequest();
xhr.onreadystatechange = function () {
if (xhr.readystate == 4) {
if (xhr.status == 200) {
var data = xhr.responseText.split(",");
if (data.length >= 1) FillData(data);
}
}
}
xhr.open("GET", url, true);
xhr.send(null);
}
input.selectedIndex = 0;
input.onkeyup = function (e) {
e = e == undefined ? window.event : e;
switch (e.keyCode) {
case upKeyCode:
clearSytleOnSelected(this);
this.selectedIndex--;
if (this.selectedIndex < 0)
this.selectedIndex = this.options.length - 1;
setSytleOnSelected(this);
break;
case downKeyCode:
clearSytleOnSelected(this);
this.selectedIndex++;
if (this.selectedIndex >= this.options.length) {
this.selectedIndex = 0;
}
setSytleOnSelected(this);
break;
case enterKeyCode:
input.value = this.options[this.selectedIndex].childNodes[0].innerHTML;
$("ulPop").style.display = "none";
break;
default:
if (this.value.length >= 1)
GetDataByKey(this.value);
else $("ulPop").style.display = "none";
break;
}
}
function $(id) {
return document.getElementById(id);
}
function FillData(data) {
$("ulPop").innerHTML = "";
for (var i = 0; i < data.length; i = i + 2) {
var item = document.createElement("li");
item.onmousedown=function(){
nowclick=true;
}
item.onclick = function () {
input.value=this.childNodes[0].title;
nowclick=false;
$("ulPop").style.display = "none";
}
var itemText = document.createElement("a");
itemText.setAttribute("class", "schoolItem");
itemText.setAttribute("href", "javascript:;");
itemText.innerHTML = data[i];
itemText.setAttribute("title", data[i + 1]);
item.appendChild(itemText); $("ulPop").appendChild(item);
}
$("ulPop").style.display = "block";
}
function clearSytleOnSelected(sender) {
if (sender.selectedIndex >= 0) {
sender.options[sender.selectedIndex].className = "";
}
}
function setSytleOnSelected(sender) {
sender.options[sender.selectedIndex].className = "itemOnSelected";
}
</script>
input.onblur = function () { $("ulPop").style.display = "none"; }
li.click前先执行了INPUT.BLUR所以你永远click不到li