webpack配置文件能用es6写么
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webpack配置文件能用es6写么相关的知识,希望对你有一定的参考价值。
参考技术A 只要修改Webpack 文件名,为webpack.config.babel.js 就可以,但node 版本> 4, 并且要安装全babel-loader 和 babel-core ,webpack 会自动把webpack.config.babel 转化成es5 参考技术B 研究react的时候也考虑过这个问题,首先可以先了解下这两种模块的机制。参考这里 要考虑的点: 目前Commonjs是nodejs(浏览器环境需要模块加载器)原生支持的,而es6需要借助babeljs来实现。意味着如果要实现自动编译上线(我司没有在线上安装nodes6 对象的扩展
一、现在还有很多浏览器不能直接使用es6语法。特别是手机端的一些低版本的浏览器。都需要用bale转换一下。
但是目前流行的框架中(vue,react,angular)。都有自己的脚手架,都能用webpack转换下。或者直接自己配置webpack , fis3,nowa 等转换。
照样不是美滋滋。
二、属性的简洁写法
//1.属性简洁表示语法 var foo = ‘bar‘; var obj = {foo}; console.log(obj); //创建对象的函数 function createOjb(x = 1,y = 1){ //x = 1, y = 1; 参数的默认值 return { x,y } } var newObj = createOjb(); console.log(newObj); //{x:1,y:1} var birthDate = ‘2017/8/12‘ //2 方法的简写 var person = { name:‘绿巨人‘, age:‘200岁‘, birthDate, say(){ console.log(this.name); //等同于 say:function(){ console.log(this.name)}; } } person.say(); // 绿巨人 //in 方法 var msg = { hello:‘helloValue‘, world:‘worldValue‘ } console.log(‘hello‘ in msg,‘helloValue‘ in msg); // true,false; => 判断某个键值是在某个对象里面 //commonJS 模块化输出 function Obj(methods){ this.methods = methods || {}; } Obj.prototype.getItem = function(key){ return key in this.methods ? methods[key] : null; } Obj.prototype.setItem = function(key,value){ this.methods[key] = value; } var obj = new Obj(); //module.exports = {obj}; //4.注意点 :简洁写法的属性名总是字符串,这会导致一些看上去比较奇怪的结果。
三、属性表达式
//属性名表达式 // 1. 对象添加属性的两种方式 var newObj = new Object(); newObj.name = ‘html‘; newObj[‘age‘] = ‘20岁‘; //对象字面量的方式 se5 中字面量方式下 属性名字只能用 字符串形式。不能用 [‘name‘] var newObj1 = { name:‘css‘, age:‘30岁‘ } //SE6 var newObj2 = { [‘name‘]:‘js‘, [‘a‘ + ‘ge‘]:‘40岁‘, [‘hello world‘]:‘say hello world‘, [‘say‘ + ‘ hi‘](){ console.log(this[‘hello world‘]) } } console.log(newObj2.name); // jss console.log(newObj2[‘hello world‘]); // say hello world newObj2[‘say hi‘](); // say hello world //!!!注意 属性名表达式是不能喝属性简写一起使用的 var objKey = {a:1}; var newObj3 = { [objKey]:‘我是一个对象‘ } console.log(newObj3); // {[object object]:‘我是一对象‘} console.log(newObj3[{a:1}]); // 我是一个对象 console.log(newObj3[‘object object‘]); // undefined 是不是很奇怪啊
以上是关于webpack配置文件能用es6写么的主要内容,如果未能解决你的问题,请参考以下文章