常用input的方法(坑及解决方法):
- 一般这样用:
/[^\d\,]/g 只能输入数字
/[^\d\,]/g 只能输入数字和逗号,其中逗号是中文逗号
1.使input的光标隐藏
color:transparent;
text-shadow:0 0 0 #303030;——改变字体
2.使input获取/失去焦点
js — onfocus/onblur
jquery — focus()/blur()
3.type属性
button 定义可点击按钮(多数情况下,用于通过 JavaScript 启动脚本)。
checkbox 定义复选框。
file 定义输入字段和 "浏览"按钮,供文件上传。
hidden 定义隐藏的输入字段。
image 定义图像形式的提交按钮。
password 定义密码字段。该字段中的字符被掩码。
radio 定义单选按钮。
reset 定义重置按钮。重置按钮会清除表单中的所有数据。
submit 定义提交按钮。提交按钮会把表单数据发送到服务器。
text 定义单行的输入字段,用户可在其中输入文本。默认宽度为 20 个字符。
- 遇到问题:
比如兼容性问题:
input,textarea在ios系统,加disable属性,字体颜色会变浅
出现问题原因:
ios默认了disabled属性时透明度为0.8
解决办法:
input:disabled,textarea:disabled{
color:#989898;
-webkit-text-fill-color: #989898;
-webkit-opacity:1;
}
(颜色设置成自己想要的颜色)
- 使用disabled,会使input的其他事件也失效(想要input框只读不写)
<input type="text" readonly unselectable="on" onfocus="this.blur()"/>
// 1.unselectable属性作用
在IE浏览器中,当input获得焦点时,点击有unselectable=”on”属性的标签时,不会触发onblur事件。
// 2.onfocus=”this.blur()”方法作用
获取焦点时调用失去焦点事件
(补充Readonly和Disabled的区别)
它们都能够做到使用户不能更改表单域中的内容,但有细微差别:
- Readonly只针对input(text / password)和textarea有效,而disabled对于所有的表单元素都有效
- 表单元素在使用了disabled后,当我们将表单以POST或GET的方式提交的话,这个元素的值不会被传递出去
- readonly会将该值传递出去(readonly接受值更改可以回传,disable接受改但不回传数据)
使用场景
- 在某个表单中为用户预填了某个唯一识别代码,不允许用户改动,但是在提交时需要传递该值,此时应该将它的属性设置为readonly 。
- 经常遇到当用户正式提交了表单后需要等待管理员的信息验证,这就不允许用户再更改表单中的数据,而是只能够查看,由于disabled的作用元素范围大,所以此时应该使用disabled,但同时应该注意的是要将submit button也disabled掉,否则只要用户按了这个按钮,如果在数据库操作页面中没有做完整性检测的话,数据库中的值就会被清除。如果说在这种情况下用readonly来代替disabled的话,若表单中只有input(text / password)和textarea元素,那还是可以的,如果存在其他发元素,比如select,用户可以在重新改写值后按回车键进行提交(回车是默认的submit触发按键)
3.我们常常在用户按了提交按钮后,利用javascript将提交按钮disabled掉,这样可以防止网络条件比较差的环境下,用户反复点提交按钮导致数据冗余地存入数据库
场景区别
- 如果一个输入项的disabled设为true,则该表单输入项不能获取焦点,用户的所有操作(鼠标点击和键盘输入等)对该输入项都无效,最重要的一点是当提交表单时,这个表单输入项将不会被提交
- 而readonly只是针对文本输入框这类可以输入文本的输入项,如果设为true,用户只是不能编辑对应的文本,但是仍然可以聚焦焦点,并且在提交表单的时候,该输入项会作为form的一项提交
jQuery操作input值的各种方法总结
获取选中的值
- 获取一组radio被选中项的值
var item = $('input[@name=items][@checked]').val();
- 获取select被选中项的文本
var item = $("select[@name=items] option[@selected]").text();
获取值:
- 文本框,文本区域:
$("#txt").attr("value");
$("#txt").val();
- 多选框checkbox:
$("#checkbox_id").attr("value");
- 单选组radio:
$("input[@type=radio][@checked]").val();
- 下拉框select:
$('#sel').val();
控制表单元素:
- 文本框,文本区域:
$("#txt").attr("value",'');//清空内容
$("#txt").attr("value",'11');//填充内容
- 多选框checkbox:
$("#chk1").attr("checked",'');//不打勾
$("#chk2").attr("checked",true);//打勾
if($("#chk1").attr('checked')==undefined) //判断是否已经打勾
- 单选组radio:
$("input[@type=radio]").attr("checked",'2');//设置value=2的项目为当前选中项
- 下拉框select:
$("#sel").attr("value",'-sel3');//设置value=-sel3的项目为当前选中项
$("<optionvalue='1'>1111</option><optionvalue='2'> 2222</option>").appendTo("#sel")//添加下拉框的option
$("#sel").empty();//清空下拉框