前端小记6——项目中常用的ES6方法
现在很多功能用es5的方法也能实现功能,但es6提供的方法显得更为高效。记录下目前常用的几个方法。
1、字符包含
通过str.includes('a')来判断, 若str中包含a则结果为true,否则为false。
eg:
let str = 'abcd';
console.log(str.includes('a')); // true
console.log(str.includes('f')); // false
此外,支持第二个参数:
console.log(str.includes('d', 1)); // true 从索引号1开始搜索(包括1)
注意:includes()方法区分大小写。
2、字符首位判断
通过str.startsWidth('a')来判断, 若a为str的首字符则结果为true,否则为false。
eg:
let str = 'abcd';
console.log(str.startsWidth('a')); // true
console.log(str.startsWidth('b')); // false
此外,支持第二个参数:
console.log(str.startsWidth('cd', 2)); // true
3、字符末位判断
通过str.endsWith('a')来判断,若a为str的末位字符则结果为true,否则为false。
eg:
let str = 'abcd';
console.log(str.endsWith('d')); // trude
console.log(str.endsWith('b')); // false
此外,支持第二个参数:
console.log(str.endsWith('ab', 2)); // true 参数代表前2个(不包括第2)
4.两个值判断是否相等
传统es5判断相等用“==”(会自动转换数据类型)或“===”(有限制,比如NaN,+0,-0)
es6方法:Object.is
eg:Object.is('a', 'a'); // true
Object.is({}, {}); // false
对比:
+0 === -0 // true
NaN === NaN // false
Object.is(+0, -0) // false
Object.is(NaN, NaN) true
5、数组中查找第一个满足元素(包含)
方法:some()方法会依次执行,当遇到满足条件的返回true,跳出循环。若无满足项,返回false。
Ps:该方法不会改变原始数组,且对空数组不生效。
eg:
var a = [1,3,5,6];
function f () {
return b = 5;
}
console.log(a.some(f)); // true
6、模板字符串(也可用于字符拼接)
传统:
$('#id').append(
'This is <b>' + page.no + '</b>' +
'item in your page' + '<em>' + page.name +
'</em> in it.'
);
es6:
$('#id).append(
This is <b>${page.no}</b> item in your page <em>${page.name}</em> in it.
);
注意:在模板中需要使用反引号,需在前面用反斜杠转译。且模板中的空格和换行都会保留。
大括号中可以是变量或函数方法或者嵌套。
7、数组遍历
方法for of
eg:
var a = ['m', 'n', 'o'];
for (i of a) {
console.log(i); // 输出的是值 m, n, o
}
8、数组去重
eg:
var a = new Set("Hello word");
for (var b of a) {
console.log(b+" ")
}
// H e l o w r d
方法一:
function fn(arr) {
return Array.form(new Set(arr)) // Array.from方法可以将 Set 结构转为数组
}
const items = [1,2,3,4,5,6,7,1,2,1,3,1,2,3];
console.log(fn(items)) // [1,2,3,4,5,6,7]
方法二:
let arr1 = [12,13,23,45,46,48,78,79,45,12,13,23];
let arr = new Set(arr1)
console.log([...arr]) // [ 12, 13, 23, 45, 46, 48, 78, 79 ]
9、常用的并集、交集、差集
eg:
let a = new Set([1, 2, 3]);
let b = new Set([4, 3, 2]);
// 并集
let union = new Set([...a, ...b]);
// Set {1, 2, 3, 4}
// 交集
let intersect = new Set([...a].filter(x => b.has(x)));
// set {2, 3}
// 差集
let difference = new Set([...a].filter(x => !b.has(x)));
// Set {1}
前端小记6——项目中常用的ES6方法的更多相关文章
- VB的一些项目中常用的通用方法-一般用于验证类
1.VB的一些项目中常用的通用方法: ' 设置校验键盘输入值,数字 Public Function kyd(key As Integer) As Integer Dim mychar mychar = ...
- 项目中常用的js方法封装---自留
1.输入一个值,返回其数据类型 type = para => { return Object.prototype.toString.call(para).slice(8,-1) } 2.冒泡排序 ...
- 在项目中常用的JS方法封装
使用方法简单,只需要放在你的 utils.js 工具文件中,直接export const 加上下面封装方法,在别的文件中使用 {方法1,方法2,方法3...}引用后直接使用即可. 01.输入一个值.返 ...
- 项目中常用的js方法(持续更新)
<script> var utils = { //时间戳转日期(timestamp:时间戳 默认当前时间) dateFormat: function(timestamp = new Dat ...
- ES6系列之项目中常用的新特性
ES6系列之项目中常用的新特性 ES6常用特性 平时项目开发中灵活运用ES6+语法可以让开发者减少很多开发时间,提高工作效率.ES6版本提供了很多新的特性,接下来我列举项目中常用的ES6+的特性: l ...
- Android 项目中常用到的第三方组件
项目中常用到的第三方组件 1 社会化分享ShareSDK-Core-2.5.9.jarShareSDK-QQ-2.5.9.jarShareSDK-QZone-2.5.9.jarShareSDK-Sin ...
- 项目中常用js方法整理common.js
抽空把项目中常用js方法整理成了common.js,都是网上搜集而来的,大家一起分享吧. var h = {}; h.get = function (url, data, ok, error) { $ ...
- 记录下项目中常用到的JavaScript/JQuery代码二(大量实例)
记录下项目中常用到的JavaScript/JQuery代码一(大量实例) 1.input输入框监听变化 <input type="text" style="widt ...
- 开发中常用的es6知识
结合实际开发,开发中常用的es6的知识: 1.新增let和const命令: ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效: cons ...
随机推荐
- Jenkins+maven+gitlab+shell实现项目自动化部署
确认jdk , maven,git这些已经在服务器上搭建成功,gitlab使用的是公司服务也没有进行搭建 下面是jenkins的两种搭建方式 1. 第一种比较简单下载对应jenkins.wa ...
- [题解](树形dp/记忆化搜索)luogu_P1040_加分二叉树
树形dp/记忆化搜索 首先可以看出树形dp,因为第一个问题并不需要知道子树的样子, 然而第二个输出前序遍历,必须知道每个子树的根节点,需要在树形dp过程中记录,递归输出 那么如何求最大加分树——根据中 ...
- JMeter - 如何测试REST API / 微服务
概述: 有许多方法和工具可用于测试REST API.当我需要测试REST API时,在查看了各种工具和选项之后,由于以下原因,我选择了JMeter. JMeter是免费和开源的. JMeter可以从C ...
- 论js里面的for循环
首先搞懂执行的顺序: 对,执行顺序就是这样的. for循环的作用: 1.在编写代码时,你常常希望反复执行同一段代码. 2.遍历数组,可以用forEach();对于DOM对象(nodelist)的话,比 ...
- HTML 常用头部标签(meta)
先来看下常用的标签列表,后文会一一介绍: <!DOCTYPE html> <!-- 使用 HTML5 doctype,不区分大小写 --> <html lang=&quo ...
- redis使用方法
redis缓存服务器笔记 redis是一个高性能的key-value存储系统,能够作为缓存框架和队列 但是由于他是一个内存内存系统,这些数据还是要存储到数据库中的 作为缓存框架: create/upd ...
- POJ 2891 Strange Way to Express Integers excrt/我真傻,真的
我真傻,真的 我单知道这道题在(b-b1)%d!=0时要判无解,哪成想自己却没有读完这组后面的数据而直接break掉...qwqfk 当 $ x \equiv b_1 ( mod a_1 ) ...
- BZOJ 4919: [Lydsy1706月赛]大根堆 启发式合并
我不会告诉你这是线段树合并的好题的... 好吧我们可以搞一个multiset在dfs时求出LIS(自带二分+排序)进行启发式合并,轻松加愉悦... #include<cstdio> #in ...
- UiAutomator编译与运行测试代码
编译与运行步骤 1.创建build文件.打开cmd命令窗口,进入工程路径cd E:\workspace\UiAutomatorDemo1,然后输入命令android create uitest-pro ...
- 三节点Hadoop集群搭建
1. 基础环境搭建 新建3个CentOS6.5操作系统的虚拟机,命名(可自定)为masternode.slavenode1和slavenode2.该过程参考上一篇博文CentOS6.5安装配置详解 2 ...