概述
Github
初始目录设置
在最初将文件进行合理归纳,有助于后期的项目打包工作。
├─index.html # HTML页面
├─src
| ├─static # 静态文件路径
| | └favicon.png
| ├─js # JavaScript文件路径
| | └main.js
| ├─css # CSS文件路径
| | └style.css
项目运行同步预览
使用原生开发页面有一个问题,就是在测试的时候你得不断去刷新页面,而不会实时监听你的文件改动而进行刷新同步。
当然我们可以使用VSCODE
去进行开发,使用live server
插件去进行同步预览。
但不是每个人都是用VSCODE
进行项目开发的,因此我们还是使用node
去实现项目的同步预览。
// 初始化Node
yarn
// 安装browser-sync
yarn add browser-sync
这里我使用browser-sync
,更多的使用方法可以去官网查看,这里就不多说了。
安装完成后,打开命令行工作,执行以下命令。
// 进入项目路径
cd nativeTemplate
// 实行browsersync(监听html、css、js文件)
browser-sync start --server --files "*.html, src/css/*.css, src/js/*.js"
但每次开始项目都得去执行命令就会比较麻烦,我们可以将其配置到package.json
中。
{
"scripts": {
"serve": "browser-sync start --server --files "*.html, src/css/*.css, src/js/*.js""
}
}
这样子我们以后只需要执行yarn serve
就可以运行项目了。
配置跨域
当你原生开发然后需要对接接口的时候,配置跨域就是一个挺头疼的事情了。
当然你可以让后端将接口设置CORS跨资源共享,达到跨域的目的。
然而我们也可以使用http-server
来实现跨域配置。
// 安装http-server
yarn add http-server
具体的使用操作我也不多说了,可以去看一下文档说明。这里就只讲讲我们跨域要用到的操作。
我们先执行下面的命令,开启本地8888端口,然后重定向到我们的API接口。
http-server -p 8888 --cors -P https://jsonplaceholder.typicode.com
当然你依旧可以配置到package.json
里,然后执行yarn http-server
进行启动。
{
"scripts": {
"http-server": "http-server -p 8888 --cors -P https://jsonplaceholder.typicode.com"
}
}
然后这时候,我们就可以在main.js
进行请求接口了。
const baseApi = 'http://localhost:8888';
// 请求数据 (跨域请求)
function request() {
fetch(baseApi + '/posts')
.then(response => response.json())
.then(data => console.log(`Request success!`, data))
}
request();
当然这个只能用于前端调试用,当项目实现后,我们可将baseApi
改为/api
,然后让后端使用nginx
去重定向既可。
项目打包
按理而言,使用原生开发是可以不需要打包项目的,直接部署就可以的。
但在实际开发中,还是需要进行项目的打包,一是将文件继续压缩,二是将静态文件进行重命名处理,防止缓存问题。
这里我们使用gulp
来实现项目打包的自动化处理。
// 安装
yarn gulp gulp-cssmin gulp-htmlmin gulp-rev gulp-rev-collector gulp-uglify del
这里的gulp-cssmin
、gulp-htmlmin
、gulp-uglify
是用于压缩css、html、js文件;gulp-rev
、gulp-rev-collector
、del
是用于重命名静态文件处理的。
安装完成后,在根路径新建一个gulpfile.js
文件,先把安装的东西引入。
const gulp = require('gulp');
const rev = require('gulp-rev');
const del = require('del');
const revCollector = require('gulp-rev-collector');
const uglify = require('gulp-uglify');
const htmlMin = require('gulp-htmlmin');
const cssMin = require('gulp-cssmin');
然后我们先来实现css的压缩和重命名。
gulp.task('rev:css', () => {
return gulp.src('src/css/*.css')
.pipe(rev()) // 将所有匹配到的文件名全部生成相应的版本号
.pipe(cssMin()) // 压缩CSS
.pipe(gulp.dest('dist/assets')) // 将压缩好的新css文件保存到dist/assets路径下
.pipe(rev.manifest()) //把所有生成的带版本号的文件名保存到rev-manifest.json文件中
.pipe(gulp.dest('rev/css')) //把rev-manifest.json文件保存到指定的路径
})
然后执行gulp rev:css
命令后,路径下会多出了dist
和rev
文件夹,dist/assets
路径下会有打包好的css
文件,而在rev/css
下会有一个rev-manifast.json
文件,里面存放着文件名的映射表,用于后面更换index.html
里的文件引入。
同理的我们也可以实现对JavaScript
和其他静态文件的压缩和重命名处理。
gulp.task('rev:js', () => {
return gulp.src('src/js/*.js')
.pipe(rev())
.pipe(uglify()) // 压缩JS
.pipe(gulp.dest('dist/assets'))
.pipe(rev.manifest())
.pipe(gulp.dest('rev/js'))
})
gulp.task('rev:static', () => {
return gulp.src('src/static/**')
.pipe(rev())
.pipe(gulp.dest('dist/assets'))
.pipe(rev.manifest())
.pipe(gulp.dest('rev/static'))
})
然后依次执行gulp rev:js
和gulp rev:static
。
之后我们需要对index.html
里面的引入进行替换。
gulp.task('rev-collector', () => {
return gulp.src(['rev/**/*.json', './*.html'])
.pipe(revCollector({
dirReplacements: { // 对引入路径进行重置
'src/css': 'assets',
'src/js': 'assets',
'src/static': 'assets'
},
replaceReved: true
}))
.pipe(htmlMin({ // 压缩HTML
collapseWhitespace:true,
collapseBooleanAttributes:true,
removeComments:true,
removeEmptyAttributes:true,
removeScriptTypeAttributes:true,
removeStyleLinkTypeAttributes:true,
minifyJS:true,
minifyCSS:true
}))
.pipe(gulp.dest('dist'))
})
执行gulp rev-collector
后,既可在dist
路径下看到新生成的index.html
文件,此时我们项目打包的基础工作就做好了。
但如果我们后面还需要修改文件后再进行项目打包时,我们需要事前清理dist
文件下的所有文件,不然的话就会累积着上次的文件,而不会被迭代掉。并且,对于rev
文件夹也是如此,当项目打包结束后,该文件夹也没有任何作用了,也可以进行删除处理。
因此我们需要进行一个清理文件的工作。
// 删除文件
gulp.task('clean:init', (cb) => {
return del(['dist/*', 'rev/*'], cb)
})
gulp.task('clean:rev', (cb) => {
return del(['rev'], cb)
})
这时候,我们在gulpfile.js
中设置了6个自动化任务,并且每次都需要按照一定的顺序去执行任务,因此我们可以将所有任务进行一个整合。
gulp.task('build', gulp.series(
'clean:init',
gulp.parallel('rev:js', 'rev:css', 'rev:static'),
'rev-collector',
'clean:rev'
))
现在我们可以执行gulp build
实现全部打包动作。
简单说一下自动化工作流程:
- 首先执行
clean:init
,将原本的dist
和rev
文件清空删除。 - 其次同步执行
rev:js
、rev:css
、rev:static
,对全部静态文件进行压缩和重命名处理。 - 接着执行
rev-collector
,对index.html
进行文件引入的更换。 - 最后执行
clean:rev
,将rev
文件夹删除。
同样,我们也可以将其配置到package.json
中。
{
"scripts": {
"build": "gulp build"
}
}
然后执行yarn build
既可进行项目打包。
项目目录说明
├─index.html # HTML页面
├─src
| ├─static # 静态文件路径
| | └favicon.png
| ├─js # JavaScript文件路径
| | └main.js
| ├─css # CSS文件路径
| | └style.css
├─dist # 打包文件路径
| ├─index.html
| ├─assets
| | ├─favicon-a35b664aff.png
| | ├─main-ce0b6aa357.js
| | └style-118e221845.css
├─gulpfile.js # gulp配置文件
├─README.md # 说明文档
├─package.json # node配置文件
最后
以上就是高高蜗牛为你收集整理的前端原生开发的一些自动化处理的全部内容,希望文章能够帮你解决前端原生开发的一些自动化处理所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复