我如何添加只读到特定的<输入>?.attr('readonly')不起作用。


当前回答

对于jQuery版本< 1.9:

$('#inputId').attr('disabled', true);

对于jQuery版本>= 1.9:

$('#inputId').prop('disabled', true);

其他回答

对于jQuery版本< 1.9:

$('#inputId').attr('disabled', true);

对于jQuery版本>= 1.9:

$('#inputId').prop('disabled', true);

使用$ .prop ()

$("#descrip").prop("readonly",true);

$("#descrip").prop("readonly",false);

启用只读功能:

$("#descrip").attr("readonly","true");

禁用只读

$("#descrip").attr("readonly","");

Readonly是html中定义的一个属性,所以把它当作一个属性来对待。

如果你想让对象不可编辑,你需要在对象中有类似readonly="readonly"的东西。 如果你想让它再次可编辑,你就不会有像readonly= "这样的东西(如果我理解正确的话,这不是标准的)。您确实需要整体删除该属性。

因此,在使用jquery时添加和删除它是有意义的。

设置为只读:

$("#someId").attr('readonly', 'readonly');

删除只读的:

$("#someId").removeAttr('readonly');

这是唯一对我有效的选择。 希望能有所帮助!

jQuery < 1.9

$('#inputId').attr('readonly', true);

jQuery 1 + 9。

$('#inputId').prop('readonly', true);

阅读更多关于prop和attr的区别