gulp——用自动化构建工具增强你的工作流程

本文介绍gulp的基本概念及其在前端项目中的应用,包括安装配置、常用API及插件使用等,帮助开发者快速上手并提高构建效率。
gulp概念
之前有写了webpack, 现在重新写gulp感觉二者最终结果虽说相差无几,但是侧重点还是有所不同
webpack更偏向于工程化,gulp侧重于项目的整个流程控制,你可以二者结合,也可以分开取舍 都有利于前端项目的工程化构建
  • 安装
    1、全局安装

      $ npm install -g gulp 

    2、作为项目的开发依赖(devDependencies)安装:

      $ npm install --save-dev gulp

    3、 在项目根目录下创建一个名为 gulpfile.js 的文件:

       var gulp = require('gulp');
       gulp.task('default', function() {
         // 将你的默认的任务代码放在这
       });

    4、 运行 gulp:

       $ gulp
    
    • api
      (1) gulp.src()

      gulp.src('client/js/**/*.js') // 匹配 'client/js/somedir/somefile.js' 并且将 `base` 解析为 `client/js/`
        .pipe(minify())
        .pipe(gulp.dest('build'));  // 写入 'build/somedir/somefile.js'
      
      gulp.src('client/js/**/*.js', { base: 'client' })
        .pipe(minify())
        .pipe(gulp.dest('build'));  // 写入 'build/js/somedir/somefile.js'

      (2) gulp.task()

      其实gulp就是不断起一些任务函数,来运行你的项目
      gulp.task('copyplugin',function(){
          gulp.src('./src/plugin/**/*')
          .pipe(gulp.dest('./dev/plugin'))
       })
      
       gulp.task('packscss',function(){
          gulp.src('./src/styles/app.scss')
          .pipe(sass().on('error',sass.logError))
          .pipe(gulp.dest('./dev/styles'))
       })
      ....

      (3) gulp.watch()

       用来接听任务函数,把要接听的任务传入 启动的时候 会根据传入的任务进行执行,当然,不会按顺序
       gulp.task('watch',function(){
          gulp.watch('./src/*.html',['copyhtml'])
          gulp.watch('./src/images/**/*',['copyimg'])
          gulp.watch('./src/styles/**/*.scss',['packscss'])
       }     

      (4) 当你想直接gulp启动项目的话,会使用

       gulp.task('default',['webserver','copyhtml','copyimg','copyplugin','packscss','packjs','watch'],
       function(){
          console.log('DONE')
      })
  • 其实gulp常用的就是插件,下面介绍一下项目中常用的插件,从而帮你更高效的构建项目
    (1) 启动服务插件 npm i gulp-webserver -D

    配置:
       引入gulp
       var gulp = require('gulp')
       
       var webserver = require('gulp-webserver')
       
       gulp.task('webserver',function(){
           gulp.src('./dev')     //编译后的根目录
           .pipe(webserver({
               host : 'localhost',
               port : 4000,
               directoryListing : {   //启动项目显示目录
                   enable : true,
                   path : './dev'
               },
               livereload : true
           }))
       })

    (2) 编译sass npm i gulp-sass node-sass -D

    var sass = require('gulp-sass')
    
    gulp.task('packscss',function(){
       gulp.src('./src/styles/app.scss')
       .pipe(sass().on('error',sass.logError))
       .pipe(gulp.dest('./dev/styles'))
       console.log('sass编译啦')
    })

    (3) 编译commenjs实现模块化开发 npm i gulp-webpack -D

    var webpack = require('gulp-webpack')
    
       gulp.task('packjs',function(){
           gulp.src('./src/scripts/app.js')
           .pipe(webpack({
               output : {
                   filename : 'app.js'  //输出文件为 name.js
               },
               module : {        
                   loaders :[      //加载器
                       {
                           test : /\.js$/,    //指定加载文件的类型
                           loader : 'imports-loader',  //用imports-loader解析
                           exclude : './node_modules'  //排除不需要编译的js文件
                       }
                   ]
               }
           }))
           .pipe(gulp.dest('./dev/scripts'))
       })

    (4) 解析浏览器不识别的require npm i imports-loader -D

           
      直接 $ gulp 即可
           bogon:guang_m macbook$ npm i imports-loader -D
           guang_m@1.0.0 /Users/macbook/Desktop/learning/third/guang_m
           └─┬ imports-loader@0.7.1 
             ├── loader-utils@1.1.0 
             └── source-map@0.5.7 
           
           npm WARN guang_m@1.0.0 No description
           npm WARN guang_m@1.0.0 No repository field.
           bogon:guang_m macbook$ gulp
           [15:01:40] Using gulpfile ~/Desktop/learning/third/guang_m/gulpfile.js
           [15:01:40] Starting 'webserver'...
           [15:01:40] Webserver started at http://localhost:4000
           [15:01:40] Finished 'webserver' after 21 ms
           [15:01:40] Starting 'packscss'...

    (5) 解析多个js文件 npm i vinyl-named -D

        gulp.src('./src/scripts/app.js')
        .pipe(name())
         .pipe(webpack({
           output: {
             filename: '[name].js'
           },
           module: {
             loaders: [
               {
                 test: /\.js$/,
                 loader: 'imports-loader',
                 exclude: './node_modules'
               }
             ]
           }

    (6) 下载yo3 框架,专注于移动端的scss npm i yo3 -D

    在node_modules中找到yo3 复制style到项目src中 
    习惯性的在style中创建app.scss 用来import一些需要的文件
    ,再在usage中创建模块scss文件index.scss显示页面样式
       
       .m-index{
           height: 100%;
           @include flexbox();
           @include flex-direction(column);
           header{
               height: .44rem;
               background: #00b38a;
           }
           section{
               background: #fff;
               @include flex();
           }
           footer{
               height:.44rem;
               background: #f6f6f6;
       
           }
       }   

    (7) 加载字符串模板 npm i string-loader -D

        loaders : [
           {
               test : /\.js$/,
               loader : 'imports-loader',
               exclude : './node_modules'
           },
           {
               test : /\.string$/,
               loader : 'string-loader'
           }
       ]    

    好了 ,常用就这些了 如果有新的知识点后续还会补充.....

/* USER CODE BEGIN Header */ /** ****************************************************************************** * @file : main.c * @brief : Main program body ****************************************************************************** * @attention * * <h2><center>© Copyright (c) 2025 STMicroelectronics. * All rights reserved.</center></h2> * * This software component is licensed by ST under BSD 3-Clause license, * the "License"; You may not use this file except in compliance with the * License. You may obtain a copy of the License at: * opensource.org/licenses/BSD-3-Clause * ****************************************************************************** */ /* USER CODE END Header */ /* Includes ------------------------------------------------------------------*/ #include "main.h" #include "usart.h" #include "gpio.h" /* Private includes ----------------------------------------------------------*/ /* USER CODE BEGIN Includes */ #include "dht11.h" #include "stdio.h" #include <stdlib.h> /* USER CODE END Includes */ /* Private typedef -----------------------------------------------------------*/ /* USER CODE BEGIN PTD */ /* USER CODE END PTD */ /* Private define ------------------------------------------------------------*/ /* USER CODE BEGIN PD */ /* USER CODE END PD */ /* Private macro -------------------------------------------------------------*/ /* USER CODE BEGIN PM */ /* USER CODE END PM */ /* Private variables ---------------------------------------------------------*/ /* USER CODE BEGIN PV */ #include "string.h" #define RxMaxLen 100 #define timeout 5000 uint8_t RxBuf[100]={0}; uint32_t startTick = 0; char atMode[] = "AT+CWMODE=1\r\n"; //设置wifi工作模式的AT指令 char atJap[] = "AT+CWJAP=\"HONOR 90\",\"041028ly\"\r\n"; // wifi连接热点的AT指令 char atTcp[] = "AT+CIPSTART=\"TCP\",\"121.37.241.174\",8600\r\n"; //wifi连接云端服务器的AT指令 char atSendConn[] = "AT+CIPSEND=88\r\n"; //wifi上传数据字节数的AT指令 char atJsonConn[] = "{\"t\":1,\"device\":\"esp8266_199\",\"key\":\"39a2825123ad4ff8a4779cbd5fca31b7\",\"ver\":\"v0.0.0.0\"}\r\n"; //wifi连接设备的JSON数据 AT指令 char atSendSens[] = "AT+CIPSEND=53\r\n"; ////wifi上传数据字节数的AT指令 //char atJsonSens[] = "{\"t\":3,\"datatype\":1,\"datas\":{\"temp\":\"12\"},\"msgid\":123}\r\n"; ////wifi给传感器上报数据的JSON AT指令 //给wifi发送AT指令 void SenAtCom(char *str) { HAL_UART_Transmit(&huart3,(uint8_t *)str,strlen(str),0xffff); } //wifi连接热点函数 void ProjectConn() { SenAtCom(atMode); HAL_Delay(50); SenAtCom(atJap); startTick= HAL_GetTick(); //获了系统当前运行时间 while ((HAL_GetTick() - startTick) < timeout) //当所用时间小于退出时间 { if(strstr((char *)RxBuf,"GOT IP") == RESET) //如没有收到“获得IP”,即如没有连接到热点 { HAL_Delay(10); //延时 SenAtCom(atJap); //继续连接热点 } else { break; //连接到了,就退出。 } } } //wifi连接服务器函数 void ServerConn() { SenAtCom(atMode); HAL_Delay(50); SenAtCom(atJap); HAL_Delay(2000); SenAtCom(atTcp); HAL_Delay(50); } //串口3接收中断回调处理函数,该函数可以处理不定长度的接收中断 void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size) { if(huart == &huart3) { HAL_UART_Transmit(&huart1,RxBuf,sizeof(RxBuf),0xffff); //把串口3接收到的wifi回复,转发到串口1,可以通串口1打印到屏幕 } memset(RxBuf,0,RxMaxLen); HAL_UARTEx_ReceiveToIdle_IT(&huart3, RxBuf, RxMaxLen); //接收串口3收到的信息,并再次开启串口3的接收中断 } /* USER CODE END PV */ /* Private function prototypes -----------------------------------------------*/ void SystemClock_Config(void); /* USER CODE BEGIN PFP */ /* USER CODE END PFP */ /* Private user code ---------------------------------------------------------*/ /* USER CODE BEGIN 0 */ DHT11_Data_TypeDef dht11_rec_buf[]={0,0,0,0,0,0.0,0.0}; int fputc(int ch ,FILE *f) { HAL_UART_Transmit(&huart1,(uint8_t *)&ch,1,0xffff); return ch; } typedef struct { float temperature; } DHT11RecBuf; /* USER CODE END 0 */ /** * @brief The application entry point. * @retval int */ int main(void) { /* USER CODE BEGIN 1 */ /* USER CODE END 1 */ /* MCU Configuration--------------------------------------------------------*/ /* Reset of all peripherals, Initializes the Flash interface and the Systick. */ HAL_Init(); /* USER CODE BEGIN Init */ DHT11RecBuf *dht11_rec_buf = (DHT11RecBuf*)malloc(sizeof(DHT11RecBuf)); /* USER CODE END Init */ /* Configure the system clock */ SystemClock_Config(); /* USER CODE BEGIN SysInit */ /* USER CODE END SysInit */ /* Initialize all configured peripherals */ MX_GPIO_Init(); MX_USART1_UART_Init(); MX_USART3_UART_Init(); /* USER CODE BEGIN 2 */ DHT11_Init(); HAL_UARTEx_ReceiveToIdle_IT(&huart3, RxBuf, RxMaxLen); //开启串口3的接收中断,仅一次 ProjectConn(); //wifi连接热点 /* USER CODE END 2 */ /* Infinite loop */ /* USER CODE BEGIN WHILE */ while (1) { char atJsonSens[128]; sprintf(atJsonSens, "{\"t\":3,\"datatype\":1,\"datas\":{\"temp\":\"%.2f\"},\"msgid\":123}\r\n", dht11_rec_buf->temperature); SenAtCom(atTcp); //连接云端服务器 HAL_Delay(100); SenAtCom(atSendConn); //发送上传数据的字节数 HAL_Delay(100); SenAtCom(atJsonConn); //连接云端服务器上的设备 HAL_Delay(2000); SenAtCom(atSendSens); //发送上传数据的字节数(要与发送的JSON数据字节数完全一致) HAL_Delay(100); SenAtCom(atJsonSens); //上传传感器数据 HAL_Delay(3000); /* USER CODE END WHILE */ free(dht11_rec_buf); /* USER CODE BEGIN 3 */ } /* USER CODE END 3 */ } /** * @brief System Clock Configuration * @retval None */ void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Initializes the CPU, AHB and APB busses clocks */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; RCC_OscInitStruct.HSEState = RCC_HSE_ON; RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB busses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) { Error_Handler(); } } /* USER CODE BEGIN 4 */ /* USER CODE END 4 */ /** * @brief This function is executed in case of error occurrence. * @retval None */ void Error_Handler(void) { /* USER CODE BEGIN Error_Handler_Debug */ /* User can add his own implementation to report the HAL error return state */ /* USER CODE END Error_Handler_Debug */ } #ifdef USE_FULL_ASSERT /** * @brief Reports the name of the source file and the source line number * where the assert_param error has occurred. * @param file: pointer to the source file name * @param line: assert_param error line source number * @retval None */ void assert_failed(uint8_t *file, uint32_t line) { /* USER CODE BEGIN 6 */ /* User can add his own implementation to report the file name and line number, tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ /* USER CODE END 6 */ } #endif /* USE_FULL_ASSERT */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
06-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值