jquery - как определить значение элемента при нажатии? - PullRequest
2 голосов
/ 10 июля 2009

как мне ввести значение tr в событие .click? я хочу иметь возможность передать идентификатор tr в updatedb.php - для обновления sql

введите

<head>
<script src="jquery-1.3.2.min.js" type="text/javascript"></script>
<script src="jquery.jeditable.mini.js" type="text/javascript"></script>

<script type="text/javascript">

    $(document).ready(function() {

var global= ""

$('.click').click(function() {
    var $this = $(this);
    var $tr = $this.closest('tr');

alert($tr.attr('id'));
global= $tr.attr('id');

});


    $('.click').editable('updatedb.php?test=123', { 
        indicator : "<img src='indicator.gif'>",
        tooltip   : "Click to edit...",
        onblur : 'submit',
        style  : "inherit"

    });


    });

</script>

</head>
<body>      
    <tr id=1>
    <td>
        <span class="click" style="display: inline">Funny click here testing!</span>
        <br />
        </td>    
    </tr>
    <tr id=2>
        <td>    
        <span class="click" style="display: inline">Second inline!</span>
        </td>
    <tr>    
</body>
</html>

здесь

Привет, jeditable не имеет преемника. Мне, наконец, удается получить значение в глобальном масштабе. Но сейчас стоит другая проблема. Jeditable не позволяет мне передавать дополнительную ценность ...

Я пытался редактируемый ( 'updatedb.php? тест = 123' затем эхо "СТАРТ". $ _POST ['test']. "END"

Я тоже пробовал другой способ, не работает.

Ответы [ 2 ]

4 голосов
/ 10 июля 2009

Возможно, вы захотите проверить плагин jQuery jEditable, преемник редактируемого. Ссылка: http://www.appelsiini.net/projects/jeditable

Возвращаясь к вашему вопросу, вы можете получить идентификатор узла TR в вашем примере, запросив атрибут с помощью parent (), closest () или parent (). Я бы рекомендовал против parent (), потому что он ожидает, что вы оставите вложенный HTML точно так же, как в вашем примере. Лучше использовать родителей () или ближайший () с фильтром.

$(document).ready(function() {
    $('.click').each(function() {
        var $this = $(this);
        var $tr = $this.closest('tr');
        // Do stuff with $tr like checking it, extracting $tr.attr('id') ...
        $this.editable('updatedb.php', {
            indicator : "",
            tooltip : "Click to edit...",
            onblur : 'submit',
            style : "inherit"
        });
    });
} 
4 голосов
/ 10 июля 2009
$(".click").click(function(){

 alert($(this).text())   // Funny click here testing! or Second inline!  (o/p);
 alert($(this).parent().parent().attr("id"))  // 1 or 2 (o/p);

});
...