繁体   English   中英

如何在电子邮件地址输入字段中显示默认域名?

[英]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 |

默认域显示在光标右侧,直到用户开始键入与默认域不匹配的域名。

有关如何实现这一目标的任何想法?

使用selectionStart

这是一个例子:

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);

现场演示

这是非常不优雅和基本的例子,但你可以建立它。 基本上,你可以;

  1. 使用默认域预填充输入
  2. 跟踪当前键入的电子邮件
  3. 单击时强制用户开始输入
  4. 如果用户键入“@”字符,您知道他们想要一个不同的域
  5. 将输入值替换为用户到目前为止输入的内容

像这样;

 $(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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM