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

常用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();//清空下拉框
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是针对你的问题的解决方案。 1. 实现 input 下拉框模糊搜索 你可以使用 Vue 的 computed 属性来实现下拉框的模糊搜索,具体实现可以参考以下代码: ```html <template> <div> <input type="text" v-model="search" @input="searchData" /> <ul> <li v-for="item in filteredData" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { data() { return { data: [ { id: 1, name: 'Apple' }, { id: 2, name: 'Banana' }, { id: 3, name: 'Orange' }, { id: 4, name: 'Pineapple' }, { id: 5, name: 'Pear' }, ], search: '', }; }, computed: { filteredData() { const search = this.search.toLowerCase(); return this.data.filter((item) => item.name.toLowerCase().includes(search)); }, }, methods: { searchData() { // 搜索操作 }, }, }; </script> ``` 这个例子中,我们使用 data 来存储所有的数据,然后使用 search 来存储搜索关键字。在 computed 中,我们使用 filteredData 来过滤数据,只展示与搜索关键字匹配的数据。 2. 解决 IOS 的 keyup 兼容性问题 在 IOS 中,keyup 事件可能不会触发,而是会触发 input 事件。为了解决这个问题,你可以使用 v-model 来绑定输入框的值,然后使用 watch 来监听输入框的变化,具体实现可以参考以下代码: ```html <template> <div> <input type="text" v-model="search" /> </div> </template> <script> export default { data() { return { search: '', }; }, watch: { search(val) { // 输入操作 }, }, }; </script> ``` 在这个例子中,我们使用 v-model 来绑定输入框的值,然后使用 watch 来监听 search 的变化。这样无论是在 IOS 还是其他设备上,都可以监听输入框的变化了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值