狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

功能強(qiáng)大的Javascript虛擬鍵盤,推薦使用

admin
2013年2月16日 10:25 本文熱度 5113




文章簡(jiǎn)介:先簡(jiǎn)單介紹一下VirtualKeyboard,它內(nèi)置了100多種鍵盤布局和200多種輸入法,9套可選皮膚方案,而且支持自建輸入法,功能相當(dāng)強(qiáng)大。

最近做項(xiàng)目,我負(fù)責(zé)做網(wǎng)頁前端,客戶需要利用觸摸屏進(jìn)行操作,不外接鼠標(biāo)鍵盤,但要求能錄入文字,包括數(shù)字,英文,中文。思考了一下,決定用JS實(shí)現(xiàn)虛擬鍵盤。


首先上網(wǎng)搜索了一下JS虛擬鍵盤,在經(jīng)過仔細(xì)篩選后,相中了VirtualKeyboard,一款功能強(qiáng)大的JS虛擬鍵盤插件。


先簡(jiǎn)單介紹一下VirtualKeyboard,它內(nèi)置了100多種鍵盤布局和200多種輸入法,9套可選皮膚方案,而且支持自建輸入法,功能相當(dāng)強(qiáng)大。


先附上下載地址,我傳到網(wǎng)盤里了,目前的最新版本3.71:http://dl.vmall.com/c0os8yayzc


下載下來先查看它的演示文檔,依次打開Jsvk\jscripts\demo_inline.html,看到虛擬鍵盤做的還是蠻漂亮的,而且支持中文拼音輸入,完全符合預(yù)期。如下圖所示:



集成到項(xiàng)目中去,說干就干!


首先將Jsvk\jscripts目錄下的文件復(fù)制到項(xiàng)目中去,文本文件和html演示文件可以刪掉。


項(xiàng)目頁面中引用JS文件:

  1. <script type="text/javascript" src="jscripts/vk_loader.js?vk_layout=CN%20Chinese%20Simpl.%20Pinyin&vk_skin=flat_gray" ></script> 

解釋一下:vk_layout=CN%20Chinese%20Simpl.%20Pinyin 表示默認(rèn)輸入法設(shè)置為簡(jiǎn)體中文,vk_skin=flat_gray 表示默認(rèn)皮膚選用flat_gray。這兩個(gè)可以根據(jù)個(gè)人需要進(jìn)行設(shè)置。


調(diào)用/隱藏虛擬鍵盤的函數(shù):

  1. VirtualKeyboard.toggle("txt_Search""softkey"); 

txt_Search是文本框的ID,softkey是虛擬鍵盤顯示位置元素的ID。


下面是個(gè)簡(jiǎn)單的例子:

  1. <html> 
  2.     <head> 
  3.     <script type="text/javascript" src="vk_loader.js?vk_layout=CN%20Chinese%20Simpl.%20Pinyin&vk_skin=flat_gray" ></script> 
  4.     </head> 
  5.     <body> 
  6.         <input type="text" id="txt_Search" onfocus="VirtualKeyboard.toggle('txt_Search', 'softkey')" onblur="VirtualKeyboard.toggle('txt_Search','softkey');" /> 
  7.         <div id="softkey"></div> 
  8.     </body> 
  9. </html> 

效果:



一步一步定制自己需要的功能


基本功能實(shí)現(xiàn)了,接下來就是中英文切換。先點(diǎn)擊CapsLock切換到大寫試試,結(jié)果失望了,中文狀態(tài)下切換到大寫輸入的依然是中文。只能點(diǎn)擊右下角的輸入法選擇菜單,找到US,切換到英文輸入法。這可不行,每次都要在上百個(gè)選項(xiàng)里來回切換,用戶體驗(yàn)得有多差啊!


于是,我有了初步想法,清空下拉列表,手動(dòng)構(gòu)建一個(gè)只有中文和英文選項(xiàng)的列表。要清空下拉列表,首先要知道它的ID,這種層一般都是動(dòng)態(tài)創(chuàng)建的,于是找到Jsvk\jscripts\virtualkeyboard.js,打開一看,不出所料,代碼是壓縮過以后的,能直接讀懂的都是神人。于是要先對(duì)它進(jìn)行解壓。打開http://jsbeautifier.org/,將JS文件中的代碼復(fù)制到輸入框中,點(diǎn)擊一下按鈕,解壓完成。ctrl+a,ctrl+c復(fù)制到新的JS文件中,OK,可以閱讀了。搜索”<select“關(guān)鍵字,一下子就找到了,代碼如下:

  1. "<select id=\"kb_langselector\"></select>" + "<select id=\"kb_mappingselector\"></select>" 

kb_mappingselector是鍵盤布局選擇框的ID,kb_langselector是輸入法選擇框的ID,kb_langselector就是我們要的ID。


有了ID,就可以修改了,因?yàn)槭莿?dòng)態(tài)創(chuàng)建的,只有當(dāng)創(chuàng)建完成以后才可以取到它的ID,于是我把代碼寫到了虛擬鍵盤加載之后。


以下代碼用到了JQuery框架,需要先引用JQuery方可正常使用。

  1. function test(){  
  2. $("#kb_langselector").empty().append("<option value='US US'>英文</option><option value='CN Chinese Simpl. Pinyin'>中文</option>").change(function (){   
  3. VirtualKeyboard.switchLayout(this.value);return false;  
  4. });  

測(cè)試一下發(fā)現(xiàn)了問題,載入停在了10%,頁面提示JS錯(cuò)誤。




通過錯(cuò)誤描述大概猜到是我構(gòu)建的option有問題,但具體問題出在哪我?guī)捉?jīng)跟蹤調(diào)試也沒找到,如果哪位大俠找到錯(cuò)誤還望不吝賜教!


遇到錯(cuò)誤久攻不下,轉(zhuǎn)變思路吧!


初步設(shè)想失敗了,于是我轉(zhuǎn)變思路,既然我構(gòu)建的有問題,那好,我不構(gòu)建了,你自己構(gòu)建,但多余的我不需要。


按照這個(gè)思路,我重新研究加載代碼,發(fā)現(xiàn)輸入法加載的JS是在Jsvk\jscripts\layouts\layouts.js中定義的。于是果斷刪除多余的選項(xiàng),只留下了Chinese Simpl. Pinyin和US兩個(gè)選項(xiàng)。改完后的效果圖如下,只有中文和英文兩個(gè)選項(xiàng),清爽多了。



這還不是我想要的!


中英文切換實(shí)現(xiàn)了,但操作還不夠便捷,我需要的是一鍵切換,為什么不在鍵盤中增加一個(gè)切換鍵呢?


首先找到皮膚文件,\Jsvk\jscripts\css\flat_gray\button_set.png,我要自己動(dòng)手加個(gè)按鍵!


原圖:



修改后:



只改圖片肯定不夠,按鈕定位在樣式表里,繼續(xù)修改樣式表!在樣式表\Jsvk\jscripts\css\flat_gray\keyboard.css最后加入下面的代碼。

  1. #kbDesk div#kb_binput_method {  
  2.     float: right;  
  3.     width: 102px;  
  4. }  
  5. #kbDesk div#kb_binput_method a {  
  6.         background-position: -453px 0px;  
  7. }  
  8. #kbDesk div#kb_binput_method.kbButtonHover a {  
  9.         background-position: -453px -38px;  
  10. }  
  11. #kbDesk div#kb_binput_method.kbButtonDown a {  
  12.         background-position: -453px -76px;  

接下來要在JS文件中給按鈕定義事件。打開virtualkeyboard.js,找到

  1. var C = {  
  2. 'backspace',  
  3. 'tab',  
  4. 'enter',  
  5. 'caps',  
  6. 'shift_left',  
  7. 'shift_right',  
  8. 'del',  
  9. 'ctrl_left',  
  10. 'alt_left',  
  11. 'space',  
  12. 'alt_right',  
  13. 'ctrl_right' 
  14.     }; 

在下面加上59: 'input_method',記得在'ctrl_right'后面加上逗號(hào)。修改后:

  1. var C = {  
  2. 'backspace',  
  3. 'tab',  
  4. 'enter',  
  5. 'caps',  
  6. 'shift_left',  
  7. 'shift_right',  
  8. 'del',  
  9. 'ctrl_left',  
  10. 'alt_left',  
  11. 'space',  
  12. 'alt_right',  
  13. 'ctrl_right',  
  14. 'input_method' 
  15.     }; 

繼續(xù)找到按鈕點(diǎn)擊響應(yīng)代碼:

  1. var d = function (i) {  
  2.         var e = DOM.getParent(i.srcElement || i.target, 'a');  
  3.         if (!e || e.parentNode.id.indexOf(Q) < 0) return;  
  4.         e = e.parentNode;  
  5.         var iI = X;  
  6.         var il = e.id.substring(Q.length);  
  7.         switch (il) {  
  8.             case "caps":  
  9.                 iI = iI ^ s;  
  10.                 break;  
  11.             case "shift_left":  
  12.             case "shift_right":  
  13.                 if (i.shiftKey) break;  
  14.                 iI = iI ^ Z;  
  15.                 break;  
  16.             case "alt_left":  
  17.             case "alt_right":  
  18.             case "ctrl_left":  
  19.             case "ctrl_right":  
  20.                 iI = iI ^ (i.altKey << 1 ^ w) ^ (i.ctrlKey << 2 ^ W);  
  21.                 break;  
  22.             default:  
  23.                 if (_) DOM.CSS(e).addClass(y.buttonDown);  
  24.                 break 
  25.         }  
  26.         if (X != iI) {  
  27.             B(iI);  
  28.             b();  
  29.         }  
  30.         i.preventDefault();  
  31.         i.stopPropagation();  
  32.     }; 

修改為:

  1. var d = function (i) {  
  2.         var e = DOM.getParent(i.srcElement || i.target, 'a');  
  3.         if (!e || e.parentNode.id.indexOf(Q) < 0) return;  
  4.         e = e.parentNode;  
  5.         var iI = X;  
  6.         var il = e.id.substring(Q.length);  
  7.         switch (il) {  
  8.             case "caps":  
  9.                 iI = iI ^ s;  
  10.                 break;  
  11.             case "input_method":  
  12.                 if (document.getElementById("kb_langselector").value == 'US US') {  
  13.                     VirtualKeyboard.switchLayout("CN Chinese Simpl. Pinyin");  
  14.  
  15.                 }  
  16.                 else {  
  17.                     VirtualKeyboard.switchLayout("US US");  
  18.  
  19.                 }  
  20.                 break;  
  21.             case "shift_left":  
  22.             case "shift_right":  
  23.                 if (i.shiftKey) break;  
  24.                 iI = iI ^ Z;  
  25.                 break;  
  26.             case "alt_left":  
  27.             case "alt_right":  
  28.             case "ctrl_left":  
  29.             case "ctrl_right":  
  30.                 iI = iI ^ (i.altKey << 1 ^ w) ^ (i.ctrlKey << 2 ^ W);  
  31.                 break;  
  32.             default:  
  33.                 if (_) DOM.CSS(e).addClass(y.buttonDown);  
  34.                 break 
  35.         }  
  36.         if (X != iI) {  
  37.             B(iI);  
  38.             b();  
  39.         }  
  40.         i.preventDefault();  
  41.         i.stopPropagation();  
  42.     }; 

既然有了按鈕,就不需要顯示下面的下拉框了,所以,給它隱藏掉!


OK,大功告成!看下效果圖



外觀和功能搞定了,但一看它的文件夾,足足7M多,精簡(jiǎn)!精簡(jiǎn)過程就不寫啦,精簡(jiǎn)完成后:



寫了這么多,謝謝你能把它看完,最后放上全部修改精簡(jiǎn)完成之后的源碼!


http://dl.vmall.com/c06xvbxyjx


原文鏈接:http://www.cnblogs.com/nnzfly/archive/2013/01/22/2871547.html


該文章在 2013/2/16 10:25:45 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved