QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

手机号码,快捷登录

泡泡马甲APP 更多内容请下载泡泡马甲手机客户端APP 立即下载 ×
查看: 1468|回复: 0

[HTML/CSS/JS] 10个JavaScript代码优化小技巧

[复制链接]

等级头衔

积分成就    金币 : 2806
   泡泡 : 1516
   精华 : 6
   在线时间 : 1244 小时
   最后登录 : 2024-5-5

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老

联系方式
发表于 2021-2-19 12:49:48 | 显示全部楼层 |阅读模式
1. if多条件判断
  1. // 冗余
  2. if (x === 'abc' || x === 'def' || x === 'ghi' || x ==='jkl') {}
  3. // 简洁
  4. if (['abc', 'def', 'ghi', 'jkl'].includes(x)) {}
2. if...else...
: N; Q3 h" ^( i* _2 N1 Z
  1. // 冗余
  2. let test: boolean;
  3. if (x > 100) {
  4.     test = true;
  5. } else {
  6.     test = false;
  7. }
  8. // 简洁
  9. let test = x > 10;
3. Null, Undefined, 空值检查
. ~" p6 S1 k& Y5 Y% B6 P, Z
  1. // 冗余
  2. if (first !== null || first !== undefined || first !== '') {
  3.     let second = first;
  4. }
  5. // 简洁
  6. let second = first || '';
4. foreach循环
  1. // 冗余
  2. for (var i = 0; i < testData.length; i++)
  3.    
  4. // 简洁
  5. for (let i in testData)
  6. // 或
  7. for (let i of testData)
5. 函数条件调用  D1 X6 _, A2 K6 {$ {( l, o/ j: L
  1. // 冗余
  2. function test1() {
  3.   console.log('test1');
  4. };
  5. function test2() {
  6.   console.log('test2');
  7. };
  8. var test3 = 1;
  9. if (test3 == 1) {
  10.   test1();
  11. } else {
  12.   test2();
  13. }
  14. // 简单
  15. (test3 === 1? test1:test2)();
6. switch条件: b0 g* N6 N# u# p( n- u# r1 X5 C
  1. // 冗余
  2. switch (data) {
  3.   case 1:
  4.     test1();
  5.   break;
  6.   case 2:
  7.     test2();
  8.   break;
  9.   case 3:
  10.     test();
  11.   break;
  12.   // so on...
  13. }
  14. // 简洁
  15. var data = {
  16.   1: test1,
  17.   2: test2,
  18.   3: test
  19. };
  20. data[anything] && data[anything]( "anything] && data[anything");
7. 多行字符串
# R7 q$ g; P, g- l
  1. // 冗余
  2. const data = 'abc abc abc abc abc abc\n\t'
  3.     + 'test test,test test test test\n\t'
  4. // 简洁
  5. const data = `abc abc abc abc abc abc
  6.          test test,test test test test`
8. 隐式返回
: m" K: ]! d: t) f! B; ]
  1. // 冗余
  2. function getArea(diameter) {
  3.   return Math.PI * diameter
  4. }
  5. // 简洁
  6. getArea = diameter => (
  7.   Math.PI * diameter;
  8. )
9. 重复字符串多次
  1. // 冗余
  2. let test = '';
  3. for(let i = 0; i < 5; i ++) {
  4.   test += 'test ';
  5. }
  6. // 简洁
  7. 'test '.repeat(5);
10. 幂乘
  1. // 冗余
  2. Math.pow(2,3);
  3. // 简洁
  4. 2**3 // 8
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号 )

GMT+8, 2024-5-5 17:13

Powered by paopaomj X3.4 © 2016-2024 sitemap

快速回复 返回顶部 返回列表