[英]Access Div Contents using Up and Down Arrow Keys using javascript
我有一個Div標簽,其中包含4個子Div標簽
<Div id="Parent">
<div id="childOne">ChildOne </div>
<div id="childOne">ChildTwo </div>
<div id="childOne">ChildThree </div>
<div id="childOne">ChildFour </div>
</Div>
現在我想通過Java腳本使用上下箭頭鍵訪問這些子Div上面的div是在單擊TextBox時顯示的。我希望用戶可以選擇任何一個子div,並且其選定的值將出現在TextBox中。 我已經通過對每個childDiv附加了onClick事件來獲得最終結果。
這是一個免費的圖書館解決方案,可以幫助您入門。
您可能想添加在文本框獲得焦點或失去焦點時隱藏和顯示div的事件。 也許[esc]應該清除選擇? (我還沒有在ie中測試過)
<style>div.active{ background: red }</style>
<input type="text" id="tb">
<div id="Parent">
<div id="childOne">ChildOne </div>
<div id="childOne">ChildTwo </div>
<div id="childOne">ChildThree </div>
<div id="childOne">ChildFour </div>
</div>
<script type="text/javascript">
function autocomplete( textBoxId, containerDivId ) {
var ac = this;
this.textbox = document.getElementById(textBoxId);
this.div = document.getElementById(containerDivId);
this.list = this.div.getElementsByTagName('div');
this.pointer = null;
this.textbox.onkeydown = function( e ) {
e = e || window.event;
switch( e.keyCode ) {
case 38: //up
ac.selectDiv(-1);
break;
case 40: //down
ac.selectDiv(1);
break;
}
}
this.selectDiv = function( inc ) {
if( this.pointer !== null && this.pointer+inc >= 0 && this.pointer+inc < this.list.length ) {
this.list[this.pointer].className = '';
this.pointer += inc;
this.list[this.pointer].className = 'active';
this.textbox.value = this.list[this.pointer].innerHTML;
}
if( this.pointer === null ) {
this.pointer = 0;
this.list[this.pointer].className = 'active';
this.textbox.value = this.list[this.pointer].innerHTML;
}
}
}
new autocomplete( 'tb', 'Parent' );
</script>
您是否在尋找所謂的自動完成或建議?
您是什么意思“使用箭頭鍵訪問它們”? 每個div中都有文本...它們不包含任何交互元素,因此鍵盤在這里沒有相關性。 也許您需要闡述您的問題?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.