关于一道数组习题的可扩展性思考

在复习廖雪峰老师的JS教程时,看到数组,又遇到了之前做过的那道小题,题目如下:

练习:在新生欢迎会上,你已经拿到了新同学的名单,请排序后显示:欢迎XXX,XXX,XXX和XXX同学!

给出了数组:

1 'use strict';
2 var arr = ['小明', '小红', '大军', '阿黄'];

这道题作为一个练习并不是很难,当时自己第一次看也是按照最直接的办法,使用了${arr[i]}来拿到对应的数组元素,使用alert(``)输出。

但今天自己再看这道题的时候,脑子中突然冒出一个想法,之前的做法过于局限,如果不是欢迎四个同学,要欢迎五个、六个或者更多的同学呢,之前的方法就必须重写,没有重用性可言,所以自己就想怎么能写出可扩展的方法,同时保留原先的格式,就把要输出的语句做了一个拆解,可以分为三部分:

(1)欢迎xxx

(2),xxx

(3)和xxx同学!

可以发现除了第一部分和最后一部分需要单独处理,第二部分是一个可以循环的结构,所以针对这些特点,我就写了如下一个方法:

 1 function SayHello(arr){
 2    let str = '';
 3    for(let i = 0; i < arr.length; i++){
 4       if(i === arr.length - 1){
 5          str += `和${arr[i]}同学!`;
 6       }else if(i === 0){
 7          str += `欢迎${arr[i]}`;
 8       }else{
 9          str += `,${arr[i]}`;
10       }
11    }
12    return str;
13 }

就是这样啦,挺简单的一个小题目,但是也算是锻炼了自己的逻辑思维能力,自勉一句:“多想,多做!”

posted @ 2016-11-11 11:07  雨帘轻挂  阅读(738)  评论(0编辑  收藏  举报