[英]How to show a default domain name in an email address input field?
我有一个需要电子邮件地址和密码的网站登录表单。 大多数用户具有相同的电子邮件地址域,但少数用户具有来自不同域的电子邮件地址。
有没有办法在电子邮件地址输入字段中自动使用默认域名,同时仍然允许用户键入不同的域名?
例如,如果| 是光标,键入时输入看起来像这样:
|@defaultreallylongdomain.com (用户尚未输入任何内容)
b|@defaultreallylongdomain.com
bo|@defaultreallylongdomain.com
bob|@defaultreallylongdomain.com
bob@|defaultreallylongdomain.com
鲍勃@ G |
。
。 (用户不断输入)
。
bob@gmail.com |
默认域显示在光标右侧,直到用户开始键入与默认域不匹配的域名。
有关如何实现这一目标的任何想法?
这是一个例子:
HTML
<input id='email' type='text'>
JS
const input = document.getElementById('email');
const defaultEmail = '@gmail.com';
input.value = defaultEmail;
function handleInput() {
const val = input.value;
const sel = input.selectionStart;
if (val.length - defaultEmail.length < sel) {
input.value = val.slice(0, sel)
input.removeEventListener('input', handleInput);
input.removeEventListener('focus', handleInput);
input.removeEventListener('click', handleInput);
}
}
input.addEventListener('input', handleInput);
input.addEventListener('focus', handleInput);
input.addEventListener('click', handleInput);
这是非常不优雅和基本的例子,但你可以建立它。 基本上,你可以;
像这样;
$(document).ready(function(){ let defaultDomain = 'exampledomain.net'; // use this to remove later let input = $("#testInput"); let typed = ""; // keep track of what the user has typed // put cursor at start when clicked input.click(function(){ $(this).get(0).setSelectionRange(0,0); }) input.keydown(function(e){ // @ is keycode 192 if(e.keyCode === 192){ // the user has typed @ and you can assume that they want a different domain input.val(typed.substring(0, typed.length - 1)); }else{ // store the email the user has typed so far, minnus default domain typed = input.val().replace(defaultDomain, ''); } }) })
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <input type="text" id="testInput" value="@exampledomain.net">
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.