JavaScript中的模板直面量

模板直面量

  • const book = {
                name: '你爱的书籍为'
            };
            console.log(`${book.name}`);//注意使用``来输出name的属性值
  • 我们可以省去function关键字,只用=>来表示

     let circle = r => {
                const name = 3.14;
                const area = name * r * r;
                return area;
            }
            console.log(circle(2));
  • 还可以省去return

  • const name = r => 
        3.14 * r * r;
        console.log(name(4));
  • 如果不接任何的值,可以用一对空的圆括号,在ES5中经常使用

  • const hello = () =>console.log('hello');
    hello()//进行调用
  • arguments对象它是一个数组,包含函数被调用时传入的参数,即使不知道函数的,名称也可以动态获取这些参数

  • apply()函数额可以将数组转变为参数

  • function sum (x,y,z){
        return x + y + z ;
    }
    let num = [3,5,6]; 
    console.log(sum(...num));
    //console.log(sum.apply(undefined,num));效果和上边一样
  • 调用sum方法可以将传入的参数用(....)来表示

  • 展开式运算符(...)也可以替代arguments,当作剩余的参数使用

  • function rest(X , Y , ...a){
        return (x + y) * a.length;
    }
    console.log(rest(1,2,"hello",5));
    上下代码效果一致
    function rest (x , y){
        let a = Array.prototype.slice.call(argument,2);
        return (x + y) * a.length;
    }
  • let [x , y ] = [ ' a '  , ' b ' ] ;
    上下的代码相同
    let x = 'a';
    let y = 'b';
    ----------------------------------
    数组解构可以进行值的互换,而不需要创建临时变量
    [x,y] = [y,x]
    上下的代码相同
    let temp = x ;
    x = y ; 
    y = temp ;
  • 属性简写功能,

  • let [x,y] = ['a' , 'b'];
    let obj = { x , y };
    console.log(obj);
    -----------------------
    let x = 'a';
    let y = 'b';
    let obj2 = { x: x,y: y };
    console.log(obj2)
    //输出的结果是,{x:"a" , y: "b"}
  • 简写方法名

  • const name = {
        name = 'absc',
        printHello (){
            console.log('Hello');
        }
    };
    console.log(name.printHello());
    这个像java一样定义方法
    --------------------------------
    上下的代码一致
    let name = {
        name: 'absds',
        printHello: function name (){
            console.log('Hello');
        }
    };
    console.log(name.printHello());
  • 更简洁的声明类的方式

  • function Book(title, pages, isbn) { // {1} 
     this.title = title; 
     this.pages = pages; 
     this.isbn = isbn; 
    } 
    Book.prototype.printTitle = function() { 
     console.log(this.title); 
    }; 
    我们可以用 ES2015 把语法简化,如下所示。
    class Book { // {2} 
     constructor(title, pages, isbn) { 
     this.title = title; 
     this.pages = pages; 
     this.isbn = isbn; 
     } 
     printIsbn() { 
     console.log(this.isbn); 
     } 
    }
  • 属性存取器

  • class Person {
         constructor(name) {
         this.name = name;
         }
    ​
         get name() {
         return this.name;
         }
         // set name(value) {
         //     this.name = value;
         // }
         }
         let main = new Person('小明');[1]
         console.log(main.name);
    ​
  • constructor是JS的构造器和java的构造器性质一致,有函数名与构造名一致的功能,故赋值为如[1]所示

  • get 和 set 是JS的关键字,在函数名前面加上get 或set 关键字

你可能感兴趣的:(javascript,前端,开发语言)