zoukankan      html  css  js  c++  java
  • JavaScript 常见基础问题二

    1、判断一个字符串中出现次数最多的字符,统计这个次数

    var str = "ababccddabbb"; 
    var obj = {}; 
    for (var i = 0; i < str.length; i++) { 
        var key = str.charAt(i); 
        if (!!obj[key]) { 
           obj[key]++; 
        } 
        else { 
           obj[key] = 1; 
        } 
    } 
    console.log(obj); 
    var max = -1, max_key = "", key; 
    for (key in obj) { 
        if (max < obj[key]) { 
           max = obj[key]; 
           max_key = key; 
        } 
    } 
    console.log(max_key + ":" + max);

    2、截取字符串abcdefg的efg

    var str = "abcdefg";
    var subStr="";
    if (/efg/.test(str)) {
        subStr=str.substr(str.indexOf("efg"),3);
    }
    console.log(subStr);

    3、求一个字符串的字节长度(一个英文字符占用一个字节,一个中文字符占用两个字节)

    function getBytes(str) {
        var len = str.length;
        var bytes = len;
        for (var i = 0; i < len; i++) {
            if (str.charCodeAt(i) > 255) {
                bytes++;
            }
        }
        return bytes;
    }
    console.log(getBytes("您好,hello"));

    4、assert判断类型

     
    var assert = {
        isBoolean: function (G) {
            return (typeof G === "boolean");
        },
        isNumber: function (G) {
            return (typeof G === "number" && isFinite(G));
        },
        isString: function (G) {
            return (typeof G === "string" || G.constructor == String);
        },
        isFunction: function (G) {
            var A = {};
            return (A.toString.apply(G) === A.toString.apply(Function));
        },
        isArray: function (G) {
            return Object.prototype.toString.call(G) === "[object Array]";
        },
        isObject: function (G) {
            return (G && (typeof G === "object" || this.isFunction(G)) || false);
        }
    };

    5、深度克隆对象

    基本类型(包括undefined,Null,boolean,String,Number),按值传递;
    引用类型(包括数组,对象),按址传递,引用类型在值传递的时候是内存中的地址。例如:
    var a = { "id": 1 };
    var b = a;
    b["name"] = 2;
    console.log(a); //{id: 1, name: 2}
    如果你修改b的值,那么a变量的值也发生了变化。
    克隆分为2种:
    A、浅度克隆:基本类型为值传递,对象仍为引用传递。
    B、深度克隆:所有元素或属性均完全克隆,并于原引用类型完全独立,即,在后面修改对象的属性的时候,原对象不会被修改。
    深度克隆对象代码:
    function cloneObject(obj) {
        var o = obj.constructor === Array ? [] : {};
        for (var i in obj) {
            if (obj.hasOwnProperty(i)) {
                o[i] = typeof obj[i] === "Object" ? cloneObject(obj[i]) : obj[i];
            }
        }
        return o;
    }
    如果是一个简单的数组,元素中没有引用类型的值,可以直接用array.concat();或者array.slice(0);来深度拷贝一个数组,这样简单又高效。数组的concat()和slice()本来就会生成一个新的数组,原来的数组不会受影响。

    6、冒泡排序算法?

    function bubbleSort(arr) {
        var len = arr.length;
        for (var i = 0; i < len - 1; i += 1) {
            for (var j = 0; j < len - i - 1; j += 1) {
                if (arr[j + 1] < arr[j]) {
                    var temp = arr[j + 1];
                    arr[j + 1] = arr[j];
                    arr[j] = temp;
                }
            }
        }
    }
    var arr = [-1, -5, 0, 300, 90, 90, -5];
    bubbleSort(arr);
    console.log(arr);

     7、获取对象,数组所有属性值(key)和对应值(value)

    (function ($) {
        window.Util = window.Util || {};
        Util.getObjectKeys = function (o) {
            var keys = [];
            if (typeof o == "object") {
                for (var property in o) {
                    keys.push(property);
                }
            }
            return keys;
        };
        Util.getObjectValues = function (o) {
            var values = [];
            if (typeof o == "object") {
                for (var property in o) {
                    values.push(o[property]);
                }
            }
            return values;
        };
    })(window.jQuery);

     8、获取字符串中特定字符出现的次数

    var str = '数码,女装,虚拟';
    var arr = str.match(/\,/gi);
    var items = arr == null ? 0 : arr.length; // 方法1
    var items = str.split(',').length - 1; // 方法2
    console.log(items);
  • 相关阅读:
    respons——文件下载
    李珊珊(为奥运冠军名字作诗)
    林跃/火亮(为奥运冠军名字作诗)
    张湘祥(为奥运冠军名字作诗)
    何可欣(为奥运冠军名字作诗)
    李小鹏(为奥运冠军名字作诗)
    王鑫(为奥运冠军名字作诗)
    杨伊琳(为奥运冠军名字作诗)
    江钰源(为奥运冠军名字作诗)
    黄旭(为奥运冠军名字作诗)
  • 原文地址:https://www.cnblogs.com/huangjianhuakarl/p/3141897.html
Copyright © 2011-2022 走看看