当前位置:  开发笔记 > 编程语言 > 正文

HTML表单只读SELECT标签/输入

如何解决《HTML表单只读SELECT标签/输入》经验,为你挑选了14个好方法。

根据HTML规范,selectHTML中的标记没有readonly属性,只有disabled属性.因此,如果您希望阻止用户更改下拉列表,则必须使用disabled.

唯一的问题是禁用的HTML表单输入不会包含在POST/GET数据中.

模拟标记readonly属性的最佳方法是什么select,仍然可以获取POST数据?



1> bezmax..:

您应该保留select元素,disabled但也要添加另一个input具有相同名称和值的隐藏元素.

如果重新启用SELECT,则应将其值复制到onchange事件中的隐藏输入,并禁用(或删除)隐藏的输入.

这是一个演示:

$('#mainform').submit(function() {
    $('#formdata_container').show();
    $('#formdata').html($(this).serialize());
    return false;
});

$('#enableselect').click(function() {
    $('#mainform input[name=animal]')
        .attr("disabled", true);
    
    $('#animal-select')
        .attr('disabled', false)
    	.attr('name', 'animal');
    
    $('#enableselect').hide();
    return false;
});
#formdata_container {
    padding: 10px;
}

Submitted data:


2> vimal1083..:

我们也可以用它

禁用除所选选项以外的所有选项


这样下拉列表仍然有效(并提交其值),但用户无法选择其他值.

演示


适用于单值SELECT标签!但是不适用于

在IE 6,7和8b2,Firefox 2和3,Opera 9.62,适用于Windows和Google Chrome的Safari 3.2.1中进行了测试和工作.


这样做的问题是下拉列表就好像它不是只读的一样.用户会认为这个东西不起作用......
我遇到了类似的问题并解决了它只显示所选的选项.不需要JS,减少对用户的混淆......`
135369一生真爱_890
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有