如果仅在变量为 true
的情况下才调用函数,则可以使用 &&
运算符。
//Longhand
if (test1) {
callMethod();
}
//Shorthand
test1 && callMethod();
11.foreach循环简写
这是迭代的常用简写技术之一。
// Longhand
for (var i = 0; i < testData.length; i++)
// Shorthand
for (let i in testData) or for (let i of testData)
每个变量的数组
function testData(element, index, array) {
console.log(‘test[’ + index + '] = ’ + element);
}
[11, 24, 32].forEach(testData);
// logs: test[0] = 11, test[1] = 24, test[2] = 32
12.return中比较
我们也可以在return语句中使用比较。它将避免我们的5行代码,并将它们减少到1行。
// Longhand
let test;
function checkReturn() {
if (!(test === undefined)) {
return test;
} else {
return callMe(‘test’);
}
}
var data = checkReturn();
console.log(data); //output test
function callMe(val) {
console.log(val);
}
// Shorthand
function checkReturn() {
return test || callMe(‘test’);
}
13.箭头函数
//Longhand
function add(a, b) {
return a + b;
}
//Shorthand
const add = (a, b) => a + b;
更多示例。
function callMe(name) {
console.log(‘Hello’, name);
}
callMe = name => console.log(‘Hello’, name);
14.短函数调用
我们可以使用三元运算符来实现这些功能。
// Longhand
function test1() {
console.log(‘test1’);
};
function test2() {
console.log(‘test2’);
};
var test3 = 1;
if (test3 == 1) {
test1();
} else {
test2();
}
// Shorthand
(test3 === 1? test1:test2)();
15. Switch简写
我们可以将条件保存在键值对象中,并可以根据条件使用。
// Longhand
switch (data) {
case 1:
test1();
break;
case 2:
test2();
break;
case 3:
test();
break;
// And so on…
}
// Shorthand
var data = {
1: test1,
2: test2,
3: test
};
data[something] && datasomething;
16.隐式返回简写
使用箭头函数,我们可以直接返回值,而不必编写return语句。
//longhand
function calculate(diameter) {
return Math.PI * diameter
}
//shorthand
calculate = diameter => (
Math.PI * diameter;
)
17.小数基数指数
// Longhand
for (var i = 0; i < 10000; i++) { … }
// Shorthand
for (var i = 0; i < 1e4; i++) {
18.默认参数值
//Longhand
function add(test1, test2) {
if (test1 === undefined)
test1 = 1;
if (test2 === undefined)
test2 = 2;
return test1 + test2;
}
//shorthand
add = (test1 = 1, test2 = 2) => (test1 + test2);
add() //output: 3
19.扩展运算符简写
//longhand
// joining arrays using concat
const data = [1, 2, 3];
const test = [4 ,5 , 6].concat(data);
//shorthand
// joining arrays
const data = [1, 2, 3];
const test = [4 ,5 , 6, …data];
console.log(test); // [ 4, 5, 6, 1, 2, 3]
对于克隆,我们也可以使用扩展运算符。
//longhand
// cloning arrays
const test1 = [1, 2, 3];
const test2 = test1.slice()
//shorthand
// cloning arrays
const test1 = [1, 2, 3];
const test2 = […test1];
20.模板文字
如果您厌倦了在单个字符串中使用 +
来连接多个变量,那么这种简写可以消除您的头痛。
//longhand
const welcome = 'Hi ’ + test1 + ’ ’ + test2 + ‘.’
//shorthand
const welcome = Hi ${test1} ${test2}
;
21.多行字符串简写
当我们在代码中处理多行字符串时,可以使用以下功能:
//longhand
const data = ‘abc abc abc abc abc abc\n\t’
- ‘test test,test test test test\n\t’
//shorthand
const data = `abc abc abc abc abc abc
test test,test test test test`
22.对象属性分配
let test1 = ‘a’;
let test2 = ‘b’;
//Longhand
let obj = {test1: test1, test2: test2};
//Shorthand
let obj = {test1, test2};
23.将字符串转换成数字
//Longhand
let test1 = parseInt(‘123’);
let test2 = parseFloat(‘12.3’);
//Shorthand
let test1 = +‘123’;
let test2 = +‘12.3’;
24.用解构简写
//longhand
const test1 = this.data.test1;
const test2 = this.data.test2;
const test2 = this.data.test3;
//shorthand
const { test1, test2, test3 } = this.data;
25.用Array.find简写
当我们确实有一个对象数组并且我们想要根据对象属性查找特定对象时,find方法确实很有用。
const data = [
{
type: ‘test1’,
name: ‘abc’
},
{
type: ‘test2’,
name: ‘cde’
},
{
type: ‘test1’,
name: ‘fgh’
},
]
function findtest1(name) {
for (let i = 0; i < data.length; ++i) {
if (data[i].type === ‘test1’ && data[i].name === name) {
return data[i];
}
}
}
//Shorthand
filteredData = data.find(data => data.type === ‘test1’ && data.name === ‘fgh’);
console.log(filteredData); // { type: ‘test1’, name: ‘fgh’ }
26.查找条件简写
如果我们有代码来检查类型,根据类型需要调用不同的方法,我们可以选择使用多个else ifs或者switch,但是如果我们有比这更好的简写方法呢?
// Longhand
if (type === ‘test1’) {
test1();
}
else if (type === ‘test2’) {
test2();
}
else if (type === ‘test3’) {
test3();
}
else if (type === ‘test4’) {
test4();
} else {
throw new Error('Invalid value ’ + type);
}
// Shorthand
var types = {
test1: test1,
test2: test2,
test3: test3,
test4: test4
};
var func = types[type];
(!func) && throw new Error('Invalid value ’ + type); func();
27.按位索引简写
当我们遍历数组以查找特定值时,我们确实使用 indexOf()
方法,如果找到更好的方法该怎么办?让我们看看这个例子。
//longhand
if(arr.indexOf(item) > -1) { // item found
}
if(arr.indexOf(item) === -1) { // item not found
}
//shorthand
if(~arr.indexOf(item)) { // item found
}
if(!~arr.indexOf(item)) { // item not found
}
按位(〜
)运算符将返回除-1以外的任何值的真实值。否定它就像做 ~~
一样简单。另外,我们也可以使用 include()
函数:
if (arr.includes(item)) {
// true if the item found
}
28.Object.entries()
此函数有助于将对象转换为对象数组。
const data = { test1: ‘abc’, test2: ‘cde’, test3: ‘efg’ };
const arr = Object.entries(data);
console.log(arr);
/** Output:
[ [ ‘test1’, ‘abc’ ],
[ ‘test2’, ‘cde’ ],
[ ‘test3’, ‘efg’ ]
]
**/
29.Object.values()
这也是ES8中引入的一项新功能,该功能执行与 Object.entries()
类似的功能,但没有关键部分:
const data = { test1: ‘abc’, test2: ‘cde’ };
const arr = Object.values(data);
console.log(arr);
/** Output:
[ ‘abc’, ‘cde’]
**/
30.双按位简写
双重NOT按位运算符方法仅适用于32位整数)
// Longhand
Math.floor(1.9) === 1 // true
// Shorthand
~~1.9 === 1 // true
31.重复一个字符串多次
要一次又一次地重复相同的字符,我们可以使用for循环并将它们添加到同一循环中,但是如果我们有一个简写方法呢?
//longhand
let test = ‘’;
for(let i = 0; i < 5; i ++) {
test += 'test ';
}
console.log(str); // test test test test test
//shorthand
'test '.repeat(5);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
最后
文章到这里就结束了,如果觉得对你有帮助可以点个赞哦
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-31ERLxTM-1712819105370)]
[外链图片转存中…(img-Sodi9B7G-1712819105371)]
[外链图片转存中…(img-6KLJY79o-1712819105372)]
[外链图片转存中…(img-KMhGoM6E-1712819105372)]
[外链图片转存中…(img-ZKy8FTKG-1712819105372)]
[外链图片转存中…(img-1aOOz5AK-1712819105373)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-dpAN2nWZ-1712819105373)]
最后
文章到这里就结束了,如果觉得对你有帮助可以点个赞哦
[外链图片转存中…(img-X25KNs2i-1712819105373)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-IRoNXecP-1712819105374)]