强制让输入框文本以大写显示的方法

发布时间:2020-08-31 10:55:24 作者:小新
来源:亿速云 阅读:266

这篇文章将为大家详细讲解有关强制让输入框文本以大写显示的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、在输入时使用JavaScript更改文本(必须使用英文输入)

使用toUpperCase()转换大写

这是最明显和最常见的方法,但也是用户最不友好的方法。在每次击键时,都会触发JavaScript事件以将值转换为大写。

<input type="text" onkeyup="this.value = this.value.toUpperCase();">

我们来看看效果,输入一个小写的‘a’,会出现:

强制让输入框文本以大写显示的方法

但这种方法会出现其他问题:

1、当我们使用中文输入法,在按shift输入字符时,会出现重复字符;因此必须使用英文输入。

强制让输入框文本以大写显示的方法

2、尝试在上面的输入框中输入“AAA”,选择中间的“A”并尝试将其更改为“ABBA”。你最终得到的是'ABAB',因为设置值会将光标移动到文本的末尾。

接下来我们改进一下,可以定位光标位置

如果将光标移动到文本中的较早位置并键入,它将被回显到已输入的文本的末尾。所以我们需要一些额外的代码来保留光标位置:

<input type="text" onkeyup="
  var start = this.selectionStart;
  var end = this.selectionEnd;
  this.value = this.value.toUpperCase();
  this.setSelectionRange(start, end);
">

看看效果,输入ss:

强制让输入框文本以大写显示的方法

并且当我们输入“AAA”,选择中间的“A”并尝试将其更改为“ABBA”,也不会在出现'ABAB'的结果了。

二、使用css+php更改文本

实际上,如果表单输入是大写或小写,则不重要。重要的是:

1、用户看到的文本将被使用;

2、我们的表单处理程序在使用之前将文本转换为大写。

考虑到这一点,我们可以抛弃所有前面的JavaScript,而是使用简单的CSS和PHP(或等效的后端)解决方案:

html+css代码

<input style="text-transform: uppercase;" type="text" name="fieldname">

php代码:

<?PHP
  $_POST['fieldname'] = strtoupper($_POST['fieldname']);
?>

效果图:

强制让输入框文本以大写显示的方法

如果使用适当的技术,你看到有多简单吗!单个CSS样式(可以移动到外部样式表),加上一行PHP,可能已经存在。不需要JavaScript或jQuery。

关于强制让输入框文本以大写显示的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. bootstrap让图片居中显示的方法
  2. iOS强制转屏、强制横屏和强制竖屏的实现方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

css

上一篇:使用<nav>链接实现滚动到页面某一部分的方法

下一篇:使用css定位html元素的方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》