2016-05-16 38 views
1

當在文本框中輸入至少2個字符時,自動完成jQuery顯示數據庫中所有用戶的列表。自動完成正在處理正常的輸入字段,但是當通過innerHTML進行基因處理時,它不起作用。如何在innerhtml生成的文本框中插入自動完成的jquery

自動完成的工作在以下領域: -

<input type="text" id="j_d_permit_by[]" name="j_d_permit_by[]" > 

按鈕的點擊會增加其他領域以及調用addjobdesc功能: -

<img src="images/add.png" width="12" height="12"> <a href="javascript: addjobdesc();">Add New Job Description</a><br /> 

功能: -

 function addjobdesc() { 
    var div = document.createElement('div'); 

     div.className = 'row'; 

     div.innerHTML = '<table id="tblObs" name="tblObs" width="70%" bgcolor="#CCCCCC"><tr bordercolor="#FFFFFF"> 
    <td colspan="5"><b>Job Description (Work Ppermit/ Activity)</b></td></tr> 

<tr bgcolor="#33CC00"> 

    <td ><center> <b>Exact Location</b> </center></td> <td><b><center>Permit Initiated By<br />/<br />Activity Supervised by</center></b></td> 

    <td><b><center>Permit Accepted By<br />/<br />aActivity Executor</center></b></td><td><b><center>For What Permit Issued</center></b></td> 

    <td><b><center>Observation</center></b></td></tr> 
    <tr><td><center><select name="s_area[]" id="s_area" onchange="addSubArea()"> 
    <option value="0">Chose Sub Area</option></select></center></td> 

    <td><input type="text" id="j_d_permit_by_add" name="j_d_permit_by[]"></td> 

    <td><center><select id="j_d_accept_by[]" name="j_d_accept_by[]" ><option value="0">Select User</option><?php $users = getUserS(); 
    while($usersss = mysql_fetch_array($users)){ ?> 
    <option value="<?php echo $usersss[0];?>"><?php echo $usersss[4]." ".$usersss[5]; ?></option> 
    <?php } ?> 
    </select></td> 

    <td><center><textarea name="permit_ref[]" cols="30"> </textarea></center></td> 

<td><center><textarea name="obs_permit[]" id="obs_permit" cols="30"></textarea></center></td></tr></table><input class="submit" type="button" value="Remove" onclick="removeR0ow__(this)">'; 

    <!--<input type="hidden" name="j_d_Location[]" id="j_d_Location" value="" /><input type="text" name="area_Location[]" id="area_Location" value="" readonly="readonly" />--> 

    document.getElementById('job_desc').appendChild(div); 

jQuery(document).ready(function(){ 
      $('#j_d_permit_by_add').autocomplete({ 
        source: 'suggest_name.php', 
        minLength:2 
        }); 
      }); 

    var Max_Length = parseInt(document.getElementsByName('s_area[]').length)-1; 
    document.getElementsByName('s_area[]').item(Max_Length).innerHTML = ''; 
    document.getElementsByName('s_area[]').item(Max_Length).innerHTML = document.getElementById('sarea_div').innerHTML; 
    } 

我想自動完成在i中生成的j_d_permit_by []字段上工作nnerHTML。

非常感謝您的幫助。

+0

您能寫出完整的代碼嗎?對於函數addjobdesc ..確定 – Sachin

+0

在問題中編輯 –

+0

id = j_d_permit_by_add的輸入在jQuery(document).ready中不可用,因此函數未綁定到輸入。 – Sachin

回答

0

你已經綁定autocompletejQuery(document).ready但當時沒有輸入與id =j_d_permit_by_add存在,因此該函數不綁定到輸入。你是動態生成的輸入,所以你必須綁定autocomplete功能在以下方式..

試試這個綁定的自動完成功能:

jQuery(document).ready(function(){ 
    $(document).on('#j_d_permit_by_add', selector, function() { 
     $(this).autocomplete({ 
      source: 'suggest_name.php', 
      minLength:2 
     }); 
    }); 
}); 

你可以參考https://stackoverflow.com/a/25114244/1659563

@Guruprasad也是正確的,您可以在動態生成輸入後綁定autocomplete函數function addjobdesc()

+0

感謝您的解釋,我明白爲什麼它不工作。自動完成仍然無法正常工作 –

+0

我也嘗試過在綁定自動完成功能後再次登錄 document.getElementById('job_desc')。appendChild(div); –

+0

Thanks man!更改了一下代碼後它工作了! –