热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WebpackbabelES6转ES5

npminstall-Dbabelcorebabelpreset-envbabelplugin-transform-runtimebabelpolyfillbabel-loader

npm install -D @babel/core @babel/preset-env @babel/plugin-transform-runtime @babel/polyfill babel-loader

创建.babelrc文件

命令行方式创建输入:type nul>.babelrc

{"presets": [["@babel/preset-env", {"useBuiltIns": "usage","modules": false}]],"plugins": [["@babel/plugin-transform-runtime", {"corejs": false,"helpers": false,"regenerator": false,"useESModules": false}]],"comments": false
}

添加module 

yarn add clone -D

webpack.config.js配置 babel-loader

let path = require('path');
let HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports= {mode:'development',//production developmententry:'./src/index.js',//入口output:{filename:'bundle.[hash:8].js',//打包后的文件名path:path.resolve(__dirname,'dist')},devServer:{port:8090,progress:true,contentBase:'./dist'},plugins:[new HtmlWebpackPlugin({template:'./src/index.html',filename:'index.html',minify:{removeAttributeQuotes:true,//删除属性双引号collapseWhitespace:true,//html折叠一行minifyJS: true,//压缩HTML中JSminifyCSS: true//压缩HTML中CSS},hash:true//生成hash戳})],module: {rules: [ // 定义css规则,use从下往上顺序执行{test: /\.css$/, // 正则匹配要识别的cssuse: [{loader: 'style-loader' // 使用style-loader进行处理,位置必须在css-loader前面},{loader: 'css-loader' // 使用css-loader进行处理}]//use:['style-loader','css-loader'] // 此处也可以这样写},{test:/\.less$/,use: [{loader: 'style-loader' // 使用style-loader进行处理,位置必须在css-loader前面},{loader: 'css-loader' // 使用css-loader进行处理},{loader: 'less-loader' //less ——> css}]},{test: /\.js$/,include: [path.resolve(__dirname, 'src')],exclude: /(node_modules|bower_components)/,loader: "babel-loader",}]}}

Superstr-1.0.js

function Superstr(){}
Superstr.prototype.version='1.0';
Superstr.prototype.jsonHttpRequest={/***请求JSON格式数据*@param:method 请求方式,标准的GET、POST(_method=PUT)*@param:url 请求地址URL*@param:asyn 是否异步请求*@param:callback 请求成功执行的回调函数*@data:请求参数*/request: function(method,url,asyn,callback,data) {var param = null;var temp = 'superstr_timestamp=' + new Date().getTime();if(data) {for(var key in data) {temp = temp + '&' + key + '=' + data[key]; }}if(method.toLocaleUpperCase()=='POST') {param = temp;} else {method = 'GET';if(url.indexOf('?')>-1) {url = url + '&' + temp;} else {url = url + '?' + temp;}}var xhr = new XMLHttpRequest();//创建Http请求对象xhr.onreadystatechange=function() {if(xhr.readyState==4&&xhr.status==200) {callback(JSON.parse(xhr.responseText));} else if(xhr.readyState==4){alert("———请求异常———"+"\n"+"请求地址(url):"+url+"\n"+"请求方式(method):"+method+"\n"+"状态码(status):"+xhr.status+"\n"+"异步(asyn):"+asyn);}}xhr.open(method,url,asyn);//true:异步 false:同步xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");xhr.send(param);}
}
Superstr.prototype.arrays={/***移除数组中重复的对象*@param:arr 数组*@param:property 数组中对象的属性名称*@return:array 处理后的数组*/only: function(arr, property) {let hash = {}var array = arr.reduce((item, next) => {if (!hash[next[property]]) {hash[next[property]] = true;item.push(next);}return item;}, [])return array;},/***过滤数组中的对象*@param:arr 数组*@param:property 数组中对象的属性名称*@param:value 数组中对象属性的值*@return:array 处理后的数组*/remove: function(arr,property,value) {var array = arr.filter((obj) => {return obj[property] != value} )return array;},/** *数组冒泡排序*@param:arr 数组*@param:property 数组中对象的属性名称*/bubbleSort: function(arr, property) {var array = arr,temp;for(var i=0; iarr[j][property]) {temp=arr[i];arr[i]=arr[j];arr[j]=temp;}}}return array;}
}
Superstr.prototype.classNames={names: {draggable:"draggable"},/***添加拖拽效果,对象互换*@descriptions:在添加效果之前需要保证对象可拖动(draggable="true")*/draggable: function() {var className = this.names.draggable;var obj = null;//拖动的对象window.onload=function() {var elements = document.getElementsByClassName(className);for(var n=0;n}
var _ = new Superstr();

index.js 导入 Superstr-1.0.js

import './Superstr-1.0.js';

执行打包命令

npx webpack

发现打包后的代码中已经没有 =>箭头函数了


推荐阅读
  • ReactJSUIAnt设计空组件原文:https://w ... [详细]
  • 本文讨论了在dva中引入antd组件table时没有显示样式的问题。提供了.roadhogrc文件的配置,包括环境和import的设置。同时介绍了extraBabelPlugins和transform-runtime的使用方法,并解释了libraryName和css的含义。 ... [详细]
  • VueCLI多页分目录打包的步骤记录
    本文介绍了使用VueCLI进行多页分目录打包的步骤,包括页面目录结构、安装依赖、获取Vue CLI需要的多页对象等内容。同时还提供了自定义不同模块页面标题的方法。 ... [详细]
  • React 小白初入门
    推荐学习:React官方文档:https:react.docschina.orgReact菜鸟教程:https:www.runoob.c ... [详细]
  • 1.移除consol.log()的babel插件安装:npmibabel-plugin-transform-remove-console-D配置:babel.config.js:这 ... [详细]
  • 前言:原本纠结于Web模板,选了Handlebars。后来发现页面都是弱逻辑的,不支持复杂逻辑表达式。几乎要放弃之际,想起了Javascript中ev ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • 本文详细介绍了git常用命令及其操作方法,包括查看、添加、提交、删除、找回等操作,以及如何重置修改文件、抛弃工作区修改、将工作文件提交到本地暂存区、从版本库中删除文件等。同时还介绍了如何从暂存区恢复到工作文件、恢复最近一次提交过的状态,以及如何合并多个操作等。 ... [详细]
  • node.jsrequire和ES6导入导出的区别原 ... [详细]
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • 本文介绍了在Android Studio中使用命令行build gradle的方法,并解决了一些常见问题,包括手动配置gradle环境变量和解决External Native Build Issues的方法。同时提供了相关参考文章链接。 ... [详细]
  • 使用gitolite搭建一个私有的git服务器,来管理git仓库。有了它,就可以跟小伙伴们愉快地进行远程协作啦。今天又折腾了一遍,在这里把几个关键的步骤记下来,方便以后查阅。准备工 ... [详细]
author-avatar
360691894_8a5c48
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有