Javascript 使用jquery和onchange获取输入值
我有一个动态表,可以根据需要使用jquery在其中添加许多行 在这几行上有一个选择列表下拉列表。此选择有一个列表。 在所选选项的函数中,我尝试执行一个ajax请求,并将结果应用于此行的一个输入中 我实际遇到的问题是,我无法获取相关行的所选列表的值。我在选择列表中添加了一个类。请求在更改时发生,但无法获取选择列表的值 以下是我尝试过的:Javascript 使用jquery和onchange获取输入值,javascript,jquery,ajax,selectlist,Javascript,Jquery,Ajax,Selectlist,我有一个动态表,可以根据需要使用jquery在其中添加许多行 在这几行上有一个选择列表下拉列表。此选择有一个列表。 在所选选项的函数中,我尝试执行一个ajax请求,并将结果应用于此行的一个输入中 我实际遇到的问题是,我无法获取相关行的所选列表的值。我在选择列表中添加了一个类。请求在更改时发生,但无法获取选择列表的值 以下是我尝试过的: <script type="text/javascript"> $().ready(function(){
<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>
返回以下内容而不是其值:
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
借
第一个表达式返回负责获取值的函数。第二个将执行它,并实际返回字段的值。感谢您的回复,但实际上它返回给我的是“未定义”而不是值如果您将
find(“input.debours\u tva”).val替换为find(.debours\u tva”).val()
?thisvar debours\u id=$(this.closest(“tr”).find(“debours\u tva”).val()console.log(debours\u id)
返回给我“undefined”您忘记了“debours\u tva”之前的点:它应该是.find(“.debours\u tva”)
很好,很好,非常感谢您的帮助,我昨天才开始学习jquery,并不像看起来那么容易。
.val
.val()