Js常见的数组题目(接上篇)

简介: Js常见的数组题目

上文:Js数组常见的题目,你能做对几个


在javascript中求出2个数组的相同的元素及不同的元素


思路:先定义一个对象,把A数组转换成对象,然后遍历B数组,判断B数组中某一项是否在A数组那个对象里面 如果在的话,说明B数组与A数组有相同的元素,否则B数组和A数组有不同的元素有哪些;

/* 
 * 求出2个数组的相同的元素和不同的元素
 * 思路:先定义一个对象,把A数组转换成对象,然后遍历B数组,判断B数组中某一项是否在
 * A数组那个对象里面 如果在的话,说明有相同的元素,否则为不同的元素  */
function getArrsSameAndDiffElem(arrs1, arrs2) {
    var hash = {},
        sameElemArrs = [],
        diffElemArrs = [];
    if (arrs1.length > 0) {
        for (var i = 0, ilen = arrs1.length; i < ilen; i += 1) {
            hash[arrs1[i]] = 1;
        }
    }
    if (arrs2.length > 0) {
        for (var j = 0, jlen = arrs2.length; j < jlen; j += 1) {
            if (hash[arrs2[j]]) { 
            // 说明有相同的元素,把相同的元素存入sameElemArrs数组里面去
                            sameElemArrs.push(arrs2[j]);
            } else { // 说明是不同的元素,把不同的元素存入diffElemArrs数组里面去
                            diffElemArrs.push(arrs2[j]);
            }
        }
    }
    return {
        sameElemArrs: sameElemArrs,
        diffElemArrs: diffElemArrs
    }
}
var arrs1 = ["aac", "aab", "cfg", 'longen', 'tugenhua', 'single'];
var arrs2 = ["aac", "mnc", "nba", "cba", "anta", 'tugenhua', 'single'];
console.log(getArrsSameAndDiffElem(arrs1, arrs2)); // 打印出 diffElemArrs = ["mnc","nba","cba","anta"]
// 相同的元素 sameElemArrs = ["aac",'tugenhua','single']

如上可以看到 arrs2中与arr1中数组有相同的元素如上,不同的元素也如上;

如果需要判断arr1中与arr2中数组相同元素及不同的元素,传递参数调换位置即可!


Javascript检测2个数组是否相似


判断2个数组是否相似的条件:

  1. 先判断这两个对象是否为Array的实例。
  2. 接着判断该数组的长度是否一致。
  3. 判断该2个对象的类型是否一样,先对这2个数组先转换为字符串后,再进行排序比较,如果该2个对象类型的个数一致,长度一致,且都是数组,说明该2个数组是相似的;比如如下:
var arr11 = [11,true];var arr22 = [false,22];

如上2个数组是相似的,但是如果2个数组如下这样的话

var arr11 = [11,true];var arr22 = [false,true];

说明2个数组不相似了~ 代码如下:

function arraysSimilar(arr1, arr2) {
    if (!(arr1 instanceof Array) || !(arr2 instanceof Array)) {
        return false;
    }
    if (arr1.length !== arr2.length) {
        return false;
    }
    var arrsLen = arr1.length;
    var tempArrs1 = [],
        tempArrs2 = [];
    for (var i = 0; i < arrsLen; i += 1) {
        var t1 = Object.prototype.toString.apply(arr1[i]);
        tempArrs1.push(t1);
        var t2 = Object.prototype.toString.apply(arr2[i]);
        tempArrs2.push(t2);
    }
    return tempArrs1.sort().join() === tempArrs2.sort().join() ? true : false;
}
var arr1 = ["aa", "cc", false, "bb"];
var arr2 = ["11", "cc", "11", false];
console.log(arraysSimilar(arr1, arr2)); // true
var arr11 = [11, true];
var arr22 = [false, 22];
console.log(arraysSimilar(arr11, arr22)); // true


如何判断该对象是否为数组


1. typeof

 首先我们会想到的是使用typeof来检测数据类型,但是对于Function, String, Number, Undefined等这几种基本类型来说,使用typeof来检测都可以检测到,比如代码如下:

function test() {}
console.log(typeof 1); // number
console.log(typeof test); // function 
console.log(typeof "yunxi"); // string
console.log(typeof undefined); // undefined

但是对于数组或者正则来说,使用typeof来检测的话,那就满足不了,因为当我们检测数组或者正则的话,那么返回的类型将会是一个对象object,如下代码所示:

console.log(typeof []);  // object
console.log(typeof /\d+/g); // object

2. Instanceof

由此我们很容易会想到使用instanceof来检测某个对象是否是数组的实例,该检测会返回一个布尔型(boolean),如果是数组的话,返回true,否则的话返回false;我们再来看下上面的检测是否为数组的代码如下:

console.log([] instanceof Array);  // true
console.log(/\d+/g instanceof Array); // false

如上可以看到使用instanceof确实可以判断是否为数组的列子;

3. constructor属性

在javascript中,每个对象都有一个constructor属性,它引用了初始化该对象的构造函数,比如判断未知对象的类型,因此我们可以如下写一个方法:代码如下:

function isArray(obj) {
    return typeof obj == 'object' && obj.constructor == Array
}
// 测试demo
console.log(isArray([])); // true
var a = { "a": 1 };
console.log(isArray(a)); // false
var b = [1, 2, 3];
console.log(isArray(b)); // true
console.log(isArray(/\d+/g)); // false

如上可以看到,通过调用isArray 方法也可以判断是否为数组的列子。

我们现在可以看到,对于第二点和第三点分别使用instanceof方法和constructor属性貌似都可以来判断是否为数组了,但是也有列外情况,比如在跨框架iframe的时候使用页面中的数组时,会失败,因为在不同的框架iframe中,创建的数组是不会相互共享其prototype属性的;如下代码测试即可得到验证~

var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;       
var arr = new xArray("1","2","3","4","5");
//这个写法IE下是不支持的,标准浏览器firefox,chrome下有
console.log(arr);  // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false 
console.log(arr.constructor === Array); // false

如上的方法我们都不能来判断一个对象是否为数组的方式; 但是我们在看ECMA262中可以看到,可以使用 Object.prototype.toString.call()方法来判断一个对象是否为数组;如下代码:

function isArray(obj) {
    return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代码调用
console.log(isArray([]));  // true
console.log(isArray([1,2,3])); // true
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;       
var arr = new xArray("1","2","3","4","5");
console.log(arr); // ["1","2","3","4","5"]
console.log(isArray(arr));  // true


js将类数组对象转换成数组对象


首先我们来看一下类数组,什么是类数组,类数组有什么特征呢?

具有:有指向对象的数字索引 及 length属性值;

不具有:它不具有数组的方法,比如push,slice,pop等方法;

Javascript中常见的类数组有arguments, HTMLCollection的集合(比如document.getElementsByClassName,document.getElementsByTagName)等方法,常见的类数组对象有如下:

document.getElementsByClassName, document.getElementsByTagName,document.getElementsByName,arguments等等;比如如下测试代码:类数组可以有length属性,可以遍历,但是它并不是数组的实例,如下代码:

function elems(){
    for(var i = 0, ilen = arguments.length; i < ilen; i+=1) {
        console.log(arguments[i]); // 循环2次 打印出 1,2
    }
    console.log(arguments instanceof Array);// false
}
elems(1,2);

我们再来测试下arguments是否和数组一样有push方法;测试代码如下:

function test(){
    console.log(arguments.push(1)); //arguments.push is not a function
}
test();

在控制台中打印出 arguments.push is not a function 报错,说明类数组并不是一个真正的数组,因为它没有数组的方法;

但是我们可以将类数组转换为数组,我们可以使用slice()方法call对象;slice()方法可以将一个类数组对象/集合转换成一个数组,只需要使用数组原型上的slice方法call这个对象,即Array.prototype.slice.call(arguments);即可将类数组转换为数组,或者我们也可以使用[].slice.call(arguments);来转换数组;

如下代码:

function test(){
    //var args = [].slice.call(arguments);
    var args = Array.prototype.slice.call(arguments);
    console.log(args.push(1)); //1
}
test();

使用上面的 [].slice.call()方法和 Array.prototype.slice.call()方法都可以将类数组转换为数组的,比如上面的args就是转换后的数组,其后就拥有push()方法;

当然如果我们不嫌麻烦的话,我们可以先在函数内部定义一个新数组,然后使用arguments.length的属性遍历每一项,把每一项存入到新数组里面去也是可以的,但是这样做并没有上面的好;如下代码:

function elems(){
    var newArrs = [];
    for(var i = 0, ilen = arguments.length; i < ilen; i+=1) {
        newArrs[i] = arguments[i];
    }
    console.log(newArrs); // [1,2]
}
elems(1,2);

目录
相关文章
|
9小时前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
23 3
|
9小时前
|
JavaScript
通过使用online表单的获取使用,了解vue.js数组的常用操作
通过使用online表单的获取使用,了解vue.js数组的常用操作
|
9小时前
|
存储 JavaScript 前端开发
深入了解JavaScript中的indexOf()方法:实现数组元素的搜索和索引获取
深入了解JavaScript中的indexOf()方法:实现数组元素的搜索和索引获取
8 0
|
9小时前
|
JavaScript 前端开发
js关于数组的方法
js关于数组的方法
11 0
|
9小时前
|
JavaScript 前端开发
js怎么清空数组?
js怎么清空数组?
13 0
|
9小时前
|
存储 JavaScript 前端开发
js处理数组的方法
js处理数组的方法
14 2
|
9小时前
|
JavaScript 前端开发 索引
JavaScript 数组的索引方法数组转换为字符串方法
JavaScript 数组的索引方法数组转换为字符串方法
|
9小时前
|
JavaScript 前端开发
JavaScript 数组的添加删除和排序
JavaScript 数组的添加删除和排序
|
9小时前
|
JavaScript 前端开发
js 操作数组的方法
js 操作数组的方法
22 4
|
9小时前
|
JavaScript 前端开发
js数组过滤,从简单到多条!
js数组过滤,从简单到多条!