jQuery/javascript实现IP/Mask自动联想功能
之前做一个云计算的项目,涉及到一个安全组自动联想的功能,思想是这样的:
主要实现方式是:后台处理securityGroupName和SecurityGroupName的组合列表,并且在前台做相应的处理,处理为数组对象,此时对名称和id的联想基本实现,如果再加上ip/task,只需做一些处理,创建一个新数组,拼接到之前的name和id的数组上,这时候就实现了securityGroupId和securityGroupName以及ip/mask之间随意的联想输入。
- /**
- * IP自动联想
- *
- * @param input IP
- * @return IP/Task
- */
- function getIpArray(input){
- var ipArray = input.split('.');
- for( var i = 0; i < 4; i++){
- if (ipArray[i] == undefined || ipArray[i] == ''){
- ipArray[i] = 0;
- }
- //
- // if(ipArray[i].indexOf('0') == 0 && ipArray[i].length > 1){
- // ipArray[i] = ipArray[i].substring(1, ipArray[i].length);
- // }
- }
- return ipArray;
- }
- function every(arr, func){
- var aa = [];
- for( var i = 0; i < arr.length; i++){
- aa.push(func(arr[i]));
- }
- return aa;
- }
- function indexOfEnd(str){
- for( var i = str.length - 1; i >= 0; i--){
- if (str.charAt(i) == '1') {
- return 8 - (str.length - i) + 1;
- }
- }
- return 0;
- }
- function getPermissions(input){
- var ipArray = getIpArray(input);
- var ip = ipArray.join('.');
- var binaryIpArray = every(ipArray, function(oct){
- return Number(oct).toString(2);
- });
- var yanma = 0;
- for( var i = binaryIpArray.length - 1; i >= 0; i--){
- if(binaryIpArray[i] != 0){
- yanma = indexOfEnd(binaryIpArray[i]) + i * 8;
- break;
- }
- }
- var abc = [ 8, 16, 24, 32 ];
- var rstArray = [ ip + '/' + yanma ];
- for( var i = 0; i < abc.length; i++){
- if(abc[i] > yanma){
- rstArray.push(ip + '/' + abc[i]);
- }
- }
- return rstArray;
- }
这里主要是在键盘事件触发的时候的一个脚本,实现自动联想
- /**
- * 创建安全组自动联想DOM
- */
- function createSgDom(input){
- var arrayObj = new Array();
- var ary = new Array();
- this.setNewAry([]);
- this.setAry([]);
- var autoData = jsonData.substring(1, jsonData.length -1).split(', ');
- for ( var element in autoData) {
- arrayObj.push(autoData[element]);
- }
- 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))))$/;
- var ip_1 = /^((?:(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))[\.]?){1,3})$/;
- var str = /^[a-zA-Z]*([a-zA-Z]|[-])*$/;
- if(null != input && !str.test(input)){
- if(ip_1.test(input) || permissions.test(input)){
- var except = false;
- if(input.indexOf('.') > -1){
- var value = input.split('.');
- for(var val in value){
- var inVal = value[val];
- if(inVal.indexOf('0') == 0 && inVal.length > 1){
- except = true;
- }
- if(inVal>255){
- except = true;
- }
- }
- } else {
- if(input>255){
- except = true;
- }
- }
- if(!except){
- var ips = getPermissions(input);
- for(var ip in ips){
- ary.push(ips[ip]);
- }
- }
- }
- }
- if(ary != null){
- newAry = arrayObj.concat(ary);
- } else {
- newAry = arrayObj;
- }
- this.setNewAry(newAry);
- $('#suggest_value').autocomplete({
- source: this.getNewAry(),
- minLength: 0,
- close: function(event, ui){
- },
- focus: function(event, ui){
- return false;
- },
- change: function(event, ui){
- },
- select: function(event, ui){
- if(ui.item.label.indexOf('(') > -1 && ui.item.label.indexOf(')') > -1){
- ui.item.value = ui.item.label.substring(0, ui.item.label.indexOf('('));
- }else{
- ui.item.value = ui.item.label.substring(0, ui.item.label.length);
- }
- }
- });
- }
最后:
- //在输入框加上一个keyup事件,指定执行脚本:createSgDom($('#suggest_value').val());
- // 引入自动联想插件和上面处理ip掩码的脚本
- <script type="text/javascript" src="theme/default/js/cbms/ip-permissions.js"></script>
- <%-- <script src="theme/default/jquery-ui/js/jquery-1.8.3.js" type="text/javascript"></script> --%>
- <script src="theme/default/jquery-ui/js/jquery-ui-1.8.24.custom.min.js" type="text/javascript"></script>
jQuery/javascript实现IP/Mask自动联想功能的更多相关文章
- Java开发工具MyEclipse的设置自动联想功能
最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共通之处它都具备,比如说基本的设置.编辑区.调试区都是类似的, ...
- UITextField关闭自动联想功能
在textField输入内容时,如果内容为英文,输入的英文如果不正确的单词就是有红色的线报警,关闭英文自动联想功能 self.autocorrectionType = UITextAutocorrec ...
- Java初学者不可不知的MyEclipse的设置技巧(自动联想功能)
最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共通之处它都具备,比如说基本的设置.编辑区.调试区都是类似的, ...
- Myeclipse设置自动联想功能
///声明,博客园暂无转载功能,这篇博客是转载自贞心真义. 最近初学Java,正在使用MyEclipse来编写新的项目,刚开始打开MyEclipse感觉这个工具既陌生又熟悉,熟悉之处在于编辑器的几大共 ...
- IDEA 代码自动补全/自动联想 功能
IDEA 的代码补全/自动联想功能,可以仅仅输入几个字母,自动补全一整段代码,非常舒服. 代码自动联想功能在 设置 -> Editor -> Live Templates 查看,很多都非常 ...
- 基于JQuery实现的文本框自动填充功能
1. 实现的方法 /* * js实现的文本框的自动完成功能 */ function doAutoComplete(textid,dataid,url){ $("#" + texti ...
- 使用TaskManager爬取2万条代理IP实现自动投票功能
话说某天心血来潮想到一个问题,朋友圈里面经常有人发投票链接,让帮忙给XX投票,以前呢会很自觉打开链接帮忙投一票.可是这种事做多了就会考虑能不能使用工具来进行投票呢,身为一名程序猿决定研究解决这个问题. ...
- Ajax实现搜索栏中输入时的自动提示功能
使用 jQuery(Ajax)/PHP/MySQL实现自动完成功能 JavaScript代码: <script src="jquery-1.2.1.pack.js" type ...
- salesforce零基础学习(八十)使用autoComplete 输入内容自动联想结果以及去重实现
项目中,我们有时候会需要实现自动联想功能,比如我们想输入用户或者联系人名称,去联想出系统中有的相关的用户和联系人,当点击以后获取相关的邮箱或者其他信息等等.这种情况下可以使用jquery ui中的au ...
随机推荐
- LR 报错误: C interpreter run time error: Error -- Unresolved symbol : vuser_end解决方法
Action.c(33): Error: C interpreter run time error: Action.c (33): Error -- Unresolved symbol : vuse ...
- XML DOM(Document Object Model)
1.XML DOM 是用于获取.更改.添加或删除 XML 元素的标准.2.节点(XML 文档中的每个成分都是一个节点): 整个文档是一个文档节点: 每个XML元素是一个元素 ...
- nhibernate 比较运算符
比较运算符 HQL运算符 QBC运算符 含义 = Restrictions.eq() 等于 <> Restrictions.not(Exprission.eq()) 不等于 > Re ...
- 哈尔滨理工大学第七届程序设计竞赛决赛(网络赛-高年级组)I - 没有名字
题目描述 tabris实在是太菜了,没打败恶龙,在绿岛也只捡到一块生铁回去了,为了不在继续拉低acimo星球的平均水平逃离地球,来到了Sabi星球. 在这里tabris发现了一种神奇的生物,这种生物不 ...
- Mybatis源码分析之结果集处理
解析封装 ResultMap 是和结果集相关的东西,最初在解析 XML 的时候,于 parseStatementNode 方法中,针对每一个 select 节点进行解析,转换为 MappedState ...
- Wireshark数据抓包教程之Wireshark捕获数据
Wireshark数据抓包教程之Wireshark捕获数据 Wireshark抓包方法 在使用Wireshark捕获以太网数据,可以捕获分析到自己的数据包,也可以去捕获同一局域网内,在知道对方IP地址 ...
- [BZOJ5109][LOJ #6252][P4061][CodePlus 2017 11月赛]大吉大利,今晚吃鸡!(最短路+拓扑排序+传递闭包+map+bitset(hash+压位))
5109: [CodePlus 2017]大吉大利,晚上吃鸡! Time Limit: 30 Sec Memory Limit: 1024 MBSubmit: 107 Solved: 57[Sub ...
- hdu 3001 三进制状压
题意:tsp问题,但是每个点可以最多走两次 链接:点我 转移方程见代码 #include<iostream> #include<cstdio> #include<cstr ...
- 线性DP POJ 1159 Palindrome
Palindrome Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 59101 Accepted: 20532 Desc ...
- 实用在线小工具 -- JS代码压缩工具
实用在线小工具 -- JS代码压缩工具 将JS代码进行压缩可以减少内存占用,下面链接是一个在线JS代码压缩工具,它将多余的空格和换行符压缩了. JS代码压缩工具链接:http://jspack ...