gpt4 book ai didi

forms - 运行 Gulp 任务 web

转载 作者:行者123 更新时间:2023-12-05 01:45:40 25 4
gpt4 key购买 nike

是否可以从 UI 页面运行 gulp 任务?

示例:拥有一个 Web 表单或任何类型的输入,当您单击任何按钮时,运行一个已经定义的特定任务(运行构建、编译 sass,您可以命名它。)

谢谢

最佳答案

是的,你可以。您只需要在需要时执行 gulp taskname 即可。您需要对执行 gulp 命令的脚本发出 ajax 请求。 F.I.,您可以使用 nodejs 和 express 使用此框架制作一个工作示例:

gulp 文件

    gulp.task('minify' , function(){
console.log('gulp called!');
gulp.src('scripts/src/test.js')
.pipe(minify() )
.pipe(gulp.dest('scripts/bin/'));
});

server.js

var express = require('express')
var app = express();
var exec = require('child_process').exec;


app.use(express.static('public'))

app.post('/send' , function(req , res){
console.log('this was called');
exec('gulp minify');
res.send('success!');

});

app.listen(3000, function () {
console.log('Example app listening on port 3000!');
});

public/index.html

    <html>

<head>

</head>

<body>
<button onclick=send()>Execute gulp minify</button>
</body>

<script
src="https://code.jquery.com/jquery-3.1.1.min.js"
integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8="
crossorigin="anonymous"></script>
<script>

function send(){
$.ajax({
url : 'http://localhost:3000/send',
method : 'POST',
success : function(res){
console.log(res);
},
error : function(response){
console.log('Error!');
console.log(response);
}
});
}
</script>
</html>

package.json

    {
"name": "gulp-from-script",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"express": "^4.14.0",
"gulp-uglify": "^2.0.0"
}
}

scripts/src/test.js

    function test(){
console.log('this file should be minified to bin/test.js on click');
//end.
}

使用该样板文件,您只需安装依赖项npm 安装

然后发球:node server.js

然后去localhost:3000/index.html

点击按钮后,/scripts/bin/test.js下会出现一个压缩文件

当然,你需要在你的系统上安装 nodejs 和 npm 才能让它工作。这只是一个演示如何执行此操作的工作示例,它可以使用任何其他服务器端技术来完成,唯一的一点是从服务器端的后 Controller 调用 gulpfile 任务。

那么,这对任何事情都有用吗?正如 Sandrina Pereira 所说,gulp 是一个任务运行器,用于构建项目的前端 Assets 。您不应从 Web 应用程序用户触发的脚本中调用它。

但是,您可以设置此类系统以在 localhost/下创建本地网站或应用程序,以通过 UI 管理您的构建,或在您的计算机中执行任何其他任务。我不知道这是否只是一个好主意或理想的主意,但它绝对可行

关于forms - 运行 Gulp 任务 web,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40807582/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com