为了账号安全,请及时绑定邮箱和手机立即绑定

原生JS去重(一)--两种方法去掉重复字符

标签:
Html/CSS

所谓“去重”,即是去掉重复的字符。本篇博客讲述两种方式去重,一种是比较简单但代码比较啰嗦点的,另一种是有点深度但是简洁的。
我直接写JavaScript代码了。
方式一:

function deleteRepetionChar(arr){
//先判断输入进来的是数组对象还是字符串
if( typeof arr == "object"){
var arr = arr;
}
else if( typeof arr == "string"){
//字符串转为数组
var arr = arr.split(",")
}

//存放不相同的数据
var box = [];//存放去重数据
var thisArr;//当前的值arr[i]

//遍历数组
for (var i = 0; i < arr.length; i++) {
    thisArr = arr[i]

    //定义一个旗子,检查是不是有重复的字符
    var flag = true;

    //遍历存放数据盒子,检查是否等于当前元素
    for (var j = 0; j < box.length; j++) {
        //如果值存在
        if(box[j]==thisArr){
            flag = false;
            break;//结束for循环
        }
    }
    if(flag==false){
        //continue返回执行函数而不压入数组
        continue ;
    }
    box.push(thisArr);
}
return box

}
//测试
var arr = [0,1,2,3,1,3,2]
document.write(finRepetionCode(arr));
//输出结果:0,1,2,3
上面那种方式,虽然比较容易理解,但是逼格不够啊。来一个逼格高一点的吧。
方式二:

function deleteRepetion(arr){
var arrTable = {},arrData = [];
for (var i = 0; i < arr.length; i++) {
if( !arrTable[ arr[i] ]){
arrTable[ arr[i] ] = true;
arrData.push(arr[i])
}
}
return arrData;
}
var arr=[1,1,2,3,2,1];
console.log(deleteRepetion(arr))
//输出结果:1,2,3
对于方式二,不解释哈。
都是一些基础。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
37
获赞与收藏
165

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消