前端的朋友可能遇到过这样的需求,要求在页面输入一串序列号,或激活码(就像在PC正版软件中的序列号),可是HTML中并没有为我们提供类似的组件,我们来自己实现一个:

大体的思路是在表单里有一个隐藏的input,而表面上用一组input代替:

 <form name="" action="" method="post">
<p>
<label>请输入激活码:</label>
<span class="act-code-group">
<input id="act-code-item-1" name="act-code-item-1" class="act-code-item" type="text" /> -
<input name="act-code-item-2" class="act-code-item" type="text" /> -
<input name="act-code-item-3" class="act-code-item" type="text" /> -
<input name="act-code-item-4" class="act-code-item" type="text" />
</span>
<input class="act-code-hidden" type="hidden" value="" />
</p>

至于式样上的东西就留给大家,自己发挥吧!

然后我们来处理一下相关逻辑:

 function initActCodeGroup(dom){
var $ = jQuery;
var actCodeGroup = dom,
actCodeItem = actCodeGroup.find('.act-code-item');
var ctrlPress = false;
//actCodeItem.attr('maxlength', '5');
actCodeItem.keyup(function(e){
var oldVal = $(this).val();
if(e.keyCode === 8){
// backspace
if(oldVal.length <= 0){
$(this).prev().focus();
}
}else if(e.keyCode === 86 && ctrlPress){
//ctrl + v
var parseTxt = $(this).val(),
parseTxtLen = parseTxt.length; ctrlPress = false; var actCodes = [];
if(parseTxt.indexOf('-') >= 0){
actCodes = parseTxt.split('-');
}else{
if(parseTxtLen >= 4){
actCodes.push(parseTxt.substr(0, 4));
}else{
actCodes.push(parseTxt.substr(0, parseTxtLen));
}
if(parseTxtLen >= 8){
actCodes.push(parseTxt.substr(4, 4));
}else{
actCodes.push(parseTxt.substr(4, parseTxtLen-4));
}
if(parseTxtLen >= 12){
actCodes.push(parseTxt.substr(8, 4));
}else{
actCodes.push(parseTxt.substr(8, parseTxtLen-8));
}
if(parseTxtLen >= 16){
actCodes.push(parseTxt.substr(12, 4));
}else{
actCodes.push(parseTxt.substr(12, parseTxtLen-12));
}
} if(actCodes.length > 1){
var curInput = $(this);
$.each(actCodes, function(i, v){
if(curInput && v.length <= 4){
curInput.val(v);
curInput = curInput.next();
}else{
return false;
}
});
} }else if(e.keyCode === 17){
setTimeout(function(){
ctrlPress = false;
}, 1000);
}else{
if(oldVal.length >= 4){
$(this).val(oldVal.substr(0,4));
if($(this).next().length > 0){
$(this).next().focus();
}
}
}
}).keydown(function(e){
if(e.keyCode === 17){
ctrlPress = true;
}
});
}

这样就实现了4*4的序列号组件,接下来调用这个初始化函数就好了

$(document).ready(function(){
initActCodeGroup($('.act-code-group'));
});

打开浏览器看看我们的序列号组件吧!

js 实现序列号效果实现的更多相关文章

  1. React.js实现原生js拖拽效果及思考

    一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...

  2. 用js实现动画效果核心方式

    为了做好导航菜单,有时候需要在菜单下拉的时候实现动画效果,所以这几天就研究了研究如何用js实现动画效果,实现动画核心要用到两个函数,一个是setTimeOut,另一个是setInterval. 下边我 ...

  3. js拖拽效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 原生JS实现分页效果2.0(新增了上一页和下一页,添加当前元素样式)

    虽然写的很烂,但至少全部都是自己写的,因为这个没有固定的顺序,所以就没有封装,如果你技术好的话,可以你写的分享给我,谢谢. <!DOCTYPE html><html lang=&qu ...

  5. 原生JS实现分页效果1.0

    不太完整,写的太急,等等加上完整注释,写起来还是有些难度的,写的有点水,后面再改进改进. <!DOCTYPE html><html lang="en">&l ...

  6. 使用JS实现手风琴效果

    想要实现简单的手风琴切换效果,需要使用JS实现,如下是使用javascript源码实现,后续会更新使用jQuery实现. 1. 先进行简单的布局:我们可以再ul下添加几个li实现html的简单布局,再 ...

  7. js弹窗登录效果(源码)--web前端

    1.JS弹窗登录效果 <!DOCTYPE html><html lang="en"><head> <meta charset=" ...

  8. 原生JS实现弹幕效果

    纯属无聊写的,可能有很多问题,欢迎批评指教. 效果图:图一是预设的一些弹幕,图二是自己发射的弹幕,效果是一样的.   首先是弹幕的位置,是要从最右滑到最左,为了防止随机高度弹幕会覆盖的问题,设置了通道 ...

  9. JS添加标签效果

    JS添加标签效果 在豆瓣网上添加自己的标签是一种常见的效果,今天也就做了一个简单的demo.由于时间的问题 我不多原理,大家可以试着操作几遍就能明白其中的原理了. JSFiddle的效果如下: 点击我 ...

随机推荐

  1. git使用笔记-基础篇

    git使用手册:https://git-scm.com/book/zh/v1/ 一.分支 1.查看所有本地分支 git branch 2.查看所有本地分支和远程分支 git branch -a 3.查 ...

  2. git跟svn 服务端对比

    Git已经火了很久,简单的使用也没有问题,但有几个问题一直以来都没有搞清楚:git跟svn有哪些异同,两者相互的优劣是什么,git的分布式怎么理解,为什么有离线提交,,,自己动手,分别看一下服务端跟客 ...

  3. ubuntu使用ppa源安装最新版本的git

    国内也有ubuntu镜像源.但是里面的git都是1.9版本.最新的已经是2.3了 1 首先使用将ppa源加入Ubuntu,交大家 sudo add-apt-repository ppa:pdoes/p ...

  4. verilog if语句

    a.基本形式 1) if(表达式) 语句1: 2)if(表达式) 语句1: else 语句1 3) if(表达式1) 语句1: else   if(表达式2) 语句2: else   if(表达式3) ...

  5. script脚本中写不写$(document).ready(function() {});的区别

    $(document).ready() 里的代码是在页面内容都加载完才执行的,如果把代码直接写到script标签里,当页面加载完这个script标签就会执行里边的代码了,此时如果你标签里执行的代码调用 ...

  6. python 字符串转字节数组

    场景: java加解密和python加解密互转的时候,因一些非显示字符无法确认两者是否一致,故需要打出他们的十六进制字节数组进行比较 1.python代码实现 str='123';print str. ...

  7. vue学习中遇到的onchange、push、splice、forEach方法使用

    最近在做vue的练习,发现有些js中的基础知识掌握的不牢,记录一下: 1.onchange事件:是在域的内容改变时发生,单选框与复选框改变后触发的事件. 2.push方法:向数组的末尾添加一个或多个元 ...

  8. 基于 MUI 构建一个具有 90 +页面的APP应用

    前言 mui是一款接近原生App体验的前端框架,只需要掌握前端技术就可以开发APP应用,官方有提供功能比较全面的demo版本, 但在实战中总会遇到一些不可避免但坑,对于没有接触过mui的开发者,难免会 ...

  9. 从零开始的全栈工程师——js篇(作用域 this 原型笔试题练习)

    作用域 // 1. fn() function fn () { console.log(12) } var as = function () { console.log(45) } // 2. var ...

  10. eclipse 构建从 SVN 上下载的可识别的 maven 项目

    从 SVN 上下载的 maven 项目中含有父项目,属于 maven 的嵌套,每个子项目和父项目虽有 pom.xml 文件,在结构上也是 maven 然而并不是 eclipse 识别的 maven 项 ...