JavaScript中的模板直面量

模板直面量

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

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

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

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

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

javascript 复制代码
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,当作剩余的参数使用

javascript 复制代码
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;
}
javascript 复制代码
let [x , y ] = [ ' a '  , ' b ' ] ;
上下的代码相同
let x = 'a';
let y = 'b';
----------------------------------
数组解构可以进行值的互换,而不需要创建临时变量
[x,y] = [y,x]
上下的代码相同
let temp = x ;
x = y ; 
y = temp ;
  • 属性简写功能,

javascript 复制代码
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"}
  • 简写方法名

javascript 复制代码
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());
  • 更简洁的声明类的方式

javascript 复制代码
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); 
 } 
}
  • 属性存取器

javascript 复制代码
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 关键字

相关推荐
ID_180079054736 分钟前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A10 分钟前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
aq553560024 分钟前
编程语言三巨头:汇编、C++与PHP大比拼
java·开发语言
vipbic31 分钟前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序
aq553560042 分钟前
PHP vs Python:30秒看懂核心区别
开发语言·python·php
我是无敌小恐龙44 分钟前
Java SE 零基础入门Day01 超详细笔记(开发前言+环境搭建+基础语法)
java·开发语言·人工智能·opencv·spring·机器学习
码云数智-大飞1 小时前
零基础微信小程序制作平台哪个好
开发语言
IT_陈寒1 小时前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
神仙别闹2 小时前
基于 MATLAB 实现的 DCT 域的信息隐藏
开发语言·matlab
ZC跨境爬虫2 小时前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)
前端·python·3d·重构·html