thinkphp整合系列之gulp实现前端自动化

2024-08-25 16:38

本文主要是介绍thinkphp整合系列之gulp实现前端自动化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这又是一个一次整合终身受益;不止是终身;换个项目同样可以很方便复用;不信你看另一个项目: thinkphp整合系列之gulp实现前端自动化

虽然我等叫php程序猿;但是不可避免的是要跟html打交道的;而且php这么容易开发web;难道我们不想自己随手写点什么?laravel这类比较前卫的框架;早就深度集成了很多前端的东西;现在;就让我们手动为thinkphp也插上gulp的翅膀吧;第一步;在自己的thinkphp项目根目录中创建 package.json;

{ "name": "baijunyao/thinkphp-bjyadmin", "version": "1.0.0", "description": "博客", "main": "index.js", "scripts": { "test": "echo \\"Error: no test specified\\" && exit 1" }, "keywords": [ "白666", "博客" ], "author": "baijunyao", "license": "Apache2", "devDependencies": { "babel-preset-es2015": "^6.18.0", "babel-preset-stage-2": "^6.18.0", "browser-sync": "^2.14.0", "gulp": "^3.9.1", "gulp-babel": "^6.1.2", "gulp-cleanhtml": "^1.0.1", "gulp-concat": "^2.6.0", "gulp-contrib-copy": "^0.1.2", "gulp-decomment": "^0.1.3", "gulp-imagemin": "^3.0.2", "gulp-less": "^3.1.0", "gulp-load-plugins": "^1.2.4", "gulp-minify-css": "^1.2.4", "gulp-plumber": "^1.1.0", "gulp-rename": "^1.2.2", "gulp-sass": "^2.3.2", "gulp-uglify": "^2.0.0" } 
}

第二步;在自己的thinkphp项目根目录中创建 gulpfile.js;

var gulp        = require('gulp'), sass        = require('gulp-sass'), minifyCss   = require('gulp-minify-css'), plumber     = require('gulp-plumber'), babel       = require('gulp-babel'), uglify      = require('gulp-uglify'), clearnHtml  = require("gulp-cleanhtml"), imagemin    = require('gulp-imagemin'), copy        = require('gulp-contrib-copy'), browserSync = require('browser-sync').create(), reload      = browserSync.reload; // 定义源代码的目录和编译压缩后的目录 
var src='tpl_src', dist='tpl'; 
// 编译全部scss 并压缩 
gulp.task('css', function(){ gulp.src(src+'/**/*.scss') .pipe(sass()) .pipe(minifyCss()) .pipe(gulp.dest(dist)) 
}) 
// 编译全部js 并压缩 
gulp.task('js', function() { gulp.src(src+'/**/*.js') .pipe(plumber()) .pipe(babel({ presets: ['es2015'] })) .pipe(uglify()) .pipe(gulp.dest(dist)); 
}); 
// 压缩全部html 
gulp.task('html', function () { gulp.src(src+'/**/*.+(html|tpl)') .pipe(clearnHtml()) .pipe(gulp.dest(dist)); 
}); 
// 压缩全部image 
gulp.task('image', function () { gulp.src([src+'/**/*.+(jpg|jpeg|png|gif|bmp)']) .pipe(imagemin()) .pipe(gulp.dest(dist)); 
}); 
// 其他不编译的文件直接copy 
gulp.task('copy', function () { gulp.src(src+'/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html|tpl)') .pipe(copy()) .pipe(gulp.dest(dist)); 
}); 
// 自动刷新 
gulp.task('server', function() { browserSync.init({ proxy: "tbjyadmin.com", // 指定代理url notify: false, // 刷新不弹出提示 }); // 监听scss文件编译 gulp.watch(src+'/**/*.scss', ['css']); // 监听其他不编译的文件 有变化直接copy gulp.watch(src+'/**/*.!(jpg|jpeg|png|gif|bmp|scss|js|html)', ['copy']);    // 监听html文件变化后刷新页面 gulp.watch(src+"/**/*.js", ['js']).on("change", reload); // 监听html文件变化后刷新页面 gulp.watch(src+"/**/*.+(html|tpl)", ['html']).on("change", reload); // 监听css文件变化后刷新页面 gulp.watch(dist+"/**/*.css").on("change", reload); 
}); 
// 监听事件 
gulp.task('default', ['css', 'js', 'image', 'html', 'copy', 'server'])

把 gulpfile.js 中的src 和 dist 变量替换为自己项目的实际目录;把proxy 替换为自己的本地自定义域名;第三步: 命令行运行如下命令:

# 安装各种包 
cnpm install 
# 运行gulp 
gulp

如果不出意外;会自动编译并打开浏览器了;例如 thinkphp整合系列之gulp实现前端自动化  显示的效果那样,简单吧;就3步;但是为了写这篇文章;我花了2个月时间写了7篇文章做铺垫;想想;我的内心都是崩溃的;以项目为例讲解下吧: 运行gulp后;会有如下操作; tpl_src 目录下的所有scss文件编译压缩输出到 src 目录下; tpl_src 目录下的所有js使用babel转码压缩输出到 src 目录下; tpl_src 目录下的所有图片压缩输出到 src 目录下; tpl_src 目录下的所有html压缩输出到src目录下; tpl_src 目录下的其他类型文件直接复制到src目录下; 触发监听任务;有文件变动自动执行上述几条任务;并且自动刷新浏览器;神马?你的html和各种静态文件还都放在Application的各个模块下的view目录中?那先来看这篇文章:thinkphp把模板文件View独立出来另外;小伙子;我看你骨骼惊奇;必是 coding 奇才;将来维护程序猿界的正义与和平的重任就交给你了;

这篇关于thinkphp整合系列之gulp实现前端自动化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106090

相关文章

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端