解决方案 »
- 晒几条自个写的js封装函数,大虾们见笑!
- 监听浏览器打开新的窗口
- 求救 jquery动画同时进行问题
- 我要用jquery写一些前台的js,有哪些工具可以有提示功能。。
- 除了ext外,哪种做框架更好一些?请高人赐教!
- 100分求[XmlHttp]后编码紊乱的问题.
- 客户端如何实现,选择不同的单选按钮选项,出现不同的table表格?
- 求对联广告(不浮动、可关闭)和浮动广告(与csdn网站首页效果差不多)的javascript代码。急用!!!
- 如何真正实现打印页面时隐藏页眉和页脚以及 设置边框的边距?望高手解决!急!
- 100分求修改<Meta >标签的Charset属性为gb2312
- 如何实现这样一个效果
- 多个栏目,怎么调用一个选项卡模板?
var arr2 = ['1000', '1001', '1002', '1003', '1004'];
var a = arr1.join(";");
for(var i=0,len=arr2.length;i<len;i++){
var reg = new RegExp("(^|;)"+arr2[i]+"(;|$)","g");
a = a.replace(reg,";");
}
a = a.replace(/^\;+|\;+$/g,"");
Result = a.split(";");
console.log(Result);类似这样。
/**
* each是一个集合迭代函数,它接受一个函数作为参数和一组可选的参数
* 这个迭代函数依次将集合的每一个元素和可选参数用函数进行计算,并将计算得的结果集返回
{%example
<script>
var a = [1,2,3,4].each(function(x){return x > 2 ? x : null});
var b = [1,2,3,4].each(function(x){return x < 0 ? x : null});
alert(a);
alert(b);
</script>
%}
* @param {Function} fn 进行迭代判定的函数
* @param more ... 零个或多个可选的用户自定义参数
* @returns {Array} 结果集,如果没有结果,返回空集
*/
Array.prototype.each = function(fn){
fn = fn || Function.K;
var a = [];
var args = Array.prototype.slice.call(arguments, 1);
for(var i = 0; i < this.length; i++){
var res = fn.apply(this,[this[i],i].concat(args));
if(res != null) a.push(res);
}
return a;
};
/**
* 得到一个数组不重复的元素集合<br/>
* 唯一化一个数组
* @returns {Array} 由不重复元素构成的数组
*/
Array.prototype.uniquelize = function(){
var ra = new Array();
for(var i = 0; i < this.length; i ++){
if(!ra.contains(this[i])){
ra.push(this[i]);
}
}
return ra;
};
/**
* 求两个集合的补集
{%example
<script>
var a = [1,2,3,4];
var b = [3,4,5,6];
alert(Array.complement(a,b));
</script>
%}
* @param {Array} a 集合A
* @param {Array} b 集合B
* @returns {Array} 两个集合的补集
*/
Array.complement = function(a, b){
return Array.minus(Array.union(a, b),Array.intersect(a, b));
};
/**
* 求两个集合的交集
{%example
<script>
var a = [1,2,3,4];
var b = [3,4,5,6];
alert(Array.intersect(a,b));
</script>
%}
* @param {Array} a 集合A
* @param {Array} b 集合B
* @returns {Array} 两个集合的交集
*/
Array.intersect = function(a, b){
return a.uniquelize().each(function(o){return b.contains(o) ? o : null});
};
/**
* 求两个集合的差集
{%example
<script>
var a = [1,2,3,4];
var b = [3,4,5,6];
alert(Array.minus(a,b));
</script>
%}
* @param {Array} a 集合A
* @param {Array} b 集合B
* @returns {Array} 两个集合的差集
*/
Array.minus = function(a, b){
return a.uniquelize().each(function(o){return b.contains(o) ? null : o});
};
/**
* 求两个集合的并集
{%example
<script>
var a = [1,2,3,4];
var b = [3,4,5,6];
alert(Array.union(a,b));
</script>
%}
* @param {Array} a 集合A
* @param {Array} b 集合B
* @returns {Array} 两个集合的并集
*/
Array.union = function(a, b){
return a.concat(b).uniquelize();
};
<script language="javascript"> var arr1 = ['1000', '1001',"556", '1002', '1003', '1004', '1005', '1006', '1007', '1008', '1009', ];
var arr2 = ["23",'1010','1000', '1002',"45",'1003', '1004'];
var s=com(arr1,arr2);alert(s);function com(a,b){
var array1=a.length>=b.length?a:b;
var array2=a.length>=b.length?b:a;
for( var i=0;i<array2.length;i++){
var index=contains(array2[i],array1);
if(index!=-1){array1.splice(contains(array2[i],array1),1);array2.splice(contains(array2[i],array2),1);
i=i-1;
}
}
var ss=array1.concat(array2);
return ss;
}
闲来无事,搞一搞function contains(a,b){for(var i=0;i<b.length;i++){
if(b[i]==a)return i;}
return -1;
}</script>
</head>
<body>
</body>
</html>