javascript - 使用 jquery 和 onchange 获取输入值

标签 javascript jquery ajax selectlist

我有一个动态表,可以使用 jquery 根据需要添加许多行。

此行上有一个选择列表下拉列表。此选择有一个列表。 在所选选项的功能中,我尝试执行 ajax 请求并将结果应用于此行的输入之一。

我实际上遇到的问题是我无法获取相关行的选定列表的值。我将一个类添加到选择列表中。请求发生在 onchange 但无法获取选择列表的值。

以下是我尝试过的:

<script type="text/javascript">
            $().ready(function(){
            $('.debours_tva').change(function(e){
            var debours_id = $(this).closest("tr").find("input.debours_tva").val
            console.log(debours_id);
            var input = $(this).closest("tr").find("input.taux")
                $.ajax({
                url: 'requetes_ajax/check_taux_tva_debours.json.php',
                method: 'GET',
                data: 'debours_id=' + debours_id,
                success: function(returnData){
                    console.log(returnData);
                    if(returnData !=''){
                    input.removeAttr('value');
                    input.attr('value',returnData)
                    }else{

                    input.removeAttr('value');
                    input.attr('value',returnData)
                    }
                }, 
                dataType :'json'
                });
            });
            });
</script>

其实遇到的问题就是那一行

 var debours_id = $(this).closest("tr").find("input.debours_tva").val

返回以下内容而不是其值:

function ( value ) {
        var hooks, ret, isFunction,
            elem = this[0];

        if ( !arguments.length ) {
            if ( elem ) {
                hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ];

                if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) {
                    return ret;
                }

                ret = elem.value;

                return typeof ret === "string" ?
                    // handle most common string cases
                    ret.replace(rreturn, "") :
                    // handle cases where value is null/undef or number
                    ret == null ? "" : ret;
            }

            return;
        }

        isFunction = jQuery.isFunction( value );

        return this.each(function( i ) {
            var val,
                self = jQuery(this);

            if ( this.nodeType !== 1 ) {
                return;
            }

            if ( isFunction ) {
                val = value.call( this, i, self.val() );
            } else {
                val = value;
            }

            // Treat null/undefined as ""; convert numbers to string
            if ( val == null ) {
                val = "";
            } else if ( typeof val === "number" ) {
                val += "";
            } else if ( jQuery.isArray( val ) ) {
                val = jQuery.map(val, function ( value ) {
                    return value == null ? "" : value + "";
                });
            }

            hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];

            // If set returns undefined, fall back to normal setting
            if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) {
                this.value = val;
            }
        });
    } 

任何形式的帮助将不胜感激。

最佳答案

您需要更换

.val

.val()

第一个表达式返回负责获取值的函数。第二个将执行它并实际返回字段的值。

关于javascript - 使用 jquery 和 onchange 获取输入值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19584412/

相关文章:

javascript - React/js onClick 在父 div 和子 div 上。 parent 总是开火

javascript - 可以加载文件的 html/javascript 页面

javascript - 如果 jquery 验证激活,如何在单选按钮中放置红色边框

javascript - 如何为 Cordova 文件传输创建工作进度条

javascript - 如何单击超链接内的文本以便拖动并突出显示它?

javascript - 制作像 Tumblr 模板一样的图像网格

javascript - "onclick"事件在 FF 和 Chrome 中不起作用

javascript - 在JS中记录HTTP请求的字节大小

javascript - 所见即所得的 niceEdit 编辑器不适用于通过 ajax-php 调用生成的文本区域

javascript - 如何通过单击按钮来更新 Flask 应用程序中的一个元素?