前端打怪之旅=>Es6入门(对象简化写法、函数)

对象的简化写法

ES6允许在大括号里面,直接写入变量和函数,作为对象的属性和方法 这样的书写更加简洁

javascript 复制代码
let name = '浅辄';
            let change  = function(){
                console.log('我可以改变世界');
            }
            const school ={
                name,
                change,
                improve(){
                    console.log('提高编程水平')
                }
            }
            console.log(school)

箭头函数

1.形式如下

js 复制代码
        let fn = function() {

        }
        let fn = (形参) => {
            //省略了function关键字
            return xxx;
        }
        //调用函数
        let result = fn(实参);
        console.log(result);

2.特性

  • this是静态的.this始终指向函数声明时所在作用域下的this的值

    js 复制代码
    	function getName1(){
    		console.log(this.name)
    	}
    	
    	let getName2=()=>{
    		console.log(this.name)
    	}
    	
                //设置window对象的name属性
                window.name='浅辄';
                const SCHOOL ={
                        name:"Lee"
                }
                //直接调用
                getName1()
                getName2()
                //call调用
                getName1.call(SCHOOL)
                getName2.call(SCHOOL)
  • 不能作为构造实例化对象

    ini 复制代码
                let Person=(name,age)=>{
                    this.name = name;
                    this.age = age;
                }
                
                let me = new Person("Lee",18);
                console.log(me);
  • 不能使用arguments变量

    js 复制代码
                            let fn=()=>{
                                    console.log(arguments);
                            }
                            fn(1,2,3)
  • 箭头函数的简写

    • 省略小括号,当形参且只有一个的时候

      csharp 复制代码
                  let add = n =>{
                      return n+n;
                  }
                  console.log(add(2));
    • 省略花括号,当代码体只有一条语句的时候,此时return必须省略,而且语句的执行结果就是函数的返回值

      ini 复制代码
                  let pow=(n)=>n*n;
                  
                  console.log(pow(2));

函数参数默认值

形参初始值

js 复制代码
        function add(a,b,c){
            return a+b+c
        }
        let result = add(1,2);
        console.log(result);

这里的c是没有给它赋值的

js 复制代码
        function add(a,b,c=10){
                return a+b+c
        }
        let result = add(1,2);
        console.log(result);

这里要注意要把赋值过的参数放在后面,否则你在下面写入实参的时候,第二个

与解构赋值结合使用

js 复制代码
function connect({
                host = "127.0 .0 .1",
                username,
                password,
                port
            }) {
                console.log(host);
                console.log(username)
                console.log(password)
                console.log(port)
            }
            connect({
                host: 'localhost',
                username: 'root',
                password: 'root',
                port: 3306
            })

rest参数

ES6引入rest参数,用于获取函数的实参,用来代替arguments

获取实参

Es5获取

javascript 复制代码
        function data(){
            console.log(arguments);
        }
        
        data('小a','小b','小c')

这是一个对象

Es6获取

javascript 复制代码
		function data(...args){
			console.log(args);
		}
		
		data('小a','小b','小c')

这是一个数组,因为他是一个数组,所以一些关于数组的API是可以调用的,比如filter some every map

注意:rest参数必须要放到参数最后

相关推荐
黑客飓风17 分钟前
JavaScript 性能优化实战大纲
前端·javascript·性能优化
emojiwoo2 小时前
【前端基础知识系列六】React 项目基本框架及常见文件夹作用总结(图文版)
前端·react.js·前端框架
张人玉2 小时前
XML 序列化与操作详解笔记
xml·前端·笔记
杨荧2 小时前
基于Python的宠物服务管理系统 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python·信息可视化
YeeWang3 小时前
🎉 Eficy 让你的 Cherry Studio 直接生成可预览的 React 页面
前端·javascript
gnip3 小时前
Jenkins部署前端项目实战方案
前端·javascript·架构
Orange3015113 小时前
《深入源码理解webpack构建流程》
前端·javascript·webpack·typescript·node.js·es6
lovepenny4 小时前
Failed to resolve entry for package "js-demo-tools". The package may have ......
前端·npm
超凌4 小时前
threejs 创建了10w条THREE.Line,销毁数据,等待了10秒
前端
车厘小团子4 小时前
🎨 前端多主题最佳实践:用 Less Map + generate-css 打造自动化主题系统
前端·架构·less