对【经典前端】项目进行工程化改造的经验分享

简介: 最近都在折腾一个叫“我爱掘金”的插件,其中有个小的概念功能叫“蝌蚪池塘”获得掘友们的喜爱,大家可以化身为小蝌蚪在池塘里实时聊天,设置了不少彩蛋,比如变身路飞,皮卡丘等。

这个小功能是使用开源项目 wokerman-tadpole 搭建的。这是一个【经典前端】项目...


image.png


什么是经典前端?


现在的前端框架都会自带脚手架,或者直接使用webpack等工具新建前端项目,这样的项目自带了混淆代码整合图片压缩发行部署等功能,非常方便。我们也已经习惯了在框架中使用importrequire。但没有这些工具之前,前端工程师都是通过script标签来引入JS代码的。我把这类仍然需要手动引入script的项目就叫做【经典前端】项目。


复习经典前端必备知识点


  • script标签写在head和写在body里的区别?


写在head里的script标签会优先于页面加载,此时body还没加载和渲染。所以浏览器会等待这些内容加载完成后才渲染body。网速不好的状态下,就看到个白屏啦。写在body最后,可以保证代码在加载和运行时,所有dom元素都被渲染出来了。


  • script标签的加载顺序?


从上到下,如果你的代码中有一些其他JS代码内容的引用,那就需要明确他们加载的前后顺序。


  • 为什么我们应该减少请求数量?


通常情况下,网页里引入的单个js,css,以及图片都不会太大。但是在大型项目中,我们可能需要引入数量众多的琐碎小文件。将这些琐碎小文件合并到一个请求里,能够更快的让我们的网页加载完成。


以上内容来自著名的《雅虎前端优化35条军规》,现在这些军规在web前端领域仍然有效,只是大部分被现代框架,脚手架帮助我们自动完成了。


来吧,开始改造


复习完经典前端的必备知识点,现在我们应该很清楚这个项目应该如何改造了。我们完全可以手动对项目进行改造,比如手动将一个个的js文件整合并压缩,但那未免也太麻烦了。所以咱们要使用 Gulp 来完成自动化改造。


Gulp介绍


gulp 将开发流程中让人痛苦或耗时的任务自动化,从而减少你所浪费的时间、创造更大价值。


1. 安装Gulp


先初始化npm环境,使老项目有机会焕发新生


npm init


image.png


init完成之后,我们的项目中就多出来package.json,这代表着我们可以使用先进的生产力工具node了。


安装gulp


npm install gulp


image.png


建立gulpfile.js


image.png


并写下我们的第一个gulp任务


var gulp = require("gulp");
gulp.task("build",function(){
    console.log("hello gulp!");
});


接着在终端里输入gulp 任务名称,也就是gulp build


image.png


gulp的环境就算是建立好了,接下来我们需要一步步完成咱们的工程化需求。


2. 建立发行目录dist


开发的归开发,发行的归发行。上面所有的提到的需求是针对发行的网页而言,开发的时候咱们还是怎么清晰,怎么方便,怎么适合分工合作的来进行。最后测试都跑通了,咱们再输出为发行版。


咱们把gulpfile.js更新一下


var gulp = require("gulp");
var del = require("del");//利用del依赖包来进行文件夹的清理工作
gulp.task("build",function(cb){
  del(["dist"]).then(()=>{
      gulp.src(['lib/**'])
      .pipe(gulp.dest('dist/lib'));
      gulp.src(['images/**'])
      .pipe(gulp.dest('dist/images'));
      gulp.src(['css/**'])
      .pipe(gulp.dest('dist/css'));
      cb();
  });
});


再次运行gulp build我们就可以看到多了一个文件夹,并且帮我们将libimagescss三个目录及其子文件都复制到了dist目录下。


image.png


kedou.htmljs文件都还没有呢?这能行?别着急,马上就来处理这俩


3. 整合JS文件


简单来说,我们需要把JS目录下的所有.js文件整合到一个文件里。


使用一个concat库(使用前记得先安装)


var concat = require('gulp-concat');


build任务最后加入以下代码


gulp.src(['js/*.js'])
.pipe(concat('main.js'))
.pipe(gulp.dest('dist/js'))


这三行代码的意思分别为


  • 获取所有js目录下.js文件的内容


  • 将所有内容拼接到main.js


  • 将拼接后的文件存放到dist/js目录下


我们再次运行gulp build试试看


image.png


项目js文件夹内的所有.js文件都被整合进了dist/main.js文件中,接下来我们为它添加压缩和混淆。


4. 混淆和压缩

引入gulp-uglify混淆压缩依赖


var uglify = require('gulp-uglify');//记得npm install gulp-uglify


在JS合并的管道中添加uglify


gulp.src(['js/*.js'])
.pipe(concat('main.min.js'))
.pipe(uglify())
.pipe(gulp.dest('dist/js'))


image.png


5. 替换kedou.html中的script引用


原本kedou.html中的script引用如图。现在这些JS都被我们合并到main.min.js中了,这个HTML页面里的引用自然也要修改才可以正常运行。


image.png


我们利用 gulp-html-replace 依赖来完成此需求


引入依赖


var htmlreplace = require('gulp-html-replace');


build任务里添加对kedou.html的操作


gulp.src('kedou.html')
.pipe(htmlreplace({
    'js': 'js/main.min.js'
}))
.pipe(gulp.dest('dist/'));


我们还需要编辑kedou.html添加需要替换的标记


image.png


再次运行gulp build


image.png


大功告成


image.png


我们成功的减少了13个请求,减少了20kB的数据


image.png


这难道是个很蛋疼的事吗?


绝对不是!!


网页性能优化,往往以KB来计算,这还没有开启gzip,开启后效果明显。


大家感兴趣的可以前往 www.rainbow1024.com/ilovejuejin…


看看我极致优化后的蝌蚪池塘,我的内容可比原版多多了。


image.png


相关文章
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
743 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
548 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
989 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
544 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
788 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
前端开发 Java 开发工具
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
1576 18
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
994 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
缓存 前端开发 Android开发
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
718 12
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
522 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
前端开发 测试技术
前端工程化的分支策略要如何与项目的具体情况相结合?
前端工程化的分支策略要紧密结合项目的实际情况,以实现高效的开发、稳定的版本控制和顺利的发布流程。
351 58

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    1167
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    512
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    398
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    390
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    507
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    678
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    1200
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    272
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    997
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    467