task-18

问答

数组方法里 pushpopshiftunshiftjoinsplit分别是什么作用?

push(),向数组的末尾添加一个或更多元素,并返回新的长度

pop(), 删除并返回数组的最后一个元素

shift(),删除并返回数组的第一个元素

unshift(),向数组的开头添加一个或更多元素,并返回新的长度

join(),把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔。

split(),用指定的分隔符将一个字符串分割成多个子字符串,并将结果放在一个数组中。分隔符可以是字符串,也可以是一个正则表达式。split()方法可以接受可选的第二个参数,用于指定数组的大小,以便确保返回的数组不会超过既定大小。

代码

数组:

1. 用 splice 实现 pushpopshiftunshift方法 (***)

var example = [2,4,5,6,7,2];
function push(arr,value){
    arr.splice(arr.length,0,value);
    return arr.length;
}
function pop(arr){
    return arr.splice(arr.length-1,1)[0];
}

function shift(arr){
    return arr.splice(0,1)[0];
}

function unshift(arr,value){
    arr.splice(0,0,value);
    return arr.length;
}
数组-1.png

2. 使用数组拼接出如下字符串 (***)

    var prod = {
        name: '女装',
        styles: ['短款','冬季','春装']
    };
    function getStr(data){
        var htmls = [];
        htmls.push('<dl class="product">');
        htmls.push('<dt>' + prod.name + '</dt>');
        for(var i = 0; i < prod.styles.length; i++){
            htmls.push('<dd>' + prod.styles[i] + '</dd>');
        }
        htmls.push('</dl>');
        return htmls.join('');
    }
    var result = getStr(prod);  
数组-2.png

3. 写一个 find 函数,实现以下功能 (***)

    var arr = ["test", 2, 1.5, false];
    function find(array,value){
        for(var i = 0; i < array.length; i++){
            if(value === array[i]){
                return i;
            }
        }
        return -1;
    }
    find(arr, "test")  // 0
    find(arr, 2)  // 1
    find(arr, 0)  // -1
数组-3.png

4. 写一个函数 filterNumeric,把数组 arr 中的数字过滤出来赋值给新数组 newarr,原数组 arr 不变 (****)

    var arr = ["a", "b", 1, 3, 5, "b", 2];
    newArr = filterNumberic(arr);  //[1,3,5,2]
    function filterNumberic(){
        var newArr = [];
        for(var i = 0; i < arr.length; i++){
            if(typeof(arr[i]) === 'number'){
                newArr.push(arr[i]);
            }
        }
        return newArr;
    }
数组-4.png

5. 对象 obj 有个 className 属性,里面的值为的是空格分割的字符串(和 html 元素的 class 特性类似),写 addClassremoveClass 函数,有如下功能:(****)

    var obj = {
        className: 'open menu'
    };
    addClass(obj, 'new')  // obj.className = 'open menu new'
    addClass(obj, 'open');  // 因为 open 已经存在,所以不会再次添加 open
    addClass(obj, 'me');  // me 不存在,所以 obj,className 变为 'open menu new me'
    console.log(obj.className);  // "open menu new me"

    removeClass(obj, 'open');  // 去掉 obj.className 里面的 open,变为 'menu new me'
    console.log(obj.className);
    removeClass(obj, 'blala');  // 因为 blala 不存在,所以此操作没有任何影响
    console.log(obj.className);

    function addClass(obj, value){
        var classNameArray = obj.className.split(' ');  // 字符串 --> 数组
        // 检测是否已存在该字符串
        for(var i = 0; i < classNameArray.length; i++){
            if(classNameArray[i] === value){
                return "已存在此 className";
                // return obj.className;
            }
        }
        classNameArray.push(value);
        obj.className = classNameArray.join(' ');  // 数组 --> 字符串
        // obj.className =  classNameArray.push(value).join(' ');
        return obj.className;
    }

    function removeClass(obj,value){
        var classNameArray = obj.className.split(' ');  // 字符串 --> 数组
        for(var i = 0; i < classNameArray.length; i++){
            if(classNameArray[i] === value){
                classNameArray.splice(i,1);
            }
        }
        obj.className = classNameArray.join(' ');  // 数组 --> 字符串
        return obj.className;
    }
数组-5.png

6. 写一个 camelize 函数,把 my-short-string 形式的字符串转化成 myShortString 形式的字符串 (***)

    camelize("background-color");
    camelize("list-style-image");
    function camelize(str){
        var strToArray = str.split('-');
        console.log(strToArray);
        for(var i = 1; i < strToArray.length; i++){
            // 方法1,相当麻烦的一种(再将里面拆解)
            // var strArrayInner = strToArray[i].split('');
            // strArrayInner[0] = strArrayInner[0].toUpperCase();
            // strToArray[i] = strArrayInner.join('');

            // 方法2
            strToArray[i] = strToArray[i][0].toUpperCase() + strToArray[i].substr(1);
            // strToArray[i] = strToArray[i][0].toUpperCase() + strToArray[i].slice(1);  // .substr(1) VS .slice(1)
        }
        var upperStr = strToArray.join('');
        console.log(upperStr);
    }
代码-6.png

7. 如下代码输出什么?为什么? (***)

arr = ["a", "b"];
arr.push( function() { alert(console.log('hello hunger valley')) } );
arr[arr.length-1]()  // ?

输出结果为:弹框显示出undefined,控制台打印出hello hunger valley

原因:arr.push(function)(){...}这句代码会把函数function(){...}添加到数组的末尾,而arr[arr.length-1]运行的就是数组的最后一项,

所以最终结果就是将函数fucntion(){...}运行一遍,console.log(...)返回undefined,所以弹框显示undefined

8. 写一个函数filterNumericInPlace,过滤数组中的数字,删除非数字。要求在原数组上操作 (****)

   var arr = ["a", "b", 1, 3, 4, 5, "b", 2];
    // 对原数组操作,不需要返回值
    filterNumber(arr);
    // console.log(arr);  // [1,3,4,5,2]
    // console.log(filterNumber(arr))

    // var arrNumber = [];
    // arr.map( function(el){ if(typeof el === 'number') {arrNumber.push(el)} } );
    // console.log(arrNumber);

    function filterNumber(value){

        // 方法 1
        for(var i = 0; i < value.length; i++){
            if( typeof(value[i]) !== 'number' ){
                value.splice(i,1);
                i--;
            }
        }
        return value;
        
        // 方法 2  把 'string' “赶到” 数组的最后,再把它割了。 !!! 但是这个方法会把原来的 'number' 的顺序打乱了
        // var value = value.sort();
        // for(var i = 0; i < value.length; i++){
        //     if( typeof(value[i]) !== 'number'){
        //         value.splice(i, value.length - i);
        //     }
        // }
        // return value;

        // 方法 3 把数组每一个的 'string' 赋给一个新的数组,再将这个新数组赋值给原数组 
        // var temp = [];
        // for(var i = 0; i < value.length; i++){
        //     if(typeof(value[i]) === 'number'){
        //         temp.push(value[i]);
        //         // temp[i] = value[i];
        //     }
        // }
        // value = temp;
        // arr = temp;
    }
代码-8.png

9. 写一个 ageSort 函数实现数组中对象按age从小到大排序 (***)

    var john = {
        name: "John Smith",
        age: 23
    };
    var mary = {
        name: "Marry Key",
        age: 18
    };
    var bob = {
        name: "Bob-small",
        age: 6
    };
    var people = [john, mary, bob];
    ageSort(people)  // [ bob, mary, john]
    // console.log(people[0].age)

    function ageSort(arr){
        arr.sort(function(a,b){
            return a.age > b.age;
        })
    }
代码-9.png

10. 写一个filter(arr, func) 函数用于过滤数组,接受两个参数,第一个是要处理的数组,第二个参数是回调函数(回调函数遍历接受每一个数组元素,当函数返回true时保留该元素,否则删除该元素)。实现如下功能: (****)

    function isNumberic(el){
        return typeof el === 'number';
    }
    arr = ["a",3,4,true,-1,2,"b"];

    arr = filter(arr, isNumberic);  // arr = [3,4,-1,2]  过滤出数字
    arr = filter(arr, function(val) { return (typeof val === 'number') && (val > 0)} );  // arr = [3,4,2]  过滤出大于 0 的整数

    function filter(arr,func){
        for(var i = arr.length-1; i >= 0; i--){
            if(!func(arr[i])){
                arr.splice(i,1);
            }
        }
    }
代码10-1.png
代码10-2.png

字符串:

1. 写一个 ucFirst函数,返回第一个字母为大写的字符 (***)

    function charUpper(value){
        // var value = value[0].toUpperCase() + value.substr(1);
        // return value;
        return value[0].toUpperCase() + value.substr(1);
    }
代码二-1.png

2. 写一个函数truncate(str, maxlength), 如果str的长度大于maxlength,会把str截断到maxlength长,并加上...,如 (****)

    function truncate(str, maxlength){
        if(str.length > maxlength){
            return str.slice(0,maxlength) + "..."
            // console.log(str)
            // return str.substr(0, maxlength) + '...';
        }else{
            return str;
        }
    }
代码二-2.png

数学函数

1. 写一个函数,获取从min到max之间的随机整数,包括min不包括max (***)

    function rangeRandomNumber1(min,max){
        return Math.floor(Math.random() * (max-min)) + min;
    }
代码三-1.png

2. 写一个函数,获取从min都max之间的随机整数,包括min包括max (***)

    function rangeRandomNumber2(min,max){
        return Math.floor(Math.random() * (max-min+1)) + min;
    }
代码三-2.png

3. 写一个函数,获取一个随机数组,数组中元素为长度为len,最小值为min,最大值为max(包括)的随机整数 (***)

    function getRandomArray(len,min,max){
        var arr = new Array(len);
        function getRandomNumber(min,max){
            return Math.floor(Math.random() * (max-min+1)) + min;
        }
        for(var i = 0; i < len; i++){
            arr[i] = getRandomNumber(min,max);
        }
        return arr;
    }
代码三-3.png

4. 写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z。

    function getRandomStr(n){
        var str = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
        var result = '';
        for(var i = 0; i < n; i++){
            result += str[Math.floor(Math.random() * str.length)]
        }
        return result;
    }
代码三-4.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容

  • 数组方法里push、pop、shift、unshift、join、split分别是什么作用 push方法接受参数添...
    饥人谷_姜琼君阅读 256评论 0 0
  • php usleep() 函数延迟代码执行若干微秒。 unpack() 函数从二进制字符串对数据进行解包。 uni...
    思梦PHP阅读 1,979评论 1 24
  • 市场上受资金追捧的仍然是趋势白马蓝筹,再次印证强者恒强的道理。 昨天提到过,针对最近拉升幅度很大的趋势股操作节奏尽...
    Leo凯文阅读 250评论 0 1
  • 39十一年前梦一场 昨夜落了一宿的大雨,阶上的青苔厚重饱满,一脚踩上去,能溢出水来。 这座院子是越发的寂静萧条,由...
    灯芯林阅读 457评论 5 13
  • 许某开班刚三年, 只因孩子偷人钱。 棍棒出手至孩残, 勒令取缔受课员。 据说许某是名牌大学毕业,因病肄业, 在...
    旖旎i阅读 321评论 3 5