zoukankan      html  css  js  c++  java
  • 简洁的js代码片段

    来源:

    https://mp.weixin.qq.com/s/Ep_6OY29fcjr-rHJcyarDQ

    https://mp.weixin.qq.com/s/mpfxqVGEivtosHTz1MZS4Q

    js常用代码整理

    1、单行 If-Else 语句(三元运算符)

    这是许多编程语言的共同特征。你可以使用三元运算符用一行代码编写整个语句,而不是在多行上编写 if-else。例如:

    const age = 12;
    let ageGroup;
    
    // LONG FORM
    if (age > 18) {
      ageGroup = "An adult";
    } else {
      ageGroup = "A child";
    }
    
    // SHORTHAND
    ageGroup = age > 18 ? "An adult" : "A child";

    但是,不要过度使用它。它会使你的代码更加冗长。明智的做法是仅用此替换简单的表达式以提高可读性并减少代码行数。

    2、从数组中删除重复项

    在 JavaScript 中,Set 是一个集合,它允许你仅存储唯一值。这意味着删除任何重复的值。

    因此,要从数组中删除重复项,你可以将其转换为集合,然后再转换回数组。

    const numbers = [1, 1, 20, 3, 3, 3, 9, 9];
    const uniqueNumbers = [...new Set(numbers)]; // -> [1, 20, 3, 9]

    解释一下它是如何工作的:

    1)、new Set(numbers)从数字列表中创建一个集合。创建集合会自动删除所有重复值。

    2)、展开运算符...将任何可迭代对象转换为数组。这意味着将集合转换回数组。[...new Set(numbers)]

    3、较短的 If-Else 的空合并(空运算符??

    这也是 if-else 的简写。

    你可以使用看涨合并,而不是使用 if-else 构造来检查值是否为空。

    该nullish合并操作 ??,如果没有定义左侧返回右侧。如果是,则返回左侧:

    let maybeSomething;
    
    // LONG FORM
    if(maybeSomething){
      console.log(maybeSomething)
    } else {
      console.log("Nothing found")
    }
    
    //SHORTHAND
    console.log(maybeSomething ?? "Nothing found")
    const data= null ?? 'data';
    console.log(data);
    // expected output: "data"
    const data1 = 1 ?? 4;
    console.log(data1);
    // expected output: 1

    4、防止崩溃的可选链

    如果访问未定义的属性,则会产生错误。这就是可选链的用武之地。

    在未定义属性时使用可选链运算符,undefined将返回而不是错误。这可以防止你的代码崩溃。

    例如:

    const student = {
      name: "Matt",
      age: 27,
      address: {
        state: "New York"
      },
    };
    
    // LONG FORM
    console.log(student && student.address && student.address.ZIPCode); // Doesn't exist - Returns undefined
    
    // SHORTHAND
    console.log(student?.address?.ZIPCode); // Doesn't exist - Returns undefined

    5、在没有第三个变量的情况下交换两个变量

    在 JavaScript 中,你可以使用解构从数组中拆分值。这可以应用于交换两个变量而无需第三个:

    let x = 1;
    let y = 2;
    
    // LONGER FORM
    let temp = x;
    x = y;
    y = temp;
    
    // SHORTHAND
    [x, y] = [y, x];

    6、将任何值转换为布尔值(!!)

    在 JavaScript 中,你可以使用 !! 在 JS 中将任何内容转换为布尔值。

    例如,这里有一些例子:

    !!true    // true
    !!2       // true
    !![]      // true
    !!"Test"  // true
    
    !!false   // false
    !!0       // false
    !!""      // false

    7、扩展运算符

    使用扩展运算符组合两个数组...:

    const nums1 = [1, 2, 3];
    const nums2 = [4, 5, 6];
    
    // LONG FORM
    let newArray = nums1.concat(nums2);
    
    // SHORTHAND
    newArray = [...nums1, ...nums2];

    也可以使用此语法代替将值推送到数组:

    let numbers = [1, 2, 3];
    
    // LONGER FORM
    numbers.push(4);
    numbers.push(5);
    
    // SHORTHAND
    numbers = [...numbers, 4, 5];

    8、传播解构

    使用扩展运算符将剩余元素分配给变量:

    const student = {
      name: "Matt",
      age: 23,
      city: "Helsinki",
      state: "Finland",
    };
    
    // LONGER FORM
    const name = student.name;
    const age = student.age;
    const address = { city: student.city, state: student.state };
    
    // SHORTHAND
    const { name, age, ...address } = student;

    9、使用 && 进行短路评估

    不必用if语句检查某事是否为真,你可以使用&&运算符:

    var isReady = true;
    
    function doSomething(){
      console.log("Yay!");
    }
    
    // LONGER FORM
    if(isReady){
      doSomething();
    }
    
    // SHORTHAND
    isReady && doSomething();

    10、类固醇的字符串

    通过将字符串包装在反引号内并${}用于嵌入值,从而在字符串之间插入变量。

    例如:

    const age = 41;
    const sentence = `I'm ${age} years old`;
    
    // result: I'm 41 years old 

    11、从数组中查找特定元素

    使用find()方法查找匹配特定条件的元素:

    const fruits = [
      { type: "Banana", color: "Yellow" },
      { type: "Apple", color: "Green" }
    ];
    
    // LONGER FORM
    let yellowFruit;
    for (let i = 0; i < fruits.length; ++i) {
      if (fruits[i].color === "Yellow") {
        yellowFruit = fruits[i];
      }
    }
    
    // SHORTHAND
    yellowFruit = fruits.find((fruit) => fruit.color === "Yellow");

    12、对象属性赋值

    你是否希望对象键与值具有相同的名称?你可以省略对象文字来执行此操作:

    const name = "Luis", city = "Paris", age = 43, favoriteFood = "Spaghetti";
    
    // LONGER FORM
    const person = {
      name: name,
      city: city,
      age: age,
      favoriteFood: favoriteFood
    };
    
    // SHORTHAND
    const person = { name, city, age, favoriteFood };

    13、压缩 For 循环

    使用内置forEach()方法通过一行代码循环遍历数组:

    const numbers = [1, 2, 3, 4, 5];
    
    // LONGER FORM
    for(let i = 0; i < numbers.length; i++){
      console.log(numbers[i]);
    }
    
    // SHORTHAND
    numbers.forEach(number => console.log(number));

    14、默认功能参数

    你可以为函数参数提供默认值:

    // LONG FORM
    function pickUp(fruit) {
      if(fruit === undefined){
        console.log("I picked up a Banana");
      } else {
        console.log(`I picked up a ${fruit}`);
      }
    }
    
    // SHORTHAND
    function pickUp(fruit = "Banana") {
      console.log(`I picked up a ${fruit}`)
    }
    
    pickUp("Mango"); // -> I picked up a Mango
    pickUp();        // -> I picked up a Banana

    15、将对象的值收集到数组中

    用于Object.values()将对象的所有值收集到一个新数组中:

    const info = { name: "Matt", country: "Finland", age: 35 };
    
    // LONGER FORM
    let data = [];
    for (let key in info) {
      data.push(info[key]);
    }
    
    // SHORTHAND
    const data = Object.values(info);

    16、检查一个项目是否存在于数组中(includes)

    这不一定是速记,因为你几乎不会保存几个字符。但这是一种更清洁的方法。

    你可以使用 includes() 方法,而不是使用 indexOf() 方法来检查元素是否在数组中。这使你的意图非常明确:

    let numbers = [1, 2, 3];
    
    // LONGER FORM
    const hasNumber1 = numbers.indexOf(1) > -1 // -> True
    
    // SHORTHAND/CLEANER APPROACH
    const hasNumber1 = numbers.includes(1)     // -> True

    17、压缩多个条件

    避免使用长|| 检查多个条件链,你可以使用你刚刚在上一个技巧中学到的东西——即,使用 includes() 方法:

    const num = 1;
    
    // LONGER FORM
    if(num == 1 || num == 2 || num == 3){
      console.log("Yay");
    }
    
    // SHORTHAND
    if([1,2,3].includes(num)){
      console.log("Yay");
    }

    18、指数运算符

    你Math.pow()习惯把一个数字提高到一个幂吗?你知道你也可以使用**运算符吗?

    // LONGER FORM
    Math.pow(4,2); // 16
    Math.pow(2,3); // 8
    
    // SHORTHAND
    4**2 // 16
    2**3 // 8

    19、Math.floor() 简写

    四舍五入Math.floor()并不是什么新鲜事。但是你知道你也可以使用~~运算符吗?

    例如:

    // LONG FORM
    Math.floor(5.25) // -> 5.0
    
    // SHORTHAND
    ~~5.25 // -> 5.0

    20、用一行代码分配多个值

    使用解构语法在一行中分配多个值:

    let num1, num2;
    
    // LONGER FORM
    num1 = 10;
    num2 = 100;
    
    // SHORTHAND
    [num1, num2] = [10, 100];

    这也适用于使用 JavaScript 对象:

    student = {
      name: "Matt",
      age: 29,
    };
    
    // LONGER FORM
    let name = student.name;
    let age = student.age;
    
    // SHORTHAND
    let { name, age } = student;

    21、大量 if 语

    //longhand
    if (fruit === 'apple' || fruit === 'banana' || fruit === 'orange' || fruit ==='mango') {
        //logic
    }
    //shorthand
    if (['apple', 'banana', 'orange', 'mango'].includes(fruit)) {
       //logic
    }

    22、变量声明

    //Longhand 
    let data1;
    let data2= 1;
    //Shorthand 
    let data1, data2= 1;

    23、分配默认值

    let data1 = null,
        data2 = test1 || '';
    console.log("null check", data2); // output will be ""

    24、空约束

    最常用的操作数之一,但请确保你的值为真、非空字符串、定义的值和非空值。

    // Longhand
    if (data1 === true) or if (data1 !== "") or if (data1 !== null)
    // Shorthand //
    if (test1)

    注意:如果 test1 有任何值,它将落入 if 循环之后的逻辑中,该运算符主要用于 null 或 undefined 检查。

    25、返回简写

    这将有助于避免使用大量代码,专门返回到基于返回语句的调用方法。

    // Longhand
    let value;
    function returnMe() {
        if (!(value === undefined)) {
            return value;
        } else {
            return callFunction('value');
        }
    }
    var data = returnMe();
    console.log(data); //output value
    function callFunction(val) {
        console.log(val);
    }
    
    // Shorthand
    function returnMe() {
        return value || callFunction('value');
    }

    26、 箭头函数

    //Longhand 
    function add(a, b) { 
       return a + b; 
    } 
    //Shorthand 
    const add = (a, b) => a + b;

    再看一个例子。

    function function(value) {
      console.log('value', value);
    }
    function= value => console.log('value', value);

    27、短函数调用

    我们可以使用三元运算符来实现这些功能。

    // Longhand
    function data1() {
        console.log('data1');
    };
    function data2() {
        console.log('data2');
    };
    var data3 = 1;
    if (data3 == 1) {
        data1();
    } else {
        data2();
    } //data1
    // Shorthand
    (data3 === 1 ? data1 : data2)(); //data1

    28、Switch语句优化

    如果你想优化你的 switch 语句,那么这个可以提供帮助。

    // Longhand
    switch (data) {
        case 1:
            data1();
            break;
        case 2:
            data2();
            break;
        case 3:
            data();
            break;
            // And so on...
    }
    // Shorthand
    var data = {
        1: data1,
        2: data2,
        3: data
    };
    const val = 1
    data[val]();
    function data1() {
        console.log("data1");
    }
    function data2() {
        console.log("data2");
    }
    function data() {
        console.log("data");
    }

    29、多行字符串

    //longhand
    const literal = 'abc abc abc abc abc abc
    	'
        + 'val test,test test test test
    	'
    //shorthand
    const literal = `abc abc abc abc abc abc
             val test,test test test test`

    30、对象属性赋值

    let data1 = 'abcd'; 
    let data2 = 'efgh';
    //Longhand 
    let data = {data1: data1, data2: data2}; 
    //Shorthand 
    let data = {data1, data2};

    31、数字转换

    //Longhand 
    let test1 = parseInt('12'); 
    let test2 = parseFloat('2.33');
    //Shorthand 
    let test1 = +'12'; 
    let test2 = +'2.33';

    32、Array.find 方法

    从数组中找到第一个匹配值的方法之一。

    const data = [{
            type: 'data1',
            name: 'abc'
        },
        {
            type: 'data2',
            name: 'cde'
        },
        {
            type: 'data1',
            name: 'fgh'
        },
    ]
    function datafinddata(name) {
        for (let i = 0; i < data.length; ++i) {
            if (data[i].type === 'data1' && data[i].name === name) {
                return data[i];
            }
        }
    }
    //Shorthand
    filteredData = data.find(data => data.type === 'data1' && data.name === 'fgh');
    console.log(filteredData); // { type: 'data1', name: 'fgh' }

    33、按位索引(indexof )

    如果我们可以将 indexof 方法与速记结合起来会怎样?按位 indexof 方法为我们做同样的工作。

    //longhand
    if (data.indexOf(item) > -1) { // item found
    }
    if (data.indexOf(item) === -1) { // item not found
    }
    //shorthand
    if (~data.indexOf(item)) { // item found
    }
    if (!~data.indexOf(item)) { // item not found
    }

    我们也可以使用包含功能。

    if (data.includes(item)) { 
    // true if the item found
    }

    34、Object.entries()

    此功能有助于将对象转换为对象数组。

    const data = {
        data1: 'abc',
        data2: 'cde',
        data3: 'efg'
    };
    const arr = Object.entries(data);
    console.log(arr);
    //[
        ['data1', 'abc'],
        ['data2', 'cde'],
        ['data3', 'efg']
    ]

    35、Object.entries()

    迭代对象值会很有帮助。

    const data = {
        data1: 'abc',
        data2: 'cde'
    };
    const arr = Object.values(data);
    console.log(arr);
    //[ 'abc', 'cde']

    Object.keys() 有助于迭代对象中的键。

    const data = {
        data1: 'abc',
        data2: 'cde'
    };
    const arr = Object.keys(data);
    console.log(arr);
    //[ 'data1', 'data2']

    36、多次重复一个字符串

    此字符串方法有助于一次又一次地重复相同的字符串值。

    //longhand 
    let data = '';
    for (let i = 0; i < 5; i++) {
        data += 'data ';
    }
    console.log(str); // data data data data data 
    //shorthand 
    'data '.repeat(5);

    37、查找数组中的最大值和最小值

    const data = [1, 4, 3]; 
    Math.max(…data); // 4
    Math.min(…data); // 1
  • 相关阅读:
    CSUST 8.4 早训
    CSUST 8.5 早训
    hdu1542 Atlantis 线段树--扫描线求面积并
    hdu1540 Tunnel Warfare 线段树/树状数组
    hdu1535 Invitation Cards 最短路
    hdu1358 Period KMP
    SQL Server 向数据库中创建表并添加数据
    初次实践数据库--SQL Server2016
    hdu1301 Jungle Roads 最小生成树
    hdu1281 棋盘游戏 二分图最大匹配
  • 原文地址:https://www.cnblogs.com/konglxblog/p/15083095.html
Copyright © 2011-2022 走看看