之前做一个云计算的项目,涉及到一个安全组自动联想的功能,思想是这样的:

安全组规则之间是可以相互引用的,也可以自己是自己手动输入的ip/mask,这时候可以加一个功能,实现securityGroupId和securityGroupName以及ip/mask之间随意的联想输入。 
主要实现方式是:后台处理securityGroupName和SecurityGroupName的组合列表,并且在前台做相应的处理,处理为数组对象,此时对名称和id的联想基本实现,如果再加上ip/task,只需做一些处理,创建一个新数组,拼接到之前的name和id的数组上,这时候就实现了securityGroupId和securityGroupName以及ip/mask之间随意的联想输入。
以下主要是实现ip/mask的转换,涉及一个最小掩码的算法,比如当前ip是10.12.0.0,这个时候需要计算出最小掩码,算法是:将该ip分段处理,如果第一个数不为0(,此处单纯的理解为10进制,也可以处理成2进制数之后相应的判断),那么查看后一位是否为0,这里以第二位为例(12)。因为第一位10后面的数(12)不为零,第二位12的后面的数(0)为零,则对12处理。12处理成2进制数为:00001100,掩码可最后一个1的位置有关,此时得出的数是6,那么第一位后面不为0,则第一位取全掩8,此时得出的值为8+6=14,也就是说该ip最后取出的最小掩码为14,还有三个是固定的,大家都会(14,16,24,34),如果不是以此往下类推。
  1. /**
  2. * IP自动联想
  3. *
  4. * @param input IP
  5. * @return IP/Task
  6. */
  7. function getIpArray(input){
  8. var ipArray = input.split('.');
  9. for( var i = 0; i < 4; i++){
  10. if (ipArray[i] == undefined || ipArray[i] == ''){
  11. ipArray[i] = 0;
  12. }
  13. //
  14. //      if(ipArray[i].indexOf('0') == 0 && ipArray[i].length > 1){
  15. //          ipArray[i] = ipArray[i].substring(1, ipArray[i].length);
  16. //      }
  17. }
  18. return ipArray;
  19. }
  20. function every(arr, func){
  21. var aa = [];
  22. for( var i = 0; i < arr.length; i++){
  23. aa.push(func(arr[i]));
  24. }
  25. return aa;
  26. }
  27. function indexOfEnd(str){
  28. for( var i = str.length - 1; i >= 0; i--){
  29. if (str.charAt(i) == '1') {
  30. return 8 - (str.length - i) + 1;
  31. }
  32. }
  33. return 0;
  34. }
  35. function getPermissions(input){
  36. var ipArray = getIpArray(input);
  37. var ip = ipArray.join('.');
  38. var binaryIpArray = every(ipArray, function(oct){
  39. return Number(oct).toString(2);
  40. });
  41. var yanma = 0;
  42. for( var i = binaryIpArray.length - 1; i >= 0; i--){
  43. if(binaryIpArray[i] != 0){
  44. yanma = indexOfEnd(binaryIpArray[i]) + i * 8;
  45. break;
  46. }
  47. }
  48. var abc = [ 8, 16, 24, 32 ];
  49. var rstArray = [ ip + '/' + yanma ];
  50. for( var i = 0; i < abc.length; i++){
  51. if(abc[i] > yanma){
  52. rstArray.push(ip + '/' + abc[i]);
  53. }
  54. }
  55. return rstArray;
  56. }

这里主要是在键盘事件触发的时候的一个脚本,实现自动联想

  1. /**
  2. * 创建安全组自动联想DOM
  3. */
  4. function createSgDom(input){
  5. var arrayObj = new Array();
  6. var ary = new Array();
  7. this.setNewAry([]);
  8. this.setAry([]);
  9. var autoData = jsonData.substring(1, jsonData.length -1).split(', ');
  10. for ( var element in autoData) {
  11. arrayObj.push(autoData[element]);
  12. }
  13. var permissions = /^((?:(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))\.){3}(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d))))$/;
  14. var ip_1 = /^((?:(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))[\.]?){1,3})$/;
  15. var str = /^[a-zA-Z]*([a-zA-Z]|[-])*$/;
  16. if(null != input && !str.test(input)){
  17. if(ip_1.test(input) || permissions.test(input)){
  18. var except = false;
  19. if(input.indexOf('.') > -1){
  20. var value = input.split('.');
  21. for(var val in value){
  22. var inVal = value[val];
  23. if(inVal.indexOf('0') == 0 && inVal.length > 1){
  24. except = true;
  25. }
  26. if(inVal>255){
  27. except = true;
  28. }
  29. }
  30. } else {
  31. if(input>255){
  32. except = true;
  33. }
  34. }
  35. if(!except){
  36. var ips = getPermissions(input);
  37. for(var ip in ips){
  38. ary.push(ips[ip]);
  39. }
  40. }
  41. }
  42. }
  43. if(ary != null){
  44. newAry = arrayObj.concat(ary);
  45. } else {
  46. newAry = arrayObj;
  47. }
  48. this.setNewAry(newAry);
  49. $('#suggest_value').autocomplete({
  50. source: this.getNewAry(),
  51. minLength: 0,
  52. close: function(event, ui){
  53. },
  54. focus: function(event, ui){
  55. return false;
  56. },
  57. change: function(event, ui){
  58. },
  59. select: function(event, ui){
  60. if(ui.item.label.indexOf('(') > -1 && ui.item.label.indexOf(')') > -1){
  61. ui.item.value = ui.item.label.substring(0, ui.item.label.indexOf('('));
  62. }else{
  63. ui.item.value = ui.item.label.substring(0, ui.item.label.length);
  64. }
  65. }
  66. });
  67. }

最后:

    1. //在输入框加上一个keyup事件,指定执行脚本:createSgDom($('#suggest_value').val());
    2. // 引入自动联想插件和上面处理ip掩码的脚本
    3. <script type="text/javascript" src="theme/default/js/cbms/ip-permissions.js"></script>
    4. <%-- <script src="theme/default/jquery-ui/js/jquery-1.8.3.js" type="text/javascript"></script> --%>
    5. <script src="theme/default/jquery-ui/js/jquery-ui-1.8.24.custom.min.js" type="text/javascript"></script>

jQuery/javascript实现IP/Mask自动联想功能的更多相关文章

  1. Java开发工具MyEclipse的设置自动联想功能

    最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共通之处它都具备,比如说基本的设置.编辑区.调试区都是类似的, ...

  2. UITextField关闭自动联想功能

    在textField输入内容时,如果内容为英文,输入的英文如果不正确的单词就是有红色的线报警,关闭英文自动联想功能 self.autocorrectionType = UITextAutocorrec ...

  3. Java初学者不可不知的MyEclipse的设置技巧(自动联想功能)

    最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共通之处它都具备,比如说基本的设置.编辑区.调试区都是类似的, ...

  4. Myeclipse设置自动联想功能

    ///声明,博客园暂无转载功能,这篇博客是转载自贞心真义. 最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共 ...

  5. IDEA 代码自动补全/自动联想 功能

    IDEA 的代码补全/自动联想功能,可以仅仅输入几个字母,自动补全一整段代码,非常舒服. 代码自动联想功能在 设置 -> Editor -> Live Templates 查看,很多都非常 ...

  6. 基于JQuery实现的文本框自动填充功能

    1. 实现的方法 /* * js实现的文本框的自动完成功能 */ function doAutoComplete(textid,dataid,url){ $("#" + texti ...

  7. 使用TaskManager爬取2万条代理IP实现自动投票功能

    话说某天心血来潮想到一个问题,朋友圈里面经常有人发投票链接,让帮忙给XX投票,以前呢会很自觉打开链接帮忙投一票.可是这种事做多了就会考虑能不能使用工具来进行投票呢,身为一名程序猿决定研究解决这个问题. ...

  8. Ajax实现搜索栏中输入时的自动提示功能

    使用 jQuery(Ajax)/PHP/MySQL实现自动完成功能 JavaScript代码: <script src="jquery-1.2.1.pack.js" type ...

  9. salesforce零基础学习(八十)使用autoComplete 输入内容自动联想结果以及去重实现

    项目中,我们有时候会需要实现自动联想功能,比如我们想输入用户或者联系人名称,去联想出系统中有的相关的用户和联系人,当点击以后获取相关的邮箱或者其他信息等等.这种情况下可以使用jquery ui中的au ...

随机推荐

  1. 深入理解javascript作用域系列第三篇

    前面的话 一般认为,javascript代码在执行时是由上到下一行一行执行的.但实际上这并不完全正确,主要是因为声明提升的存在.本文是深入理解javascript作用域系列第三篇——声明提升(hois ...

  2. 2016 湖南省省赛B题《有向无环图》

    题目链接[https://vjudge.net/problem/CSU-1804] 题意: 给出一个有向无环图,然后让你算下面的结果,count(i,j)表示i->j之间的路径条数. 题解: 根 ...

  3. 【BZOJ 4663】 (最小割)

    4663: Hack Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 69  Solved: 26 Description 由于 FZYZ 教学区禁止使 ...

  4. 20162327WJH《程序设计与数据结构》课程总结

    20162327<程序设计与数据结构>课程总结 一.每周作业链接汇总 预备作业1:第一篇博客主要谈论了对本学期学习的展望,树立了一个目标. 预备作业2:简单的谈了谈自己的优势和一些成功的案 ...

  5. 1.8(SQL学习笔记)触发器

    一.触发器简介 当需要某些操作在某些语句执行之前或之后执行就需要使用触发器. 例如每次插入数据时进行数据校对,每次删除数据后将删除内容备份到新表. 这些操作我们希望它(某些语句)在满足某些条件时自动执 ...

  6. Java 请求webServce接口 带参数

    public String getWebServiceByParams(String param){ //获取基金缴付记录 // Post请求的url,与get不同的是不需要带参数 URL postU ...

  7. bzoj 1789: [Ahoi2008]Necklace Y型项链 贪心

    1789: [Ahoi2008]Necklace Y型项链 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/Jud ...

  8. ExtJs2.0学习系列(12)--Ext.TreePanel之第一式

    今天开始,我们就开始一起学习TreePanel了,道个歉,上篇的代码很乱阿. 我总是喜欢用最简单的例子开始,去理解最基本的使用方法,减少对i后面高级使用的干扰! TreePanel是继承自Panel, ...

  9. Centos 6/ 7下通过yum安装php7环境

    本文转自:云溪社区 2015年12月初PHP7正式版发布,迎来自2004年以来最大的版本更新.PHP7最显著的变化就是性能的极大提升,已接近Facebook开发的PHP执行引擎HHVM.在WordPr ...

  10. ASM相关视图

    oracle asm对于我们并非一个黑盒子 ,我们能够通过对应视图查看asm instance信息,和oracle系统视图一样. v$asm_diskgroup x$kfgrp  记录diskgrou ...