【问题标题】:JQuery .focus() event changing DropDown optionJQuery .focus() 事件更改 DropDown 选项
【发布时间】:2011-04-06 13:38:48
【问题描述】:

我有一个选择列表,它是在网格内使用 jquery 构建的。当用户输入一个键时,选择列表被构建,然后我调用 click() 和 focus() 以便我可以再次使用键命令。

我遇到的问题是 .focus() 在触发时会更改选择列表的选择。有没有人经历过这种行为或找到解决方法?提前致谢

function INTEREST_createPaymentTypeDropDown() {
    //Interest specific:
    //build a dropdown for the enum
    //if the PaymentType input exists
    if ($("#PaymentType").length > 0) {

        var cellPaymentTypeValue = $("#PaymentType").val();
        var selectedOption;

        $("#PaymentType").replaceWith("<select id='PaymentType' style='width:95px; height: 20px;' name='PaymentType'></select>");
        $.each(INTEREST_PAYMENT_TYPES, function(key, val) {
            var newoption = $("<option value=\"" + val + "\">" + key + "</option>");

            if (val == cellPaymentTypeValue || key == cellPaymentTypeValue) {
                //append select to the current value
                selectedOption = val;
            }
            $("#PaymentType").append(newoption);
            $("#PaymentType").addClass("t-input");
        });

        if (selectedOption != null) {
            $("#PaymentType").val(selectedOption.toString());
        }
    }


    function INTEREST_setEditField(field) {
        if ($("#PaymentType").length > 0) {
            // this is where the problem is
            $("#PaymentType").click();
        }
        else {
            $(".t-grid-content").find('.t-input').click();
            $(".t-grid-content").find('.t-input').select();
        }

        INTEREST_persistPaymentTypeOnCellChange(field);
    }

    function INTEREST_persistPaymentTypeOnCellChange(field) {
        //keep the value of the enum not the enum index
        //in the payment type field
        var paymentTypeCell = $(field).parent().children().eq(1);

        if ($(paymentTypeCell).html().length == 1) {
            $.each(INTEREST_PAYMENT_TYPES, function(key, val) {
                if ($(paymentTypeCell).html() == val) {
                    $(paymentTypeCell).html(key);
                }
            });
        }
    }

    $('td.t-grid-edit-cell', 'div#AccountPayments').live('keydown', function(event) {
        if (event.which == 39 || event.which == 9) //Tab or right arrow
        {
            if ($(this).hasClass('t-last')) {
                INTEREST_goToNextRow(this, event);
            }
            else {
                INTEREST_goToRight(this, event);
            }
        }
        else if (event.which == 37 || event.which == 9 && event.shiftKey) //left arrow. Todo: add shift tab
        {
            if ($(this).hasClass('t-first')) {
                INTEREST_goToPreviousRow(this, event);
            }
            else {
                INTEREST_goToLeft(this, event);
            }
        }
        else if (event.which == 40) //down arrow
        {
            INTEREST_goDown(this, event);
        }
        else if (event.which == 38) //up arrow
        {
            INTEREST_goUp(this, event);
        }
    });

    $("#PaymentType").live('click', function(event) {
        $(this).focus();
    });

【问题讨论】:

    标签: javascript jquery html focus telerik


    【解决方案1】:

    会不会是列表顶部没有空选项,所以当调用 click() 时,会导致 PaymentType 自动选择第 0 个选项?

    【讨论】:

    • 您好有空选项,但它会默认为第一个选项而不是第二个。当我从右侧或底部下拉时,它会从第一个更改为第二个,如果我从顶部输入,它会将其更改为第二个值。
    • 会不会和这条线有关? if (val == cellPaymentTypeValue || key == cellPaymentTypeValue) { //append select to the current value selectedOption = val; } 为什么代码会将keyval 与同一个变量进行比较?它们是一样的吗?
    • 另外,focus() 调用是否会发送您不一定期望的事件代码并触发keydown 事件或其他函数?此外,我假设没有为 focus() 函数定义特殊行为/函数。这些都是在黑暗中拍摄,如果没有帮助,我很抱歉。
    • 嗨,杰森,感谢您的回复。我将 key 和 val 与 my 变量进行比较的原因是,单元格中的值可能是字符串或整数。我很确定您对焦点是正确的,它似乎会关闭并调用其他事件,而这些事件又会再次调用焦点,这会更改选择列表选择的索引
    • focus 在我之前也发生了一些奇怪的事情。我正在设置focus,它没有将光标放在该字段中,但该字段实际上确实有焦点。我通过首先模糊场然后聚焦场来解决它。你可以试试看有没有帮助???
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-09-26
    • 2013-09-11
    • 2012-01-29
    • 1970-01-01
    • 1970-01-01
    • 2018-09-19
    • 2015-06-06
    相关资源
    最近更新 更多