ES5与ES6常用语法教程之 ①函数写法、创建对象、导入导出模块方式
函数写法区别
计算a, b两个数字之和,有返回值
- es5 写法
function add(a, b) {
    return a + b;
}
- es6 写法(箭头函数)
let add = (a, b) => {
    return a + b
}
注意:
- 箭头函数作用于执行代码,这时使用{}
let add = (a, b) => {a + b}
- 当执行的代码语句只有一个逻辑表达式,这时可以省略{}
let add = (a, b) => a + b
- 箭头函数用于返回对象时,这时使用()
let add = (a, b) => (c)
- 箭头函数的参数当只有一个参数时,这时可以省略参数的()
let add = a => alert(a)
打印计算结果,没有返回值
- es5
function printSum(a, b) {
    console.log(a + b);
}
- es6
let printSum = (a, b) => {
    console.log(a + b)
}
省略{}
let printSum = (a, b) => console.log(a + b)
函数执行多条逻辑语句
- es5
function printAB(a, b){
    console.log(a);
    console.log(b);
}
- es6
let printAB = (a, b) => {
    console.log(a)
    console.log(b)
}
创建对象区别
es5和es6创建对象方式的不同
- es5
let App = React.createClass({
    render: function(){
        return (
            <View>
                <Text>这是es5创建的对象</Text>
            </View>
        )
    }
})
- es6
class App extends React.Component{
    render() {
        return (
            <View>
                <Text>这是es6创建的对象</Text>
            </View>
        )
    }
}
注意:
- render函数内可以返回视图组件,也可以返回其他的对象
- 如果return函数中如果返回视图组件,则视图组件一定要使用()包裹起来
- ()中只能有一个顶级视图标签
这种写法就属于()中有2个顶级标签, 这种会语法报错
let App = React.createClass({
    render: function(){
        return (
            <Text>这是es5创建的对象</Text>
            <Text>这是es5创建的对象</Text>
        )
    }
})
导入导出模块方式区别
导出方式
- es5
module.exports = App
- es6
export default App
当只导出一个模块时,可以直接使用下面的写法
export default class App extents Component {}
注意:
下面的两种导出方式,导入模块时,写法不一样
- 方式1
// 导出export default App
// 导入import App from './App'
- 方式2
// 导出export {App}
// 导入import {App} from './App'
导入方式
- es5
var App = require('./App');
- es6
import App from './App'
注意:
当es5和es6的导入导出方式混用时,切记:当使用es6导出模块,使用es5导入模块,这时程序会报错
设置默认的导入导出模块
- es6 设置默认导出的内容
export default function dinner(fruit, dessert){
    console.log(`${fruit}+${dessert}`)
}
或者
function dinner(fruit, dessert){
    console.log(`${fruit}+${dessert}`)
}
export default dinner
注意:
当需要导出一个js文件中的全部模块时,使用 * as xxx 语法
function fruit(fruit){
    console.log(fruit)
}
function dessert (dessert ){
    console.log(dessert )
}
// 导出全部模块export {fruit, dessert}
// 导入全部模块import * as chef from './xxx' console.log(chef.fruit)
console.log(chef.dessert)
导入导出模块重命名
导出和导入模块时,可以重命名模块的名字
- 导出重命名
let fruit = '苹果'
let dessert = '面包' function dinner( fruit, dessert){
console.log(`${fruit}+${dessert}`)
} // 导出模块dinner函数的名字重命名为supper
export {dinner as supper} // 导入supper模块
import {supper} from './App'
- 导入重命名
let fruit = '苹果'
let dessert = '面包' function dinner( fruit, dessert){
console.log(`${fruit}+${dessert}`)
} // 导出模块dinner函数
export {dinner} // 导入dinner模块,并重命名为supper
import {dinner as supper} from './App'
ES5与ES6常用语法教程之 ①函数写法、创建对象、导入导出模块方式的更多相关文章
- ES5与ES6常用语法教程之 ②解构语法糖、声明变量异同
		js常用语法系列教程如下 es5与es6常用语法教程(1) es5与es6常用语法教程(2) es5与es6常用语法教程(3) es5与es6常用语法教程(4) es5与es6常用语法教程(5) es ... 
- ES5与ES6常用语法教程之 ③模板字符串、判断字符串是否包含其它字符串
		这部分教程我们主要讲解以下几个常用语法 模板字符串 带标签的模板字符串 判断字符串中是否包含其他字符串 给函数设置默认值 模板字符串 老式的拼接字符串方法 let dessert = ' 
- ES5与ES6常用语法教程之 ④展开运算符...在数组和对象中的作用
		展开操作符(spread) 展开运算符(spread operator)允许一个表达式在某处展开.展开运算符在多个参数(用于函数调用)或多个元素(用于数组字面量)或者多个变量(用于解构赋值)的地方可以 ... 
- ES6常用语法
		ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015. 也就是说,ES6就是ES2015. ... 
- ES6常用语法简介import export
		ES6常用语法简介import export let与var用法区别 //var var a = []; for (var i = 0; i < 10; i++) { a[i] = functi ... 
- vue学习(一)ES6常用语法
		1 ES6常用语法 1.1 变量提升 例① # 变量提升 <div id="app"> </div> <script> console.log( ... 
- Typora+markdown 最常用语法教程
		Typora+markdown 最常用语法教程(by 程序员宝藏) Typora+markdown 最常用语法教程(by 程序员宝藏) 请先配置推荐配置(文件->偏好设置): 文章目录 Typo ... 
- JAE京东云引擎Git上传管理代码教程和京东云数据库导入导出管理
		文章目录 Git管理准备工作 Git工具上传代码 发布代码装程序 mywebsql管理 京东云引擎小结 JAE京东云引擎是京东推出的支持Java.Ruby.Python.PHP.Node.js多语 ... 
- ES6 常用语法知识汇总
		ES6模块化如何使用,开发环境如何打包? 1.模块化的基本语法 /* export 语法 */ // 默认导出 export default { a: '我是默认导出的', } // 单独导出 exp ... 
随机推荐
- JAVA 流与文件
			流 InputStream和OutputStream是所有的输入流和输出流的超类.他们两个都是抽象类. read方法和write方法都是阻塞方法,这意味着如果不能里可以写入或者读取,比如因为网络问题, ... 
- updatedepthtexture 和 screen space shadow 开关
			2018.0.3f 里面directional light开了shadow 就会有一张updatedepth 如果距离远 没有阴影就没有shadow pass 但是updatedepth没有关掉 管线 ... 
- maven工程的简单构建
			1.按maven约定的目录结构创建文件夹 约定目录结构:不按约定的目录来建maven无法正常工作: Hello |---src |---|---main ... 
- MVN 报错1
			找不到mapper映射文件 只打包了下面这些 所以pom.xml文件中添加 <!-- 如果不添加此节点mybatis的mapper.xml文件都会被漏掉. --> <build> ... 
- java+实现上传文件夹
			我们平时经常做的是上传文件,上传文件夹与上传文件类似,但也有一些不同之处,这次做了上传文件夹就记录下以备后用. 首先我们需要了解的是上传文件三要素: 1.表单提交方式:post (get方式提交有大小 ... 
- MessagePack Java Jackson Dataformat - POJO 的序列化和反序列化
			在本测试代码中,我们定义了一个 POJO 类,名字为 MessageData,你可以访问下面的链接找到有关这个类的定义. https://github.com/cwiki-us-demo/serial ... 
- elasticsearch 单实例安装启动
			elasticsearch 初次启动 下载 elasticsearch-6.3.2.tar.gz 创建目录 /usr/local/elasticsearch/ 解压 tar -zxf elastics ... 
- TCP层close系统调用的实现分析
			在调用close系统调用关闭套接字时,如果套接字引用计数已经归零,则需继续向上层调用其close实现,tcp为tcp_close:本文仅介绍tcp部分,前置部分请参考本博关于close系统调用的文章: ... 
- TCP主动打开 之 第三次握手-发送ACK
			假定客户端执行主动打开,并且已经收到服务器发送的第二次握手包SYN+ACK,在经过一系列处理之后,客户端发送第三次握手包ACK到服务器:其流程比较简单,主要是分配skb,初始化ack包并发送:需要注意 ... 
- 浏览器缓存及vw和vh的使用
			在浏览器缓存中不仅有 cookie 还有了别的选择 Storage 浏览器又分了两种缓存:sessionStorage localStorage localStorage 缓存:是一种永久的缓存,也就 ... 
