js 弹出虚拟键盘修改密码的简单实例


Posted in Javascript onOctober 10, 2016

实例如下:

//定义当前是否大写的状态
window.onload=
  function()
  {
    password1=null;    
    initCalc();
  }

var CapsLockValue=0;

var check;
function setVariables() {
tablewidth=630; // logo width, in pixels
tableheight=20; // logo height, in pixels
if (navigator.appName == "Netscape") {
horz=".left";
vert=".top";
docStyle="document.";
styleDoc="";
innerW="window.innerWidth";
innerH="window.innerHeight";
offsetX="window.pageXOffset";
offsetY="window.pageYOffset";
}
else {
horz=".pixelLeft";
vert=".pixelTop";
docStyle="";
styleDoc=".style";
innerW="document.body.clientWidth";
innerH="document.body.clientHeight";
offsetX="document.body.scrollLeft";
offsetY="document.body.scrollTop";
  }
}
function checkLocation() {
if (check) {
objectXY="softkeyboard";
var availableX=eval(innerW);
var availableY=eval(innerH);
var currentX=eval(offsetX);
var currentY=eval(offsetY);
x=availableX-tablewidth+currentX;
//y=availableY-tableheight+currentY;
y=currentY;

evalMove();
}
setTimeout("checkLocation()",0);
}
function evalMove() {
//eval(docStyle + objectXY + styleDoc + horz + "=" + x);
eval(docStyle + objectXY + styleDoc + vert + "=" + y);
}
  self.onError=null;
  currentX = currentY = 0; 
  whichIt = null;      
  lastScrollX = 0; lastScrollY = 0;
  NS = (document.layers) ? 1 : 0;
  IE = (document.all) ? 1: 0;
  function heartBeat() {
    if(IE) { diffY = document.body.scrollTop; diffX = document.body.scrollLeft; }
    if(NS) { diffY = self.pageYOffset; diffX = self.pageXOffset; }
    if(diffY != lastScrollY) {
          percent = .1 * (diffY - lastScrollY);
          if(percent > 0) percent = Math.ceil(percent);
          else percent = Math.floor(percent);
          if(IE) document.all.softkeyboard.style.pixelTop += percent;
          if(NS) document.softkeyboard.top += percent; 
          lastScrollY = lastScrollY + percent;}
    if(diffX != lastScrollX) {
      percent = .1 * (diffX - lastScrollX);
      if(percent > 0) percent = Math.ceil(percent);
      else percent = Math.floor(percent);
      if(IE) document.all.softkeyboard.style.pixelLeft += percent;
      if(NS) document.softkeyboard.left += percent;
      lastScrollX = lastScrollX + percent;  }    }
  function checkFocus(x,y) { 
      stalkerx = document.softkeyboard.pageX;
      stalkery = document.softkeyboard.pageY;
      stalkerwidth = document.softkeyboard.clip.width;
      stalkerheight = document.softkeyboard.clip.height;
      if( (x > stalkerx && x < (stalkerx+stalkerwidth)) && (y > stalkery && y < (stalkery+stalkerheight))) return true;
      else return false;}
  function grabIt(e) {
    check = false;
    if(IE) {
      whichIt = event.srcElement;
      while (whichIt.id.indexOf("softkeyboard") == -1) {
        whichIt = whichIt.parentElement;
        if (whichIt == null) { return true; } }
      whichIt.style.pixelLeft = whichIt.offsetLeft;
      whichIt.style.pixelTop = whichIt.offsetTop;
      currentX = (event.clientX + document.body.scrollLeft);
        currentY = (event.clientY + document.body.scrollTop);   
    } else { 
      window.captureEvents(Event.MOUSEMOVE);
      if(checkFocus (e.pageX,e.pageY)) { 
          whichIt = document.softkeyboard;
          StalkerTouchedX = e.pageX-document.softkeyboard.pageX;
          StalkerTouchedY = e.pageY-document.softkeyboard.pageY;} }
    return true;  }
  function moveIt(e) {
    if (whichIt == null) { return false; }
    if(IE) {
      newX = (event.clientX + document.body.scrollLeft);
      newY = (event.clientY + document.body.scrollTop);
      distanceX = (newX - currentX);  distanceY = (newY - currentY);
      currentX = newX;  currentY = newY;
      whichIt.style.pixelLeft += distanceX;
      whichIt.style.pixelTop += distanceY;
      if(whichIt.style.pixelTop < document.body.scrollTop) whichIt.style.pixelTop = document.body.scrollTop;
      if(whichIt.style.pixelLeft < document.body.scrollLeft) whichIt.style.pixelLeft = document.body.scrollLeft;
      if(whichIt.style.pixelLeft > document.body.offsetWidth - document.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft = document.body.offsetWidth - whichIt.style.pixelWidth - 20;
      if(whichIt.style.pixelTop > document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5) whichIt.style.pixelTop = document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5;
      event.returnValue = false;
    } else { 
      whichIt.moveTo(e.pageX-StalkerTouchedX,e.pageY-StalkerTouchedY);
      if(whichIt.left < 0+self.pageXOffset) whichIt.left = 0+self.pageXOffset;
      if(whichIt.top < 0+self.pageYOffset) whichIt.top = 0+self.pageYOffset;
    if( (whichIt.left + whichIt.clip.width) >= (window.innerWidth+self.pageXOffset-17)) whichIt.left = ((window.innerWidth+self.pageXOffset)-whichIt.clip.width)-17;
      if( (whichIt.top + whichIt.clip.height) >= (window.innerHeight+self.pageYOffset-17)) whichIt.top = ((window.innerHeight+self.pageYOffset)-whichIt.clip.height)-17;
      return false;}
    return false;  }
  function dropIt() {whichIt = null;
    if(NS) window.releaseEvents (Event.MOUSEMOVE);
    return true;  }
  if(NS) {window.captureEvents(Event.MOUSEUP|Event.MOUSEDOWN);
    window.onmousedown = grabIt;
     window.onmousemove = moveIt;
    window.onmouseup = dropIt;  }
  if(IE) {
    document.onmousedown = grabIt;
     document.onmousemove = moveIt;
    document.onmouseup = dropIt;  }
//  if(NS || IE) action = window.setInterval("heartBeat()",1);



  document.write("<DIV align=center id=\"softkeyboard\" name=\"softkeyboard\" style=\"position:absolute; left:0px; top:0px; width:500px; z-index:180;display:none\"> <table id=\"CalcTable\" width=\"\" border=\"0\" align=\"center\" cellpadding=\"0\" cellspacing=\"0\" bgcolor=\"\">      <FORM id=Calc name=Calc action=\"\" method=post autocomplete=\"off\">    <tr> <td title=\"为保证后台登陆安全,建议使用输入器输入帐号密码\" align=\"right\" valign=\"middle\" bgcolor=\"\" style=\"cursor: default;height:30\"> <INPUT type=hidden value=\"\" name=password> <INPUT type=hidden value=ok name=action2> <font style=\"font-size:13px;\">-+-www.soojs.com?后台管理帐号密码输入器-+-</font>              <INPUT style=\"width:100px;height:20px;background-color:#54BAF1;\" type=button value=\"使用键盘输入\" bgtype=\"1\" onclick=\"password1.readOnly=0;password1.focus();softkeyboard.style.display='none';password1.value='';\"><span style=\"width:2px;\"></span></td>   </tr>   <tr align=\"center\">     <td align=\"center\" bgcolor=\"#FFFFFF\"> <table align=\"center\" width=\"%\" border=\"0\" cellspacing=\"1\" cellpadding=\"0\">\n     <tr align=\"left\" valign=\"middle\"> \n      <td> <input type=button value=\" ~ \"></td>\n      <td> <input type=button value=\" ! \"></td>\n      <td> <input type=button value=\" @ \"></td>\n      <td> <input type=button value=\" # \"></td>\n      <td> <input type=button value=\" $ \"></td>\n      <td> <input type=button value=\" % \"></td>\n      <td> <input type=button value=\" ^ \"></td>\n      <td> <input type=button value=\" & \"></td>\n      <td> <input type=button value=\" * \"></td>\n      <td> <input type=button value=\" ( \"></td>\n      <td> <input type=button value=\" ) \"></td>\n      <td> <input type=button value=\" _ \"></td>\n      <td> <input type=button value=\" + \"></td>\n      <td> <input type=button value=\" | \"></td>\n      <td colspan=\"1\" rowspan=\"2\"> <input name=\"button10\" type=button value=\" 退格\" onclick=\"setpassvalue();\" onDblClick=\"setpassvalue();\" style=\"width:100px;height:42px\"> \n      </td>\n     </tr>\n     <tr align=\"left\" valign=\"middle\"> \n      <td> <input type=button value=\" ` \"></td>\n      <td> <input type=button value=\" 1 \"></td>\n      <td> <input type=button value=\" 2 \"></td>\n      <td> <input type=button value=\" 3 \"></td>\n      <td> <input type=button value=\" 4 \"></td>\n      <td> <input type=button value=\" 5 \"></td>\n      <td> <input type=button value=\" 6 \"></td>\n      <td> <input type=button value=\" 7 \"></td>\n      <td> <input type=button value=\" 8 \"></td>\n      <td> <input type=button value=\" 9 \"></td>\n      <td> <input name=\"button6\" type=button value=\" 0 \"></td>\n      <td> <input type=button value=\" - \"></td>\n      <td> <input type=button value=\" = \"></td>\n      <td> <input type=button value=\" \\ \"></td>\n      <td> </td>\n     </tr>\n     <tr align=\"left\" valign=\"middle\"> \n      <td> <input type=button value=\" q \"></td>\n      <td> <input type=button value=\" w \"></td>\n      <td> <input type=button value=\" e \"></td>\n      <td> <input type=button value=\" r \"></td>\n      <td> <input type=button value=\" t \"></td>\n      <td> <input type=button value=\" y \"></td>\n      <td> <input type=button value=\" u \"></td>\n      <td> <input type=button value=\" i \"></td>\n      <td> <input type=button value=\" o \"></td>\n      <td> <input name=\"button8\" type=button value=\" p \"></td>\n      <td> <input name=\"button9\" type=button value=\" { \"></td>\n      <td> <input type=button value=\" } \"></td>\n      <td> <input type=button value=\" [ \"></td>\n      <td> <input type=button value=\" ] \"></td>\n      <td><input name=\"button9\" type=button onClick=\"capsLockText();setCapsLock();\" onDblClick=\"capsLockText();setCapsLock();\" value=\"切换大/小写\" style=\"width:100px;\"></td>\n     </tr>\n     <tr align=\"left\" valign=\"middle\"> \n      <td> <input type=button value=\" a \"></td>\n      <td> <input type=button value=\" s \"></td>\n      <td> <input type=button value=\" d \"></td>\n      <td> <input type=button value=\" f \"></td>\n      <td> <input type=button value=\" g \"></td>\n      <td> <input type=button value=\" h \"></td>\n      <td> <input type=button value=\" j \"></td>\n      <td> <input name=\"button3\" type=button value=\" k \"></td>\n      <td> <input name=\"button4\" type=button value=\" l \"></td>\n      <td> <input name=\"button5\" type=button value=\" : \"></td>\n      <td> <input name=\"button7\" type=button value=\" " \"></td>\n      <td> <input type=button value=\" ; \"></td>\n      <td> <input type=button value=\" ' \"></td>\n      <td rowspan=\"2\" colspan=\"2\"> <input name=\"button12\" type=button onclick=\"OverInput();\" value=\"  确定 \" style=\"width:130px;height:42\"></td>\n     </tr>\n     <tr align=\"left\" valign=\"middle\"> \n      <td> <input name=\"button2\" type=button value=\" z \"></td>\n      <td> <input type=button value=\" x \"></td>\n      <td> <input type=button value=\" c \"></td>\n      <td> <input type=button value=\" v \"></td>\n      <td> <input type=button value=\" b \"></td>\n      <td> <input type=button value=\" n \"></td>\n      <td> <input type=button value=\" m \"></td>\n      <td> <input type=button value=\" < \"></td>\n      <td> <input type=button value=\" > \"></td>\n      <td> <input type=button value=\" ? \"></td>\n      <td> <input type=button value=\" , \"></td>\n      <td> <input type=button value=\" . \"></td>\n      <td> <input type=button value=\" / \"></td>\n     </tr>\n    </table></td>  </FORM>   </tr> </table></DIV>")
//给输入的密码框添加新值
  function addValue(newValue)
  {
    if (CapsLockValue==0)
    {
      var str=Calc.password.value;
      if(str.length<password1.maxLength)
      {
        Calc.password.value += newValue;
      }      
      if(str.length<=password1.maxLength)
      {
        password1.value=Calc.password.value;
      }
    }
    else
    {
      var str=Calc.password.value;
      if(str.length<password1.maxLength)
      {
        Calc.password.value += newValue.toUpperCase();
      }
      if(str.length<=password1.maxLength)
      {
        password1.value=Calc.password.value;
      }
    }
  }
//实现BackSpace键的功能
  function setpassvalue()
  {
    var longnum=Calc.password.value.length;
    var num
    num=Calc.password.value.substr(0,longnum-1);
    Calc.password.value=num;
    var str=Calc.password.value;
      password1.value=Calc.password.value;
  }
//输入完毕
  function OverInput()
  {
    //m_pass.mempass.value=Calc.password.value;
    var str=Calc.password.value;
      password1.value=Calc.password.value;
      //alert(theForm.value);
    //theForm.value=m_pass.mempass.value;
    softkeyboard.style.display="none";
    Calc.password.value="";
    password1.readOnly=1;
    //password1.value=Calc.password.value;
  }
//关闭软键盘
  function closekeyboard(theForm)
  {
    //eval("var theForm="+theForm+";");
    //theForm.value="";
    softkeyboard.style.display="none";
    //Calc.password.value="";

  }
//显示软键盘
  function showkeyboard()
  {
    if(event.y+140)
    softkeyboard.style.top=event.y+document.body.scrollTop+15;
    if((event.x-250)>0)
    {
      softkeyboard.style.left=event.x-250;
    }
    else
    {
      softkeyboard.style.left=0;
    }
    
    softkeyboard.style.display="block";
    password1.readOnly=1;
    password1.blur();
    //password1.value="";
  }

//设置是否大写的值
function setCapsLock()
{
  if (CapsLockValue==0)
  {
    CapsLockValue=1
//    Calc.showCapsLockValue.value="当前是大写 ";
  }
  else 
  {
    CapsLockValue=0
//    Calc.showCapsLockValue.value="当前是小写 ";
  }
}


function setCalcborder()
{
  CalcTable.style.border="1px solid #0090FD"
}

function setHead()
{
  CalcTable.cells[0].style.backgroundColor="#7EDEFF"  
}

function setCalcButtonBg()
{
  for(var i=0;i<Calc.elements.length;i++)
  {
    if(Calc.elements[i].type=="button"&&Calc.elements[i].bgtype!="1")
    {
  //    if(i==10)
//  alert(123);
      Calc.elements[i].style.borderTopWidth= 0
      Calc.elements[i].style.borderRightWidth= 2
      Calc.elements[i].style.borderBottomWidth= 2
      Calc.elements[i].style.borderLeftWidth= 0
      Calc.elements[i].style.borderTopStyle= "none";
      Calc.elements[i].style.borderRightStyle= "solid";
      Calc.elements[i].style.borderBottomStyle= "solid";
      Calc.elements[i].style.borderLeftStyle= "none";
      //#46AC17
      Calc.elements[i].style.borderTopColor= "#118ACC";
      Calc.elements[i].style.borderRightColor= "#118ACC";
      Calc.elements[i].style.borderBottomColor= "#118ACC";
      Calc.elements[i].style.borderLeftColor= "#118ACC";
      //#CBF3B2
      Calc.elements[i].style.backgroundColor="#ADDEF8";

      
      
      var str1=Calc.elements[i].value;
      str1=str1.trim();
      /*
      if(str1=="`") 
      {
        Calc.elements[i].style.fontSize=14;
      }
      */

      if(str1.length==1)
      {
        //Calc.elements[i].style.fontSize=16;
        //Calc.elements[i].style.fontWeight='bold';
      }
      
      var thisButtonValue=Calc.elements[i].value;
      thisButtonValue=thisButtonValue.trim();
      if(thisButtonValue.length==1)
      {
        Calc.elements[i].onclick=
          function ()
          {
            var thisButtonValue=this.value;
            thisButtonValue=thisButtonValue.trim();
            addValue(thisButtonValue);
            //alert(234)
          }
        Calc.elements[i].ondblclick=
          function ()
          {
            var thisButtonValue=this.value;
            thisButtonValue=thisButtonValue.trim();
            addValue(thisButtonValue);
            //alert(234)
          }
      }
      
    }
  }
}

function initCalc()
{
  setCalcborder();
  setHead();
  setCalcButtonBg();
}

String.prototype.trim = function()
{
  // 用正则表达式将前后空格
  // 用空字符串替代。
  return this.replace(/(^\s*)|(\s*$)/g, "");
}

var capsLockFlag;
capsLockFlag=true;

function capsLockText()
{
if(capsLockFlag)//改成大写
{
  for(var i=0;i<Calc.elements.length;i++)
  {
      var char=Calc.elements[i].value;
      var char=char.trim()
    if(Calc.elements[i].type=="button"&&char>="a"&&char<="z"&&char.length==1)
    {
    
      Calc.elements[i].value=" "+String.fromCharCode(char.charCodeAt(0)-32)+" "
    }
  }
}
else
{
  for(var i=0;i<Calc.elements.length;i++)
  {
      var char=Calc.elements[i].value;
      var char=char.trim()
    if(Calc.elements[i].type=="button"&&char>="A"&&char<="Z"&&char.length==1)
    {
    
      Calc.elements[i].value=" "+String.fromCharCode(char.charCodeAt(0)+32)+" "
    }
  }
}
capsLockFlag=!capsLockFlag;
}

以上就是小编为大家带来的js 弹出虚拟键盘修改密码的简单实例全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
封装的jquery翻页滚动(示例代码)
Nov 18 Javascript
jQuery中index()方法用法实例
Dec 27 Javascript
javascript中AJAX用法实例分析
Jan 30 Javascript
IScroll5 中文API参数说明和调用方法
May 21 Javascript
HTML5基于Tomcat 7.0实现WebSocket连接并实现简单的实时聊天
Oct 31 Javascript
Javascript DOM事件操作小结(监听鼠标点击、释放,悬停、离开等)
Jan 20 Javascript
vue 组件使用中的一些细节点
Apr 25 Javascript
javascript、php关键字搜索函数的使用方法
May 29 Javascript
JavaScript设计模式之建造者模式实例教程
Jul 02 Javascript
node.js读取Excel数据(下载图片)的方法示例
Aug 02 Javascript
详解简单易懂的 ES6 Iterators 指南和示例
Sep 24 Javascript
深入理解Antd-Select组件的用法
Feb 25 Javascript
js捕捉键盘事件和按键键值的方法
Oct 10 #Javascript
js中获取键盘事件的简单实现方法
Oct 10 #Javascript
轻松实现jquery选项卡切换效果
Oct 10 #Javascript
为jQuery-easyui的tab组件添加右键菜单功能的简单实例
Oct 10 #Javascript
Javascript生成带参数的二维码示例
Oct 10 #Javascript
详细讲解JavaScript中的this绑定
Oct 10 #Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
Oct 10 #Javascript
You might like
dedecms防止FCK乱格式化你的代码的修改方法
2007/03/17 PHP
一些使用频率比较高的php函数
2008/10/03 PHP
Linux下PHP加速器APC的安装与配置笔记
2014/10/24 PHP
PHP针对多用户实现更换头像功能
2016/09/04 PHP
浅谈mysql_query()函数的返回值问题
2016/09/05 PHP
Java/JS获取flash高宽的具体方法
2013/12/27 Javascript
JQuery 控制内容长度超出规定长度显示省略号
2014/05/23 Javascript
分享10个原生JavaScript技巧
2015/04/20 Javascript
javascript数组去重的六种方法汇总
2015/08/16 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
详解用webpack把我们的业务模块分开打包的方法
2017/07/20 Javascript
JavaScript实现留言板案例
2020/03/17 Javascript
多个Vue项目部署到服务器的步骤记录
2020/10/22 Javascript
[01:28:56]2014 DOTA2华西杯精英邀请赛 5 24 CIS VS DK
2014/05/26 DOTA
python使用pil生成图片验证码的方法
2015/05/08 Python
Python3之简单搭建自带服务器的实例讲解
2018/06/04 Python
python 3调用百度OCR API实现剪贴板文字识别
2018/09/04 Python
Python实现批量修改图片格式和大小的方法【opencv库与PIL库】
2018/12/03 Python
Python 调用 zabbix api的方法示例
2019/01/06 Python
Python要如何实现列表排序的几种方法
2020/02/21 Python
Python requests HTTP验证登录实现流程
2020/11/05 Python
matplotlib实现数据实时刷新的示例代码
2021/01/05 Python
CSS3 please 跨浏览器的CSS3产生器
2010/03/14 HTML / CSS
前端canvas动画如何转成mp4视频的方法
2019/06/17 HTML / CSS
html5时钟实现代码
2010/10/22 HTML / CSS
详解移动端html5页面长按实现高亮全选文本内容的兼容解决方案
2016/12/03 HTML / CSS
美国时尚女装在线:Missguided
2016/12/03 全球购物
荷兰家电购物网站:Expert.nl
2020/01/18 全球购物
建筑设计师岗位职责
2013/11/18 职场文书
印刷技术专业自荐信
2014/09/18 职场文书
离婚协议书范文2014
2014/10/16 职场文书
实习单位证明范例
2014/11/17 职场文书
教师先进个人材料
2014/12/17 职场文书
格列佛游记读书笔记
2015/06/30 职场文书
为什么MySQL 删除表数据 磁盘空间还一直被占用
2021/10/16 MySQL
vscode内网访问服务器的方法
2022/06/28 Servers