常用input的常用方法(坑,兼容性问题及解决方法,取值)

本文深入探讨了HTML input元素的多种使用方法与常见问题,包括正则表达式限制输入、CSS样式调整、事件监听、type属性详解及兼容性解决方案。同时,对比了readonly与disabled属性在不同场景下的应用,提供了jQuery操作input值的实用技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用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();//清空下拉框
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值