#### **1、调用indexOf方法**
~~~
var arr = [12, 1, 1, 11, 64, 64, 78, 9];
function unique2(arr) {
var hash = [];
for (var i = 0; i < arr.length; i++) {
if (arr.indexOf(arr[i]) == i) {
hash.push(arr[i]);
}
}
return hash;
}
console.log(unique2(arr));
// [12, 1, 11, 64, 78, 9]
~~~
#### **2.内置对象 includes:**
~~~
var a = [11,11,22,44,33,33];
var temp = [];
a.forEach(element =>{
if(!temp.includes(element)){
temp.push(element)
}
})
console.log(temp);
~~~
#### **3.es6新加方法:**
```
var a = [11,11,22,44,33,33];
console.log([...new Set(a)])
```
#### **4.obj 方法**
```
var a = [11,11,22,44,33,33];
var temp = [];
var obj = {};
a.forEach(ele => {
if(!obj[ele]){
obj[ele]= 'a' ;
temp.push(ele);
}
})
console.log(obj);
//{11: "a", 22: "a", 33: "a", 44: "a"}
console.log(temp); // [11, 22, 44, 33]
```
[还有太多办法了,但是我不想背了,这是地址你去看吧](https://www.cnblogs.com/jiayuexuan/p/7527055.html)
- HTML,CSS
- 如何书写高效的css样式
- box-shadow
- 表格合并行列
- 自适应单位
- 隐藏元素
- 浏览器缓存
- 浏览器内核
- css和js的合理走位
- 2021样式问题汇总
- 模拟面试
- 移动端适配问题
- flexible(rem)
- vw+rem
- 判断一个属性是对象的私有属性
- px rpx em rem vw
- 清除浮动
- 栅格系统
- get&&post
- 雪碧图
- new操作符
- call apply bind区别
- 前端模块化
- 回调函数
- 回调地狱(封装版)
- 回调地狱(promise)
- 回调地狱(generator)
- 回调地狱(async)
- es6新特性
- let
- 箭头函数
- 展开 解构 默认赋值
- vue生命周期
- axios封装
- axios跨域拿数据
- ajax封装
- JavaScript
- 数组
- 排序
- 取偶数
- 反转排序
- 取最大值
- 数组去重
- 复杂版
- 数组的克隆(深拷贝)的方法
- 求质数
- 原型和原型链
- 创建对象
- 什么是路由
- SASS
- jQuery中的append和prepend区别?
- css动画及js动画的区别
- 隐式类型转换
- 原型
- 事件传播
- 函数
- 增加属性
- 构造函数
- 一元操作符
- 作用域
- 短语
- Vue
- - nextTick
- 自我介绍
- 哦豁(;д;)
- for in效果
- 事件
- promise特点
- 如何实现一个ajax请求
- 媒体查询
- substr和substring
- MVC、MVVM
- 面向对象
- 取数据、渲染数据
- ajax
- vue
- React
- es6-class
- 几种类型的DOM节点
- js同源策略
- 闭包
- 2021
- 数据类型
- 闭包2
- 防抖节流
- 原型与原型链
- call与apply与bind
- 深浅拷贝
- New关键字
